【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 总线都准备好了之后才进行写操作。

相关推荐
Q_219327645514 小时前
基于ARM的嵌入式温度控制系统的设计
arm开发
想你依然心痛19 小时前
从x86到ARM的HPC之旅:鲲鹏开发工具链(编译器+数学库+MPI)上手与实战
java·开发语言·arm开发·鲲鹏·昇腾
MUTA️19 小时前
x86 架构下运行 ARM-ROS2 Docker 镜像操作指南
arm开发·docker·架构
比奇堡派星星2 天前
Linux 杂项设备驱动框架详解
linux·arm开发·驱动开发
xingzhemengyou12 天前
LINUX 通过/proc/interrupts了解系统硬件中断的使用情况
linux·arm开发
rfidunion2 天前
ubuntu下使用qemu模拟ARM(一)-------安装samba服务器
服务器·arm开发·ubuntu
三佛科技-134163842122 天前
FT32F072xx、FT32F072xB、FT32F072x6/x8基于ARM Cortex-M0内核32位单片机分析
arm开发·单片机·嵌入式硬件·智能家居·pcb工艺
p66666666682 天前
STM32(基于 ARM Cortex-M 内核)中函数调用栈帧的开辟 销毁过程
arm开发·stm32·嵌入式硬件
星空真迷人3 天前
嵌入式 WiFi 加持 普通设备也能联网 “唠嗑”
arm开发·stm32·单片机·嵌入式硬件·物联网·iot
灵哎惹,凌沃敏3 天前
FreeRTOS 任务上下文切换核心函数:xPortPendSVHandler详解
c语言·arm开发