段寄存器

        在8086系统中,访问存储器的地址码由段地址和段内偏移地址两部分组成。为什么会这样而不是直接用一个寄存器表示呢?举个例子,在16位CPU中,有20位地址线,也就是说可访问的地址空间为2^20=1M,但是CPU只有16位,相应的寄存器也只有16位,所以寄存器可表示的最大的数值为2^16=65536=64K<1M的,所以必须采用分段的方式来寻址了。段寄存器用来存放各分段的逻辑基值,并指示当前正在使用的4个逻辑段,包括代码段寄存器CS、堆栈段寄存器SS、数据段寄存器DS和附加段数据寄存器ES。

       1,代码段寄存器CS(Code Segment):存放当前正在运行的程序代码所在段的段基值,表示当前使用的指令代码可以从该段寄存器指定的存储器段中取得,相应的偏移值则由IP提供。
  2,数据段寄存器DS(Data Segment):指出当前程序使用的数据所存放段的最低地址,即存放数据段的段基值。
  3,堆栈段寄存器SS(Stack Segment):指出当前堆栈的底部地址,即存放堆栈段的段基值。
  4,附加段寄存器ES(Extra Segment):指出当前程序使用附加数据段的段基址,该段是串操作指令中目的串所在的段。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
(*env)->ReleaseShortArrayElements(env, SNRArray, SNRElements, 0); (*env)->ReleaseByteArrayElements(env段寄存器可以直接赋值,但需要符合一定的规范。在实模式下,可以通过将, LLIArray, LLIElements, 0); (*env)->ReleaseByteArrayElements(env, codeArray, codeElements, 0一个16位地址值直接赋给段寄存器来改变段寄存器的值,例如: ``` mov ax); (*env)->ReleaseDoubleArrayElements(env, LArray, LElements, 0); (*env)->ReleaseDoubleArrayElements(env, 0x1234 ; 将地址0x1234赋给AX寄存器 mov ds, ax ; 将AX, PArray, PElements, 0); (*env)->ReleaseFloatArrayElements(env, DArray, DElements, 0); 寄存器的值赋给DS段寄存器 ``` 在保护模式下,需要使用特定的指令 obsd_t *obsd = (obsd_t *) obsdObj; obsd->time = observationData->time; 来加载选择子(Segment Selector)和描述符(Segment Descriptor)来改变段寄存器的值。例如: obsd->sat = observationData->sat; obsd->rcv = observationData->rcv; memcpy(obsd->SN``` mov ax, selector ; 将选择子赋给AX寄存器 mov ds, ax ; 将AX寄存R, observationData->SNR, sizeof(observationData->SNR)); memcpy(obsd->LLI, observationData->LLI器的值赋给DS段寄存器 ``` 需要注意的是,在保护模式下,段寄存器的值不再是一个简单的16位地址值,而是一个指向描述符的指针。因此,直, sizeof(observationData->LLI)); memcpy(obsd->code, observationData->code, sizeof(observationData->code)); 接将地址值赋给段寄存器是不可行的。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值