当前位置: 首页 > news >正文

[SV]如何在UVM环境中使用C Model

在UVM环境中使用C Memory

一、C语言实现Memory

1.1 代码说明

  1. Memory 初始化
    • memory_init() 函数将内存空间初始化为 0,并初始化互斥锁。
  2. AXI 写操作 (axi_write)
    • 检查地址范围是否合法。
    • 使用 memcpy 将数据从输入缓冲区写入模拟内存。
    • 使用互斥锁保证线程安全。
  3. AXI 读操作 (axi_read)
    • 检查地址范围是否合法。
    • 使用 memcpy 从模拟内存读取数据到输出缓冲区。
    • 使用互斥锁保证线程安全。
  4. 线程安全
    • 通过 pthread_mutex_t 实现读写互斥,确保多线程环境下的安全操作。
  5. 测试代码
    • 模拟了 AXI 写和读操作。
    • 验证读出的数据是否与写入的数据一致。
#include <stdio.h>
#include <stdint.h>
#include <stdlib.h>
#include <string.h>
#include <pthread.h>#define MEMORY_SIZE 65536typedef struct {uint8_t memory[MEMORY_SIZE]; // 内存空间pthread_mutex_t lock;       // 互斥锁
} Memory;static Memory mem;// 初始化 Memory
void memory_init() {memset(mem.memory, 0, MEMORY_SIZE); // 初始化内存为 0pthread_mutex_init(&mem.lock, NULL); // 初始化互斥锁
}// 写操作:DPI 可调用
extern "C" int axi_write(uint32_t addr, const uint8_t *data, uint32_t size) {if (addr + size > MEMORY_SIZE) {fprintf(stderr, "AXI Write Error: Address out of range\n");return -1; // 地址越界}pthread_mutex_lock(&mem.lock); // 上锁memcpy(&mem.memory[addr], data, size); // 写入数据pthread_mutex_unlock(&mem.lock); // 
http://www.lryc.cn/news/505973.html

相关文章:

  • 十大开源的Cursor AI替代方案
  • 相机光学(四十六)——镜头马达(VCM)控制策略模式
  • 专业140+总分410+浙江大学842信号系统与数字电路考研经验浙大电子信息与通信工程,真题,大纲,参考书。
  • 了解ARM的千兆以太网——RK3588
  • JavaFX使用jfoenix的UI控件
  • Linux(Ubuntu)命令大全——已分类整理,学习、查看更加方便直观!(2024年最新编制)
  • 单片机:实现教学上下课的自动打玲(附带源码)
  • 进程通信方式---共享映射区(无血缘关系用的)
  • 深度学习实战智能交通计数
  • 【MySQL】MySQL表的操作
  • Redis篇-12--数据结构篇4--Hash内存模型(数组,链表,压缩列表zipList,哈希表,短结构)
  • 二、windows环境下vscode使用wsl教程
  • Qwen2-VL微调体验
  • 论文的模拟环境和实验环境
  • MySQL EXPLAIN 详解:一眼看懂查询计划
  • 自动呼入机器人如何与人工客服进行无缝切换?
  • 二分类模型的性能评价指标
  • 鸿蒙操作系统简介
  • 单片机:实现蜂鸣器数码管的显示(附带源码)
  • C语言期末复习笔记(上)
  • HarmonyOS 实时监听与获取 Wi-Fi 信息
  • Unity超优质动态天气插件(含一年四季各种天气变化,可用于单机局域网VR)
  • 1 JVM JDK JRE之间的区别以及使用字节码的好处
  • 【网络安全】网站常见安全漏洞—服务端漏洞介绍
  • MAPTR:在线矢量化高精地图构建的结构化建模与学习(2208)
  • 基于容器的云原生,让业务更自由地翱翔云端
  • 大屏开源项目go-view二次开发2----半环形控件(C#)
  • web:pc端企业微信登录-vue版
  • OpenGL ES 01 渲染一个四边形
  • 【ETCD】【源码阅读】深入解析 EtcdServer.applyEntries方法