Intel 8086

✍ dations ◷ 2024-12-23 09:44:23 #Intel x86处理器

Intel 8086(亦称之为iAPX 86)是由英特尔公司于1976年初开始设计,1978年年中发表的Intel第一款16位微处理器。随后于1979年,又推出了Intel 8088,它在芯片的外部连接椎使用8位资料总线(允许使用更廉价和更少集成电路)的支持,成为8086的一个低成本的简化产品,并用在IBM PC的原始设计中的处理器(包括广为人所知的IBM PC XT(英语:IBM PC XT))中而被人知晓。

8086是Intel最成功的处理器系列x86架构的开端。

1972年,Intel发布了8008微处理器——世界上第一款8位微处理器。 8008微处理器有18个引脚,其中地址总线使用了14个引脚,并且与8位数据总线复用引脚。指令集源自是Datapoint公司为计算机的CRT-键盘终端设计的但相当通用的指令集。当时英特尔还是一家生产DRAM为主业的公司,缺乏这方面的技术储备。

1974年,Intel发布了8080微处理器, 被公认是第一款真正可用的微处理器。8080的芯片封装采用40个引脚,其中8个数据总线引脚、16个地址总线引脚都是专用的,因此数据总线与地址总线可以并行工作。8080的扩展后的指令集在源代码级别上向前兼容8008指令集。

1975年,Intel发布了第三款8位微处理器——8085。采用了新的制造工艺,简化了输入电压引脚的数量。同一时期还有Motorola 6800(1974)、Microchip PIC16X(1975)、MOS Technology 6502(1975)、Zilog Z80(1976)及Motorola 6809(1978)等8位微处理器。在8位微处理器市场竞争中Z80最为成功。

8086项目起始于1976年5月,是英特尔公司当时更为看重的16位的iAPX 432(英语:Intel iAPX 432)微处理器的备份项目。8086一方面要与Motorola, Zilog, National Semiconductor等公司的16位、32位微处理器竞争市场份额,另一方面也是对Zilog Z80在8位微处理器市场上的成功的回击。由于采用了与8085微处理器近似的微体系结构与物理实现工艺,8086项目进展相当快。

8086微处理器被设计为在汇编源程序上向前兼容8008, 8080, 8085等微处理器。指令集与编程模式是基于8080微处理器,但指令集做了扩展以完全支持16位计算。

新增加的指令包括:完全支持有符号整数、段基址+偏移量寻址、类似于Z80的自重复操作、直接支持嵌套的ALGOL类语言如Pascal或PL/M、微码实现的乘法除法指令、以及更好支持与协处理器(8087或8089)和多处理器系统的总线结构.

第一版的指令集与高层的体系结构的设计仅用了3个月。 在没有CAD工具的时代,4名工程师与12名布线绘图员平行工作, 用了2年多的时间才把8086的高层设计实现为可运行测试的产品。这在当时算是很快的研发速度。

8086是随机逻辑与微码的混合实现,使用了大约20,000个晶体管(算上所有的ROM与可编程逻辑阵列为29,000个晶体管)。芯片面积为33 mm²,制造工艺为3.2 μm.

8086体系结构由Stephen P. Morse设计,并在最后定案时得到Bruce Ravenel(8087体系结构设计者)的帮助。逻辑设计者是以Jim McKevitt与John Bayliss为首的硬件开发工程师团队。项目经理William Pohlman。迄今8086的指令集仍然是PC机与服务器的基本指令集。

所有的内部寄存器、内部及外部数据总线都是16位宽,因此是完全的16位微处理器。20位外部地址总线,因此物理寻址空间为1MiB (即220 = 1,048,576).由于内部寄存器都是16位,对1M地址空间寻址时采取了段寻址方式。8086的封装采用40引脚的双列直插(dual in-line),数据总线与地址总线复用了前16个引脚。16位的I/O地址,因此独立的I/O寻址空间为64KiB的虚拟寻址空间 (即216 = 65,536).由于8086内部的地址寄存器是16 位宽,因而最大线性寻址空间为64 KiB.使用超过64 KiB内存空间的程序设计时,需要调整段寄存器(segment registers)。直到32位的80386出现之前,8086的这种段寻址相当不便.

8086芯片封装的8个控制引脚在或下有不同功能。"min"模式是使用单处理器的小型计算机系统,"max"模式是使用多处理器的中到大型计算机系统。

8086有8个16比特的寄存器,包括栈寄存器SP与BP,但不包括指令寄存器IP、控制寄存器FLAGS以及四个段寄存器。AX, BX, CX, DX,这四个寄存器可以按照字节访问;但BP, SI, DI, SP,这四个地址寄存器只能按照16位宽访问。

