SECTION("using uninitialized chip throws logic_error")
        {
-               REQUIRE_THROWS_AS(chip.name(), ::std::logic_error&);
+               REQUIRE_THROWS_AS(chip.name(), ::std::logic_error);
        }
 }
 
 
 TEST_CASE("Trying to open a nonexistent chip throws system_error", "[chip]")
 {
-       REQUIRE_THROWS_AS(::gpiod::chip("nonexistent-chip"), ::std::system_error&);
+       REQUIRE_THROWS_AS(::gpiod::chip("nonexistent-chip"), ::std::system_error);
 }
 
 TEST_CASE("Chip object can be reset", "[chip]")
 
        SECTION("invalid offset (single line)")
        {
-               REQUIRE_THROWS_AS(chip.get_line(9), ::std::out_of_range&);
+               REQUIRE_THROWS_AS(chip.get_line(9), ::std::out_of_range);
        }
 
        SECTION("invalid offset (multiple lines)")
        {
-               REQUIRE_THROWS_AS(chip.get_lines({ 1, 19, 4, 7 }), ::std::out_of_range&);
+               REQUIRE_THROWS_AS(chip.get_lines({ 1, 19, 4, 7 }), ::std::out_of_range);
        }
 
        SECTION("line not found by name")
 
 
        SECTION("error if not requested")
        {
-               REQUIRE_THROWS_AS(line.event_get_fd(), ::std::system_error&);
+               REQUIRE_THROWS_AS(line.event_get_fd(), ::std::system_error);
        }
 
        SECTION("error if requested for values")
                config.request_type = ::gpiod::line_request::DIRECTION_INPUT;
 
                line.request(config);
-               REQUIRE_THROWS_AS(line.event_get_fd(), ::std::system_error&);
+               REQUIRE_THROWS_AS(line.event_get_fd(), ::std::system_error);
        }
 }
 
 
        {
                auto lines = chip.get_all_lines();
 
-               REQUIRE_THROWS_AS(lines.get(11), ::std::out_of_range&);
+               REQUIRE_THROWS_AS(lines.get(11), ::std::out_of_range);
        }
 }
 
        line.release();
 
        REQUIRE_FALSE(line.is_requested());
-       REQUIRE_THROWS_AS(line.get_value(), ::std::system_error&);
+       REQUIRE_THROWS_AS(line.get_value(), ::std::system_error);
 }
 
 TEST_CASE("Uninitialized GPIO line behaves correctly", "[line]")
 
        SECTION("using uninitialized line throws logic_error")
        {
-               REQUIRE_THROWS_AS(line.name(), ::std::logic_error&);
+               REQUIRE_THROWS_AS(line.name(), ::std::logic_error);
        }
 }
 
 
        SECTION("using uninitialized line_bulk throws logic_error")
        {
-               REQUIRE_THROWS_AS(bulk.get(0), ::std::logic_error&);
+               REQUIRE_THROWS_AS(bulk.get(0), ::std::logic_error);
        }
 }
 
                auto line = chip.get_line(3);
 
                REQUIRE_NOTHROW(line.request(config));
-               REQUIRE_THROWS_AS(line.request(config), ::std::system_error&);
+               REQUIRE_THROWS_AS(line.request(config), ::std::system_error);
        }
 
        SECTION("request the same line twice in line_bulk")
                 */
                auto lines = chip.get_lines({ 2, 3, 4, 4 });
 
-               REQUIRE_THROWS_AS(lines.request(config), ::std::system_error&);
+               REQUIRE_THROWS_AS(lines.request(config), ::std::system_error);
        }
 }
 
 
        SECTION("get value")
        {
-               REQUIRE_THROWS_AS(line.get_value(), ::std::system_error&);
+               REQUIRE_THROWS_AS(line.get_value(), ::std::system_error);
        }
 
        SECTION("set value")
        {
-               REQUIRE_THROWS_AS(line.set_value(1), ::std::system_error&);
+               REQUIRE_THROWS_AS(line.set_value(1), ::std::system_error);
        }
 }