精华内容
下载资源
问答
  • STM32 系列之 DAC 寄存器运用于理解

    千次阅读 2018-06-10 16:41:49
    在这里,我也不多BB,基本是看了原子的PDF之后,自己理解。所以可能比较简略 单个DAC通道如下: VDDA 和VSSA为模拟电源...控制DAC的寄存器是 DAC_CR 共32位,底16位用于控制通道1,高16位用于控制通道2. 标准库代码:

    在这里,我也不多BB,基本是看了原子的PDF之后,自己理解。所以可能比较简略


    单个DAC通道如下:



    VDDA 和VSSA为模拟电源端。  

    输出电压 = Vref+ * (DORx/2^n)                  n为DAC的数据位数

    DORx 不能直接用户操作,所以只能操作DHRx。(看上图)


    控制DAC的寄存器是 DAC_CR  共32位,底16位用于控制通道1,高16位用于控制通道2.



    标准库代码:


    展开全文
  • 寄存器

    千次阅读 2016-09-04 22:24:52
    8086 有14个16位寄存器,这14个寄存器按其用途可分为(1)通用寄存器、(2)指令指针、(3)标志寄存器和(4)段寄存器等4类。 通用寄存器 有8个, 又可以分成2组,一组是数据寄存器(4个),另一组是指针寄存器及...

    8086寄存器

    编辑
    8086 有14个16位 寄存器,这14个寄存器按其用途可分为(1) 通用寄存器、(2)指令指针、(3) 标志寄存器和(4) 段寄存器等4类。

    通用寄存器

    有8个, 又可以分成2组,一组是 数据寄存器(4个),另一组是指针寄存器及 变址寄存器(4个).
    顾名思义, 通用寄存器是那些你可以根据自己的意愿使用的寄存器,修改他们的值通常不会对 计算机的运行造成很大的影响。
    数据寄存器分为:
    AH&AL=AX(accumulator): 累加寄存器,常用于运算;在乘除等 指令中指定用来存放 操作数,另外,所有的 I/O指令都使用这一寄存器与外界设备传送数据。
    BH&BL=BX(base): 基址 寄存器,常用于地址索引
    CH&CL=CX(count):计数 寄存器,常用于计数;常用于保存计算值,如在 移位指令,循环(loop)和串处理指令中用作隐含的计数器.
    寄存器 寄存器
    DH&DL=DX(data): 数据寄存器,常用于数据传递。
    他们的特点是,这4个16位的 寄存器可以分为高8位: AH, BH, CH, DH.以及低八位:AL,BL,CL,DL。这2组8位 寄存器可以分别寻址,并单独使用。
    另一组是 指针 寄存器变址寄存器,包括:
    SP(Stack Pointer): 堆栈指针,与SS配合使用,可指向目前的堆栈位置
    BP(Base Pointer): 基址 指针 寄存器,可用作SS的一个相对基址位置
    SI(Source Index):变址 寄存器,可用来存放相对于DS段之源变址指针
    DI(Destination Index):目的 变址 寄存器,可用来存放相对于ES 段之目的变址 指针
    这4个16位 寄存器只能按16位进行存取操作,主要用来形成 操作数的地址,用于 堆栈操作和 变址运算中计算操作数的 有效地址

    指令指针IP

    指令指针IP是一个16位专用 寄存器,它指向当前需要取出的指令 字节,当BIU从 内存中取出一个指令字节后,IP就自动加(取出该字节的长度,如:BIU从内存中取出的是1个字节,IP就会自动加1,如果BIU从内存中取出的字节数长度为3,IP就自动加3),指向下一个指令字节。注意,IP指向的是 指令地址的段内地址 偏移量,又称 偏移地址(Offset Address)或 有效地址(EA,Effective Address)。

    标志寄存器

    8086有一个16位的标志性 寄存器FR,在FR中有意义的有9位,其中6位是状态位,3位是控制位。 标志寄存器(Flags Register,FR)又称 程序状态字(Program Status Word,PSW)。这是一个存放条件标志、控制 标志寄存器,主要用于反映处理器的状态和运算 结果的某些特征及控制 指令的执行。
    标志寄存器位置图: [4]  
    15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0
            OF DF IF TF SF ZF   AF   PF   CF
    OF:溢出标志位OF用于反映有 符号数加减运算所得 结果是否溢出。如果运算 结果超过当前运算位数所能表示的范围,则称为溢出,OF的值被置为1,否则,OF的值被清为0。
    DF:方向标志DF位用来决定在串操作 指令执行时有关指针 寄存器发生调整的方向。
    IF:中断允许标志IF位用来决定CPU是否响应CPU外部的 可屏蔽中断发出的 中断请求。但不管该标志为何值,CPU都必须响应CPU外部的不可屏蔽中断所发出的 中断请求,以及CPU内部产生的 中断请求。具体规定如下:
    (1)、当IF=1时,CPU可以响应CPU外部的 可屏蔽中断发出的 中断请求
    (2)、当IF=0时,CPU不响应CPU外部的 可屏蔽中断发出的中断请求。
    TF:跟踪标志TF。该标志可用于 程序调试。TF标志没有专门的 指令来设置或清除。
    (1)如果TF=1,则CPU处于单步执行 指令的工作方式,此时每执行完一条指令,就显示CPU内各个 寄存器的当前值及CPU将要执行的下一条指令。
    (2)如果TF=0,则处于连续工作模式。
    SF: 符号标志SF用来反映运算 结果的符号位,它与运算结果的最高位相同。在 微机系统中, 有符号数采用补码表示法,所以,SF也就反映运算 结果的正负号。运算 结果为非负数时,SF的值为0,否则其值为1。当运算 结果没有产生溢出时,运算结果等于逻辑结果(即应该得到的正确的结果),此时SF表示的是逻辑结果的正负,当运算结果产生溢出时,运算结果不等于逻辑结果,此时的SF值所表示的正负情况与逻辑结果相反,即:SF=0时,逻辑结果为负,SF=1时,逻辑结果为非负。
    ZF:零标志ZF用来反映运算 结果是否为0。如果运算 结果为0,则其值为1,否则其值为0。在判断运算结果
    寄存器 寄存器
    是否为0时,可使用此标志位。
    AF:( Assistant Carry Flag)下列情况下, 辅助进位标志AF的值被置为1,否则其值为0:
    (1)、在字操作时,发生低 字节向高字节进位或借位时
    (2)、在 字节操作时,发生低4位向高4位进位或借位时。
    PF:奇偶标志PF用于反映运算 结果中“1”的个数的奇偶性。如果“1”的个数为偶数,则PF的值为1,否则其值为0。
    CF:进位标志CF主要用来反映无 符号数运算是否产生进位或借位。如果运算 结果的最高位产生了一个进位或借位,那么,其值为1,否则其值为0。

    段寄存器

    为了运用所有的 内存空间,8086设定了四个 段寄存器,专门用来保存 段地址
    寄存器 寄存器
    CS(Code Segment): 代码段寄存器
    DS(Data Segment):数据 段寄存器
    SS(Stack Segment): 堆栈段 寄存器
    ES(Extra Segment):附加 段寄存器
    当一个程序要执行时,就要决定程序代码、数据和 堆栈各要用到 内存的哪些位置,通过设定 段寄存器CS,DS,SS 来指向这些起始位置。通常是将DS固定,而根据需要修改CS。所以,程序可以在可 寻址空间小于64K的情况下被写成任意大小。所以,程序和其数据组合起来的大小,限制在DS 所指的64K内,这就是COM文件不得大于64K的原因。8086以 内存作为战场,用 寄存器做为军事基地,以加速工作。
    备注:由于所讲的是16位cpu(IP 寄存器的位数为16,即: 偏移地址为16位)2的16次幂就是64K,所以16位 段地址不能超过64K,超过64K会造成64K以上的地址找不到。

    展开全文
  • 和 A 的ascii比较,修改标志寄存器  jb s  ; 小于 A 就跳转,不用大小写转换  cmp byte ptr[si] , 7Ah ; 和 z 的ascii比较,修改标志寄存器  ja s ; 大于 z 就跳转  and byte ...
    assume cs:codesg
    datasg segment
            db "Beginner's All-purpose Symbolic Instruction Code." , 0
    datasg ends
    codesg segment
    start:  mov ax , datasg
            mov ds , ax
            mov si , 0
            call letterc             ; 调用子程序
            mov ax , 4c00h
            int 21h
    letterc:mov cl , [si]
            mov ch , 0
            jcxz finish               ; 如果读到最后的 0 就跳转
            cmp byte ptr[si] , 41h                         ; 和 A 的ascii比较,修改标志寄存器
            jb s                              ; 小于 A 就跳转,不用大小写转换
            cmp byte ptr[si] , 7Ah                         ; 和 z 的ascii比较,修改标志寄存器
            ja s                           ; 大于 z 就跳转
            and byte ptr[si] , 11011111b      ; 小写改大写
    s:        inc si
            jmp short letterc
    finish:        ret       ; 程序结束,跳转执行call后的指令
    codesg ends
    end start
    VAAAgHF4ly8AAEACJFQAAIAESKgAAAAJkFABAAASIKECAAAk8D++cts4k1FopQAAAABJRU5ErkJggg==

    NKZjp9tZVxOz+4XOIzpd2Zf2C51NdOClvOP80dnY7xh27gUAAKznHeePSmlYqj9ontRcN4l6+4UOOuigE0ZZqShfUH7xjvNHpXZ1HTtNH31C54Yq9njtRAcddP6OTgBppaV8TTkAAAAAAAAAAAAAAAAAAAAAAAAAAAAs4H+Yg+9TGA6jFAAAAABJRU5ErkJggg==


     

    转载于:https://www.cnblogs.com/meihao1203/p/8023260.html

    展开全文
  • 寄存器详解

    千次阅读 2012-12-07 18:09:14
    AX/EAX: 累加器,算术通用寄存器,与端口的通讯也用这个寄存器. BX/EBX: 基址寄存器. CX/ECX: 计数器,结合串处理指令使用. DX/EDX: 算术通用寄存器.和累加器结合表示双字长的数,其中累加器用于存低位数. ...
    AX/EAX: 累加器,算术通用寄存器,与端口的通讯也用这个寄存器.
    
    BX/EBX: 基址寄存器.
    CX/ECX: 计数器,结合串处理指令使用.
    DX/EDX: 算术通用寄存器.和累加器结合表示双字长的数,其中累加器用于存低位数.



    [From]http://blog.csdn.net/huangwei1024/archive/2007/01/29/1496560.aspx

    2.1 寄存器组

    寄存器是CPU内部重要的数据存储资源,是汇编程序员能直接使用的硬件资源之一。由于寄存器的存取速度比内存快,所以,在用汇编语言编写程序时,要尽可能充分利用寄存器的存储功能。

    寄存器一般用来保存程序的中间结果,为随后的指令快速提供操作数,从而避免把中间结果存入内存,再读取内存的操作。在高级语言(如:C/C++语言)中,也有定义变量为寄存器类型的,这就是提高寄存器利用率的一种可行的方法。

    另外,由于寄存器的个数和容量都有限,不可能把所有中间结果都存储在寄存器中,所以,要对寄存器进行适当的调度。根据指令的要求,如何安排适当的寄存器,避免操作数过多的传送操作是一项细致而又周密的工作。有关“寄存器的分配策略”在后续课程《编译原理》中会有详细的介绍。

    由于16位/32位CPU是微机CPU的两个重要代表,所以,在此只介绍它们内部寄存器的名称及其主要功能。

    2.1.1 寄存器组

    1、 16位寄存器组

    16位CPU所含有的寄存器有(见图2.1中16位寄存器部分):

    4个数据寄存器(AX、BX、CX和DX)

    2个变址和指针寄存器(SI和DI)2个指针寄存器(SP和BP)

    4个段寄存器(ES、CS、SS和DS)

    1个指令指针寄存器(IP)1个标志寄存器(Flags)

    2、 32位寄存器组

    32CPU除了包含了先前CPU的所有寄存器,并把通用寄存器、指令指针和标志寄存器从16位扩充成32位之外,还增加了216位的段寄存器:FSGS

    32位CPU所含有的寄存器有(见图2.1中的寄存器):

    4个数据寄存器(EAX、EBX、ECX和EDX)

    2个变址和指针寄存器(ESI和EDI)2个指针寄存器(ESP和EBP)

    6个段寄存器(ES、CS、SS、DS、FSGS)

    1个指令指针寄存器(EIP)1个标志寄存器(EFlags)
    寄存器详解
    寄存器详解
    寄存器详解

    图2.1 CPU寄存器组的示意图

    2.1.2、通用寄存器的作用

    通用寄存器可用于传送和暂存数据,也可参与算术逻辑运算,并保存运算结果。除此之外,它们还各自具有一些特殊功能。汇编语言程序员必须熟悉每个寄存器的一般用途和特殊用途,只有这样,才能在程序中做到正确、合理地使用它们。

    表2.1 通用寄存器的主要用途

    寄存器的分类寄存器

    主 要 用 途

    数据

     

    寄存器

    AX

    乘、除运算,字的输入输出,中间结果的缓存

    AL

    字节的乘、除运算,字节的输入输出,十进制算术运算

    AH

    字节的乘、除运算,存放中断的功能号

    BX

    存储器指针

    CX

    串操作、循环控制的计数器

    CL

    移位操作的计数器

    DX

    字的乘、除运算,间接的输入输出

    变址
    寄存器
    SI

    存储器指针、串指令中的源操作数指针

    DI

    存储器指针、串指令中的目的操作数指针

    变址
    寄存器
    BP

    存储器指针、存取堆栈的指针

    SP

    堆栈的栈顶指针

    指令指针

    IP/EIP
    标志位寄存器Flag/EFlag
    32位

    CPU的

    段寄存器

    16位CPU的

    段寄存器

    ES附加段寄存器
    CS代码段寄存器
    SS堆栈段寄存器
    DS数据段寄存器
    新增加的
    段寄存器
    FS附加段寄存器
    GS附加段寄存器

    更详细的内容请点击:通用寄存器功能的说明

    2.1.3、专用寄存器的作用

    16CPU内部有一个16位的标志寄存器,它包含9个标志位。这些标志位主要用来反映处理器的状态和运算结果的某些特征。各标志位在标志寄存器内的分布如图2.2所示。

    1514131211109876543210
    OFDFIFTFSFZF AF PF CF

    3117161514131211109876543210
    VMRFNTIOPLOFDFIFTFSFZF AFPFCF

    图2.2 16位/32位标志寄存器的示意图

    上面9个标志位可分为二组:运算结果标志位(有背景色的标志位)和状态控制标志位。前者受算术运算逻辑运算结果的影响,后者受一些控制指令执行的影响。

    更详细的内容请点击:标志位的说明

    有些指令的执行会改变标志位(如:算术运算指令等),不同的指令会影响不同的标志位,有些指令的执行不改变任何标志位(如:MOV指令等),有些指令的执行会受标志位的影响(如:条件转移指令等),也有指令的执行不受其影响。

    程序员要想熟练运用这些标志位,就必须掌握每个标志位的含义、每条指令的执行条件和执行结果对标志位的作用。

    注意:虽然知道每个标志位在标志寄存器内的具体位置是有好处的,但通常情况下,没有这个必要。在使用第5.2.9节中的“条件转移指令”时,系统会自动引用相应标志位的值来决定是否需要“转移”的,所以,不必过分强调标志位在标志寄存器内的具体位置。

    展开全文
  • 8086寄存器

    2017-04-25 13:19:10
    8086 有14个16位寄存器,这14个寄存器按其用途可分为(1)通用寄存器、(2)指令指针、(3)标志寄存器和(4)段寄存器等4类。 通用寄存器 有8个, 又可以分成2组,一组是数据寄存器(4个),另一组是指针寄存器及变址...
  • 寄存器,寄存器是什么意思寄存器定义寄存器是中央处理器内的组成部分。寄存器是有限存贮容量的高速存贮部件,它们可用来暂存指令、数据和位址。在中央处理器的控制部件中,包含的寄存器有指令寄存器(IR)和程序计数器...
  • 单片机DPTR(DPH,DPL)和SP特殊寄存器C语言...这三个特殊寄存器对C程序员来说是透明的,不用C程序员操作,编译的时候会自动运用这三个寄存器 编译器把C译成指令序列时,会根据具体情况处理SP,相对于C的使用者是透明的。...
  • cpu寄存器

    2019-03-27 16:59:51
    8086 有14个16位寄存器,这14个寄存器按其用途可分为(1)通用寄存器、(2)指令指针、(3)标志寄存器和(4)段寄存器等4类。 通用寄存器 通用寄存器有8个, 又可以分成2组,一组是数据寄存器(4个),另一组是指针寄存器及变址...
  • nrf2401寄存器

    2013-04-16 11:30:11
    nrf2401所有寄存器介绍及运用,学习2401必备
  • 寄存器运用 8086CPU有14个寄存器 它们的名称为: AX、BX、CX、DX、SI、DI、SP、BP、 IP、CS、SS、DS、ES、PSW (1)加法与减法:AX、BX、CX、DX、BP、SI、DI、SP——通用寄存器 (2)乘法与除法:DX、AX(字操作),...
  • 寄存器寻址

    万次阅读 2017-04-05 20:24:06
    一、寄存器 总共有14个16位寄存器,8个8位寄存器。   通用寄存器:  数据寄存器:  AH(8位) AL(8位) AX(16位) (AX和AL又称累加器)  BH(8位) BL(8位) BX(16位) (BX又称基址寄存器,唯一作为存储器...
  • 汇编语言:寄存器相关概念初理解(通用寄存器、段寄存器、专用寄存器) 1.寄存器分类 一图抵千言: 2.详细介绍及注意事项 (1)AX BX CX DX被称为通用寄存器(可被分割为2个8位寄存器),存放数据的,数据寄存器(16...
  • 汇编-寄存器

    2017-11-07 20:40:45
    一个字可以存放在16位寄存器中,这个字的高位字节和低位字节自然就存放在这个寄存器的高8位寄存器和第八位寄存器中。 在对寄存器进行计算的过程中,在计算单个寄存器的时候会出现丢失,但是这里的丢失指的是进位制...
  • 寄存器的认识

    2019-07-23 08:53:55
    寄存器是中央处理器内的组成部分。寄存器是有限存贮容量的高速存贮部件,它们可用来暂存指令、数据和地址。 对于8086的系统: 1.寄存器按照功能的不同可分为通用寄存器(ax,bx,cx,dx,sp,bp,si,di。其中的前...
  • [From]AX/EAX: 累加器,算术通用寄存器,与端口的通讯也用这个寄存器.BX/EBX: 基址寄存器.CX/ECX: 计数器,结合串处理指令使用.DX/EDX: 算术通用寄存器.和累加器结合表示双字长的数,其中累加器用于存低位数.[From]...

空空如也

空空如也

1 2 3 4 5 ... 20
收藏数 21,075
精华内容 8,430
关键字:

寄存器运用