[SV]SystemVerilog Semaphore

本文详细介绍了SystemVerilog内置类Semaphore,如何通过桶的概念实现对共享资源的访问控制和同步。讲解了Semaphore的方法,如new(), get(), put(), try_get(),并用示例说明了其在多进程并发环境中的应用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Semaphore

        Semaphore是一个SystemVerilog内置类,用于对共享资源的访问控制和基本同步。

        信号量就像一个包含键数的桶。使用信号量的进程必须首先从bucket中获取一个键,然后才能继续执行。所有其他进程必须等待,直到有足够数量的键返回到bucket。

假设有两个进程试图访问一个共享内存区域。其中一个进程试图写入,而另一个进程试图读取相同的内存位置。这导致一个不可预测的结果。信号量可以用来克服这种情况。

Semaphore 语法

semaphore semaphore_name;

 Semaphore 方法

        Semaphore是一个内置类,它提供以下方法:

        new():  创建一个具有指定数量的 keys
        get():   从 bucket 中获取一个或者多个 keys
        put():   返回一个或者多个 keys 到 bucket 中
        try_get(): 在没有 blocking 的状态下,从 bucket 中获取一个或者多个 keys

1、new( );

    semaphore_name = new(numbers_of_keys);

        新方法将创建带有number_of_keys的信号量;其中number_of_keys为整型变量。.

        默认的键数是“0”

        new()方法将返回信号量句柄,如果不能创建信号量,则返回null

2. put( );

    semaphore_name.put(number_of_keys); or semaphore_name.put();

        semaphore 的 put() 方法 用于向 semaphore 返回 一个或者多个 key。

        当调用 semaphore 的 put() 方法时,将指定数量的键返回给信号量。默认返回的键数是1。

3、get( );

    semaphore_name.get(number_of_keys); or semaphore_name.get();

        semaphore 的 put() 方法 用于向 semaphore 获得 一个或者多个 key。

         当调用 semaphore 的 get() 方法时,如果指定的 keys 数可用,则该方法返回并继续执行,如果指定数量的 keys 不可用,则进程将阻塞,直到 keys 可用为止,请求的 keys 的默认数量是1。

4、try_get();

        semaphore 的 put() 方法 用于向 semaphore 获得 一个或者多个 key,但不会阻塞。

    semaphore_name.try_get(number_of_keys); or semaphore_name.try_get();

        当调用 semaphore 的 try_get() 方法时,如果指定的 keys 数可用,则该方法返回1并继续执行;如果指定的 keys 数不可用,则该方法返回0并继续执行。请求的 keys 的默认数量是1。

举例说明

       semaphore 的 sema 是用 1 个 key 创建的,两个进程同时访问 display 方法,但只有一个进程将获得信号量键,另一个进程将等待直到它获得 key。

module semaphore_ex;
  semaphore sema; //declaring semaphore sema
  initial begin
    sema=new(1); //creating sema with '1' key
    fork
      display(); //process-1
      display(); //process-2
    join
  end
 
  //display method
  task automatic display();
    sema.get(); //getting '1' key from sema
    $display($time,"\tCurrent Simulation Time");
    #30;
    sema.put(); //putting '1' key to sema
  endtask
endmodule


————————————————
原文链接:https://blog.csdn.net/gsjthxy/article/details/96446009

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值