8086以8080和8085(它与8080有汇编语言上的源代码兼容性)的设计为基础,拥有类似的寄存器集合,但是扩展为16位。总线接口单元(Bus Interface Unit)透过6字节预存(prefetch)的贮列(queue)将指令送给运行单元(Execution Unit),所以取指令和运行是同步的-一种流水线的原始形式(8086指令长度变化从1到6字节)。

8086有四个完全一样的16位寄存器,但也能够当作八个8位寄存器来访问;以及四个16位变址寄存器(包含堆栈索引)。数据寄存器通常由指令隐含地使用,针对暂存值需要复杂的寄存器配置。它提供64K 8位的输出输入(或32K 16位)端口,以及固定的向量中断。大部分的指令只能够访问一个存储器地址,所以其中一个运算符必须是一个寄存器。运算结果会存储在运算符中的一个。

8086有4个存储器区段(segment)寄存器,可以通过变址寄存器来设置。区段寄存器可以让CPU一种当时是全新的方式访问多达1MB之存储器。在现今有区段的处理器中,8086把区段寄存器左移4位然后把它加上去寻址。这通常被认为是一个不太好的设计,因为这么做会让各区段有重叠。尽管这样对于汇编语言而言会显得有用——因为可以充分控制区段,但同时却使高级语言中的指针(像是C编程语言)使用变得困难。它降低了指针的高效率,且有可能产生两个指向同一个地方的指针拥有不同的地址。更坏的是,这种方式产生要让存储器扩展到大于1MB的困难。而80286的寻址方式改变让存储器扩展较有效率。

由于8位机(如Intel 8008)时代沿袭下来的紧凑编码,大多数指令虽然有两个源操作数(operands)及一个输出结果,但单条指令至多使用两个地址,因此运算结果被存入一个源操作数中。且最多只能有一个内存操作数,另外的操作数是寄存器或立即数。内存操作数也可以用于存储指令的输出结果。8位微处理器的指令集不能把输出结果直接保存在内存操作数中,因此8086指令集的如此设计大大提高了代码密度(code density)。

相比与8080或8085,8086有更强的寄存器通用性,但比起典型的小型计算机来说仍有很大不如。8086的某些指令隐式使用某些寄存器。比起更为规则的16- 或32-位处理器如PDP-11, VAX, 68000,等等,8086的寄存器分配特性使得编译器的工作更为复杂;另一方面,比起半现代化的但广为使用的8位微处理器如6502, 6809,或8085,编译器生成代码就容易太多了.

8086有64 KiB的字宽为8位的(或32K个宽度为16位的)I/O寻址空间.

栈的长度最大为64 KB(一个段) ,8086硬件支持栈顶由高地址向低地址生长。入栈、弹栈的数据单元长度为2字节。栈顶位置由寄存器的组合SS:SP给出.

共有256 个中断,包括硬件中断与软中断。中断可以嵌套,使用栈来保存中断返回地址。

8086增加了一些8080与8085所没有的新指令,用于更好地支持Pascal与PL/M的高级程序设计特性;如push , ret , (其它一些指令如push and enter,在随后的80186, 80286, and 80386中陆续增加.)

8086有一个16位宽的标志寄存器FLAGS.其中9个比特是被使用的,另外7个比特保留未用。具体是:进位标志CF、奇偶标志PF、辅助标志AF、为零标志ZF、符号标志SF、追踪标志TF、中断允许标志IF、方向标志DF、溢出标志OF。

在Intel的8位、16位处理器中,由于寄存器的宽度为8或16比特,而地址总线的宽度一般是要大于寄存器的宽度,所以为了能访问整个地址空间,需要采取特殊的寻址计算——分段寻址。从80386开始的32位微处理器,地址总线宽度也是32比特,可以视作扁平(flat)地址空间,不再需要分段寻址。

8086的分段寻址,是指一个物理地址由段地址(segment selector)与偏移量(offset)两部分组成,长度各是16比特。其中段地址左移4位(即乘以16)与偏移量相加即为物理地址。例如,06EFh:1234h,表示段地址为06EFh,偏移量为1234h,物理地址为06EF0h + 1234h = 08124h。在计算物理地址时如果发生上溢出,8086处理器舍弃进位。例如,FFFFh:0010h所对应的物理地址为00000h.

一个20位的物理地址对应着4096个不同的"段地址:偏移量"的组合。这是因为,偏移量的最低4位对应于物理地址的最低四位,而偏移量的高12位共有4096个取值。

