有2个文件
pc.v : 读指令
id.v : 译码
pineline :流水线控制
id.v
{
...
//当前读取的4字节指令
input wire[31:0] inst;
//流水线控制标志
input wire[8:0] flg_pineline;
...
//------------------------------------
//以下用c表达
//当前指令,假设指令最大长度 12*4=48字节
unsiged char * cur_pc = malloc(48);
//下一条指令,假设指令最大长度 12*4=48字节
unsiged char * next_pc = malloc(48);
//全局变量,如果一条指令读取完成
//如果10字节的指令,要分3次,
//期间每次都是 false,最后完成是 true
flg_inst_complete;
//指令总长度
inst_tot_len;
//本次读取指令的长度(如:10自己指令,
//前2次为4字节,最后一次读取的指令
//长度为2字节,另外2字节为下一指令的)
inst_cur_len;
//指令剩余长度
inst_left_len;
//cur_pc[cur_pos]
int cur_pos ;
........
译码分析
.........
//最后
for(i=inst_cur_len;i>0; i--)
{
cur_pc[cur_pos] = inst[i];
cur_pos++;
}
//读取12字节,有10字节是当前指令,
//2字节为下一条指令
if(flg_inst_complete == true)
{
cur_pos = 0;
for(i=(32 - inst_cur_len);i>0; i--)
{
next_pc[cur_pos] = inst[i];
cur_pos++;
}
}
//-----------------------------------
}
问题:
1)以上c逻辑如果用 verilog hdl 表达,该如何写?
2)全局变量的初始值(flg_inst_complete=true,
inst_len_dword_cnt=0)该怎样赋值?
在c里简单,main函数里赋值即可;
但在verilog hdl里,该怎样做?
| 有奖活动 | |
|---|---|
| 这个春节你犒赏自己什么了?分享你的故事,有奖征集 | |
| 2026年“我要开发板活动”第三季,开始了! | |
| 硬核工程师专属补给计划——填盲盒 | |
| “我踩过的那些坑”主题活动——第002期 | |
| 【EEPW电子工程师创研计划】技术变现通道已开启~ | |
| 发原创文章 【每月瓜分千元赏金 凭实力攒钱买好礼~】 | |
| 【EEPW在线】E起听工程师的声音! | |
| 高校联络员开始招募啦!有惊喜!! | |
我要赚赏金打赏帖 |
|
|---|---|
| 【S32K3XX】Standby RAM的初始化流程被打赏¥18元 | |
| Gravity:中英文语音合成模块V2.0及其串口控制被打赏¥24元 | |
| 全彩色度变化图的绘制被打赏¥27元 | |
| 【FreeRtos】FreeRtos任务栈的生长方向管理方式被打赏¥20元 | |
| 【瑞萨RA8D1 LVGL/LWIP评测】LVGL添加输入设备:EC11旋转编码器被打赏¥39元 | |
| 【瑞萨RA8D1 LVGL/LWIP评测】RA8D1部署FreeRTOS+LVGL被打赏¥33元 | |
| 空气质量检测器设计与实现被打赏¥24元 | |
| 【瑞萨RA8D1 LVGL/LWIP评测】LWIP进行UDP、TCP、HTTP、MQTT功能联合测试被打赏¥41元 | |
| 【瑞萨RA8D1 LVGL/LWIP评测】RA8D1部署FreeRTOS+LWIP被打赏¥36元 | |
| RTOS怎么选?让我来给你答案!被打赏¥15元 | |
我要赚赏金
