【ARM AMBA APB 入门 1.1 -- APB 读写寄存器 RTL 实现】

请阅读【ARM AMBA 总线 文章专栏导读】


文章目录

    • [APB 寄存器访问](#APB 寄存器访问)
      • [APB 读寄存器 RTL 代码实现](#APB 读寄存器 RTL 代码实现)
      • [APB 写寄存器 RTL 代码实现](#APB 写寄存器 RTL 代码实现)

APB 寄存器访问

APB 读寄存器 RTL 代码实现

APB 总线读寄存器操作代码实现:

bash 复制代码
wire [31:0] SOC_PLL_CFG_REG;
wire [31:0] SOC_PLL_LOCK_REG;
wire [31:0] SOC_PLL_BP_REG;

always@(posedge clk) begin
  if(psel & (~pwrite)) begin
  case(paddr)
    32'b00000000 + 32'h10 : prdata <= SOC_PLL_CFG_REG;
    32'b00000000 + 32'h14 : prdata <= SOC_PLL_LOCK_REG;
    32'b00000000 + 32'h18 : prdata <= SOC_PLL_BP_REG;
    default: prdata <= 32'hdeadbeaf;
  endcase
  end
end

assign SOC_PLL_CFG_REG[31:24] = 8'b0;
assign SOC_PLL_CFG_REG[23:12] = soc_pll_cfg_reg_rd;
assign SOC_PLL_CFG_REG[11:9] = soc_pll_postdiv1;
assign SOC_PLL_CFG_REG[8:6] = SOC_PLL0_postdiv2;
assign SOC_PLL_CFG_REG[5:0] = soc_pll_postdvi2;

从上面代码可以看到 当 psel 为 高,且 pwrite 为 低的时候 去判断 paddr 的地址对应哪个寄存器的地址,然后将该寄存器的值赋值给 prdata。

同时也可以看到,SOC_PLL_CFG_REG 位域中的各个值,来源于不同的信号。

APB 写寄存器 RTL 代码实现

bash 复制代码
reg_wr = psel & pwrite & penable;
reg_rd = psel & (~pwrite)
assign soc_pll_cfg_reg_wr = (paddr == 32'h00000000 + 32'h10) & reg_wr;
assign soc_pll_cfg_reg_rd = (paddr == 32'h00000000 + 32'h10) & reg_rd;

always@(posedge clk or negedge rst_n) begin
  if(!rst_n) begin
    soc_pll_cfg_reg_rd < 12'd57;
  end
  else if (soc_pll_cfg_reg_wr) begin
    soc_pll_cfg_reg_rd < pwdata[23:12];
  end
end

always@(posedge clk or negedge rst_n) begin
  if(!rst_n) begin
    soc_pll_postdiv1 < 3'b0;
  end
  else if (soc_pll_cfg_reg_wr) begin
    soc_pll_postdiv1 < pwdata[11:9];
  end
end

always@(posedge clk or negedge rst_n) begin
  if(!rst_n) begin
    soc_pll_postdiv2 < 3'b3;
  end
  else if (soc_pll_cfg_reg_wr) begin
    soc_pll_postdvi2 < pwdata[8:6];
  end
end
always@(posedge clk or negedge rst_n) begin
  if(!rst_n) begin
    soc_pll_postdvi2 < 6'd4;
  end
  else if (soc_pll_cfg_reg_wr) begin
    soc_pll_postdvi2 < pwdata[5:0];
  end
end

从上面的代码中可以看到,在写 SOC_PLL_CFG_REG 这个寄存器的的时候需要先保证 soc_pll_cfg_reg_wr 这个信号为高,这个信号的作用是保证 寄存器的地址已经 APB 总线都准备好了之后才进行写操作。

相关推荐
17(无规则自律)3 小时前
深入浅出 Linux 内核模块,写一个内核版的 Hello World
linux·arm开发·嵌入式硬件
梁洪飞16 小时前
内核的schedule和SMP多核处理器启动协议
linux·arm开发·嵌入式硬件·arm
代码游侠1 天前
学习笔记——Linux字符设备驱动
linux·运维·arm开发·嵌入式硬件·学习·架构
syseptember2 天前
Linux网络基础
linux·网络·arm开发
代码游侠2 天前
学习笔记——Linux字符设备驱动开发
linux·arm开发·驱动开发·单片机·嵌入式硬件·学习·算法
程序猿阿伟2 天前
《Apple Silicon与Windows on ARM:引擎原生构建与模拟层底层运作深度解析》
arm开发·windows
wkm9562 天前
在arm64 ubuntu系统安装Qt后编译时找不到Qt3DExtras头文件
开发语言·arm开发·qt
unicrom_深圳市由你创科技2 天前
基于ARM+DSP+FPGA异构计算架构的高速ADC采集卡定制方案
arm开发·fpga开发
松涛和鸣2 天前
DAY69 Practical Guide to Linux Character Device Drivers
linux·服务器·arm开发·数据库·单片机·嵌入式硬件
松涛和鸣2 天前
69、Linux字符设备驱动实战
linux·服务器·网络·arm开发·数据库·驱动开发