段地址所对应的物理地址的粒度是16字节(=24),称之为paragraph。

段地址确定后,偏移量的取值最多为64KiB(=65536),这就是分段寻址的最大的线性地址空间。实际上在8086处理器上,操作系统分配的线性地址空间可以是不大于64KiB的任意数量。程序可以自由访问整个物理内存空间,操作系统没有任何权限限制或监管(supervision)。

8086处理器有20根地址总线引脚(pins),因此物理内存空间最大为220=1MiB=1,048,576字节。这还包括了IO内存。因此使用8086处理器的计算机的主存的容量少于1MiB,最常见的主存容量是640KiB。

由于X86指令集的向后兼容原则,计算物理地址时,段地址左移4位被所有后继支持实模式的X86处理器所继承。80286是使用24位宽地址总线的16位微处理器,如果要在整个224=16MiB物理存储空间寻址,就必须采用其它方式,即保护模式寻址,这时16位的段地址是指向段描述符表(segment descriptors table)的一个包含24位基地址的条目,基地址加上16位偏移量即为24位的物理地址。

在8086上运行的编译器,一般支持两种C语言的指针:近指针(near)与远指针(far)。近指针是16位的地址偏移值,隐式与程序的代码段地址或数据段地址结合使用以确定物理地址。远指针是32位的“段地址:偏置量”成对出现,用以确定20位的物理地址。某些编译器支持“巨指针”(huge),类似于远指针。但巨指针的地址运算是线性20位;而远指针的地址运算在16位偏移值溢出时不影响段地址部分,因此远指针的线性部分是16位。

为了避免对大量的指针、数据结构、函数指出是“近”还是“远”,编译器提供了内存模式(memory model)给出了缺省的内存访问方式:

预编译库对不同的内存模式要分别编译为相应版本。

8位机上的程序可以不考虑段地址直接以.com可执行文件以“微模式”在8086上运行。这是当时8086与MS-DOS作为新平台获取市场成功的关键原因——大量已存的CP/M应用程序能很快得到利用。

以下8086/8088汇编源代码是将给定大小的数据块从一个位置拷贝到另一个位置的叫做_memcpy的子程序。每次拷贝一个字节,数据移动和循环逻辑采用16位操作。

                                                                                                                                                                                                                   0000:1000            0000:1000            0000:1000 55         0000:1001 89 E5      0000:1003 06         0000:1004 8B 4E 06   0000:1007 E3 11      0000:1009 8B 76 04   0000:100C 8B 7E 02   0000:100F 1E         0000:1010 07         0000:1011 8A 04      0000:1013 88 05      0000:1015 46         0000:1016 47         0000:1017 49         0000:1018 75 F7      0000:101A 07         0000:101B 5D         0000:101C 29 C0      0000:101E C3         0000:101F            
; _memcpy(dst, src, len); Copy a block of memory from one location to another.;; Entry stack parameters;       = len, Number of bytes to copy;       = src, Address of source data block;       = dst, Address of target data block;; Return registers;      AX = Zero            org     1000h       ; Start at 0000:1000h_memcpy     proc            push    bp          ; Set up the call frame            mov     bp,sp            push    es          ; Save ES            mov     cx,   ; Set CX = len            jcxz    done        ; If len=0, return            mov     si,   ; Set SI = src            mov     di,   ; Set DI = dst            push    ds          ; Set ES = DS            pop     esloop        mov     al,     ; Load AL from             mov     ,al     ; Store AL to             inc     si          ; Increment src            inc     di          ; Increment dst            dec     cx          ; Decrement len            jnz     loop        ; Repeat the loopdone        pop     es          ; Restore ES            pop     bp          ; Restore previous call frame            sub     ax,ax       ; Set AX = 0            ret                 ; Return            end proc

上面的代码使用BP(基指针)寄存器创建一个调用帧(包含子程序执行过程中的所有参数和局部变量的栈的区域)。这种调用约定支持可重入和递归代码,大多数类ALGOL语言上世纪50年代后期就已采用这种约定。ES段寄存器保存在堆栈上,并用DS段寄存器中的值替换,于是指令MOV AL会在相同的源数据段和目的数据段之间操作。在返回前,子程序恢复了ES寄存器以前的值。

上面的子程序是一种比较麻烦的拷贝成块数据的方法。若源数据区域和目的数据区域都是处于单个65,536字节的段中(上述程序的要求),使用8086的块MOV指令更有优势。上面的循环部分可以替换为:

0000:1011 F2         0000:1012 A5         
loop        rep                  ; Repeat until CX=0            movsw                ; Move the data block

