微控制器数据寻址模式详解:从立即数到间接寻址

需积分: 15 18 下载量 53 浏览量 更新于2024-08-09 收藏 9.82MB PDF 举报
"PIC18(L)F2X/4XK22数据手册-采用XLP技术的28/40/44引脚低功耗、高性能单片机" 在微控制器编程中,数据寻址模式是至关重要的,因为它决定了处理器如何访问内存中的数据。在标题提及的"数据寻址模式-computational ocean acoustics"背景下,虽然具体应用可能涉及到海洋声学计算,但基本的数据寻址概念是通用的。 5.6 数据寻址模式主要涉及四种类型,适用于不同类型的指令和操作数: 1. **固有寻址**:这类寻址模式通常用于不需参数的控制指令,比如SLEEP、RESET和DAW。这些指令全局影响设备或隐式作用于一个特定的寄存器。 2. **立即数寻址**:在这种模式下,指令的参数是一个立即数,如ADDLW和MOVLW,它们分别向W寄存器添加或移动立即数值。CALL和GOTO指令也属于此类,它们包含20位的程序存储器地址。 3. **直接寻址**:直接寻址允许在指令中直接指定操作的数据源或目标地址的一部分。在PIC18系列中,针对位和字节的指令默认使用直接寻址。地址通常是一个8位立即数,可以指定数据RAM中的寄存器或快速操作存储区。如果地址的特定位"a"为1,存储区选择寄存器(BSR)的内容与直接地址结合,形成12位完整地址。若"a"为0,则直接地址指向快速操作存储区的一个寄存器。有些指令如MOVFF,包含完整的12位地址,无视BSR。 4. **间接寻址**:通过文件选择寄存器(FSR)作为指针,间接寻址允许动态访问数据存储器。FSR作为一个特殊的RAM中的寄存器,可以被程序直接修改。使用INDF进行寄存器间接寻址可以实现指针的自动递增、递减或偏移,提高代码效率,例如在例5-5中清零RAM的操作。 扩展指令集启用时,某些核心指令的行为可能会改变,这在处理数据存储器时尤其重要,如PIC18F25K22、PIC18F45K22、PIC18LF25K22和PIC18LF45K22等芯片。 理解这些寻址模式对于编写高效的、能够充分利用硬件资源的微控制器代码至关重要。不同的寻址模式在不同场景下各有优势,正确选择和使用可以优化程序性能和内存利用率。