SystemC-Components-Test/tests/ordered_semaphore/test.cpp

36 lines
948 B
C++
Raw Normal View History

2022-10-02 11:39:06 +02:00
#define SC_INCLUDE_DYNAMIC_PROCESSES
#include <scc/ordered_semaphore.h>
#include <scc/utilities.h>
#include <factory.h>
#include <catch2/catch_all.hpp>
#include <systemc>
using namespace sc_core;
2022-10-02 19:18:57 +02:00
struct top: public sc_core::sc_module {
top():top("top"){}
top(sc_module_name const& nm):sc_core::sc_module(nm) {}
2022-10-02 11:39:06 +02:00
scc::ordered_semaphore sem{"sem", 2};
scc::ordered_semaphore_t<2> sem_t{"sem_t"};
};
factory::add<top> tb;
TEST_CASE("simple ordered_semaphore test", "[SCC][ordered_semaphore]") {
auto& dut = factory::get<top>();
auto run1 = sc_spawn([&dut](){
dut.sem.wait();
dut.sem_t.wait();
dut.sem.set_capacity(4);
2022-10-02 19:18:57 +02:00
dut.sem_t.set_capacity(4); // should fail
2022-10-02 11:39:06 +02:00
dut.sem_t.post();
dut.sem.post();
});
sc_start(1_ns);
REQUIRE(run1.terminated());
2022-10-02 19:18:57 +02:00
REQUIRE(sc_report_handler::get_count(SC_ERROR) == 0);
REQUIRE(sc_report_handler::get_count(SC_WARNING) == 1);
2022-10-02 11:39:06 +02:00
}