这种方法每次可以拷贝一个字。REP指令使下面的MOVSW重复直至CX=0,重复之时自动递增SI和DI。另外,MOVSBMOVSD指令可以用来一次拷贝单个字节或双字。大多数汇编器在REP指令用在MOVSW之前为REP MOVSW的情况下都会正确汇编。

如果被中断,这个程序也能正确运行,因为程序计数器会继续指向REP指令,知道块拷贝已经结束。拷贝会在中断服务程序将控制恢复的时候继续。

外部总线作为数据与地址的复用,降低了CPU的性能。取16比特或8比特数据需要4个时钟周期。指令的长度为1-6个字节,取指令与执行是并发完成的。CPU内的总线界面单元把取到的指令保存在6字节的预取队列中。

8086涉及内存访问的指令,包括跳转(jump)指令需要比8080与8085更多的时间,原因在于:

8086的后继处理器的内存访问性能大大增强了。80186与80286有专门的地址计算硬件,节约了很多时间周期。80286的外部地址总线与数据总线是分开各自专用的。

8086/8088可以连接上专用的数学协处理器以增加浮点计算性能。标准的数学协处理是Intel 8087,执行80位浮点数运算。

第一个以8086为基础的商业微电脑是Mycron2000。

IBM Displaywriter文字处理机也使用8086。在大部分显要的所有微处理器中,IBM PC使用了更窄的存储器总线版本的8086,也就是Intel 8088。8086CPU结构上的一个重要特点是分为二大部分,即总线接口单元BIU和运行单元EU,其中BIU负责外部信息交换,EU负责指令运行,二者合理分工、并发工作,工作效率比此前的CPU明显提高,常称之为流水线结构。

8086和8088支持两种硬件模式:最大模式和最小模式。最大模式是用在大型应用中的多重处理,并且也是支持8087处理器的必需。该模式通常硬件化在电路中,不能由软件改变。具体来说,#33引脚(MN/MX)是连载高电压还是接地决定了模式。改变引脚#33的状态就改变了其他特定引脚的功能,这些引脚中大多数是CPU处理(局部)总线的。IBM PC和PC/XT使用工作在最大模式的Intel 8088,让CPU与PC或PC/XT主办上安装在数学协同处理器插口的可选8087协同处理器。(PC和PC/XT可能因为其他原因而要求用最大模式,比如要支持DMA控制器。)

2018年6月8日,英特尔在官网上开启了限量抽奖活动,奖品为i7-8086k,限量生产8086个。

相关

  • 解剖学史解剖学史古代埃及人在医学上十分出色。有关外科的纸草书记载了他们对疾病的认识。最早的纸莎草文献是约1600BC的《艾德温·史密斯纸草文稿》。汉谟拉比法典对外科手术的相关
  • 纳吉布拉穆罕默德·纳吉布拉·阿赫马德扎伊(普什图语:ډاکټر نجیب ﷲ احمدزۍ‎,英语:Mohammed Najibullah Ahmadzai,1947年8月6日-1996年9月28日),阿富汗政治家、共产主义者,出生
  • 凯旋医院高雄市立凯旋医院位于台湾南部高雄市,是一所市立精神专科教学医院。前身是“台湾省立高雄疗养院”,设立理由是台湾省政府计划,在台湾省南部设立公立精神专科病院,方便中南部病患
  • OTCOTC可以指:
  • 侧齿铰齿(Hinge teeth)是多个物种的外壳内部表层的一部分,包括软体动物门的双壳纲及腕足动物门的旧有铰纲的物种。根据定义,这些物种都有两瓣壳,而这两瓣壳通过在壳的背部或顶部边缘
  • 牧歌牧歌是民歌的一种,描绘一个理想化的牧人生活的方式,流行放牧民族。牧歌有时描述的是一种田园风光。在欧州的古典文学中,牧歌呈现了牧羊人的生活形式,可能是在树荫下反复辩难,或倾
  • 自由民主党 (德国)自由民主党(德语:Freie Demokratische Partei,缩写为FDP),1968年–2001年期间缩写为F.D.P.,是德国的一个经济自由主义政党,是德国政坛中历史比较悠久的政党之一。威斯巴登基本原则
  • LPLLPL可能指以下其中一个项目:
  • 和平号太空站远征队列表这是一个和平号太空站远征队的列表。
  • 载泽贝子衔奉恩镇国公载泽(1868年3月17日-1929年6月18日),满洲镶白旗人。初名载蕉,字荫坪,爱新觉罗氏,宗室。清朝重臣,改革派、立宪派人物。清光绪三年(1877年)为辅国公。二十年(1894年)成婚