发明于1947年的晶体管作为电子放大器和开关,是各种电子设备(从袖珍收音机到仓库规模的超级计算机)的核心部件。其早期版本被称为“双极晶体管”,至今仍在使用。到了20世纪60年代,工程师已经找到了将多个双极晶体管组合成单个集成电路的方法。但由于这些晶体管的复杂结构,集成电路只能包含少量的晶体管。所以,因此,建立在双极集成电路基础上的微型计算机虽然比早期计算机小得多,但仍然需要多块主板和数百个芯片。

英特尔的4位4004芯片被广泛认为是世界上第一个微处理器。但是,这个头衔不是没有竞争对手。

1960年,出现了一种新型晶体管——金属氧化物半导体(MOS)晶体管。起初,这项技术并没有表现出广阔的前景。但到了1964年,相较于双极集成电路,在MOS 晶体管基础上制作的集成电路拥有更高的密度和更低的生产成本。如摩尔定律所述,集成电路越来越复杂,但如今MOS技术引领了潮流。

20世纪60年代末,单一MOS集成电路包含100个甚至更多逻辑门,每个逻辑门又包含多个晶体管,因此这种技术对于制造计算机特别有吸引力。这些芯片及其诸多组件被称为大规模集成电路(LSI)。

工程师们认识到,随着MOS晶体管的密度越来越大,最终将实现基于单一芯片的计算机处理器。但是由于MOS晶体管的速度要低于双极晶体管,所以,只有当性能要求偏低或设备需要小而轻时(如数据终端、计算器或者航空电子设备),MOS芯片计算机才能发挥作用。因此,正是这些计算应用领域掀起了微处理器革命。

今天,大多数工程师脑中的印象是,这场革命始于1971年英特尔的4位4004芯片,很快英特尔又推出了8位的8008芯片。实际上,微处理器的诞生故事要精彩和奇妙得多。尤其是,一些刚刚披露的文件描述了一个长期被遗忘的芯片——德州仪器的TMX 1795——力压英特尔8008,成为第一款8位微处理器,却一直默默无闻。

TMX 1795,3078个晶体管

4004,2300个晶体管

8008,3098个晶体管

将MOS集成电路应用于计算,为第一款微处理器打开了大门。第一台利用MOS-LSI芯片制造的计算机是由Autonetics(位于加州阿纳海姆市,北美航空公司的一个分支机构)在1967年制造的D200。

1996年为国家发明家名人堂举办的入场仪式中,Federico Faggin,Marcian“Ted”Hoff Jr.和Stanley Mazor [左起])展示了他们在20世纪70年代初创立的先驱微处理器,即Intel 4004。

这台24位紧凑型通用计算机的设计初衷是用于航空和导航。它的中央处理单元由24个MOS芯片组成,得益于四相逻辑设计技术,利用个相分离的时钟信号(每个信号都有一个不同的开关模式或相位)推动晶体管的状态变化,从而使电路大大简化。该计算机只有几公斤重,用于为“波塞冬”潜射弹道导弹制导以及B-1轰炸机燃料的管理。甚至还有人考虑把它用在航天飞机上。

很快,D200之后又出现了另一台航空电子计算机——由盖瑞特艾雷赛奇(现在隶属于霍尼韦尔)制造的中央航空数据计算机(Central Air Data Computer),包含3个CPU和28个芯片。该计算机是为F-14战斗机设计的飞行控制系统,使用的是盖瑞特艾雷赛奇在1968—1970年间开发的MP944 MOS-LSI芯片组。这台20位的计算机通过处理从传感器获得的信息,为仪器和飞机控制生成输出数据。

F-14计算机的架构与众不同。它有3个并行的功能单元:一个进行乘法运算,一个进行除法运算,另一个用于特殊的逻辑功能运算(包括在最高值和最低值之间选择一个值)。每个功能单元由多个不同的MOS芯片构成,如一块只读存储器(ROM)芯片(包含了决定该单元将如何运作的数据)、一块数据控制芯片、各种运算芯片,以及一块用于临时存储的随机访问存储器(RAM)芯片。

由于F-14计算机属于机密,因此几乎没有人知道MP944芯片组。但是Autonetics公司对其D200进行了广泛宣传,后来推动了另一台更加紧凑的MOS计算机的出现——System Ⅳ。该计算机的发明者是李•博塞尔(Lee Boysel),他于1968年离开了仙童半导体公司,与他人共同创办了四相系统公司(Four-Phase Systems,以Autonetics的四相逻辑命名)。

24位System Ⅳ计算机的CPU仅由9个MOS芯片构成:3个名为AL1的算术逻辑单元(ALU)芯片(进行加减等运算操作,以及与、或、非等逻辑操作)、3个ROM芯片,以及3块随机逻辑芯片。

几乎同时,一家位于马萨诸塞州的创业公司——Viatron计算机系统公司也加入了这场游戏。该公司创建于1967年11月,而仅在一年之后,便推出了System 21——一台配备各种辅助设备的16位微型计算机,全部由定制化的MOS芯片构成。

我们要感谢Viatron的某个人创造了“微处理器”一词。1968年10月,该公司在推出产品2101时首次使用了这个名称。但这款微处理器并不是一个芯片。在Viatron的字典里,这个词指的是智能终端的一部分,这一智能终端配有键盘和磁带驱动器,并与一台单独的微型计算机相连。Viatron的“微处理器”用于控制该终端,由3块不同主板上的18个定制MOS芯片构成。

与此同时,20世纪60年代末,日本计算器制造商日本计算机公司(Business Computer Corp.也被称为比吉康,Busicom)与英特尔签署协议,为一款多芯片计算器定制芯片。最终产品被简化成一款单芯片CPU,也就是现在著名的英特尔4004,同时还有用于存储和输入/输出(I/O)的辅助芯片。这款4位4004芯片(意思是它只能操作4位宽度的数据)通常被认为是第一款微处理器。

1971年初,这款配备4004芯片的计算器上市了。当时,它有许多竞争对手。一家名为Mostek的半导体公司制造出了首款芯片计算器MK6010。Pico Electronics和通用仪器也在研发了它们的芯片计算器G250。不到半年,德州仪器的TMS1802芯片计算器也上市了,成为德州仪器取得巨大成功的0100生产线上的首款芯片。虽然这些电路作为计算器有很好的效果,但对其他事情却无能为力,而4004却能执行存储于外部ROM上的指令。因此4004能用于通用计算机。

那时正是电子计算器业务快速发展的年代,经历了财务危机的比吉康放弃了它对4004芯片的专有权。1071年11月,英特尔开始将4004及其附属配套芯片作为一款适用于通用计算应用的独立产品进行市场推广。但不过几个月之后,4004被其他更加强大的微处理器夺去了光辉,因此,基本没有找到可应用的商业领域,只包括几款弹球机、一款文字处理器和一个投票计算系统。

从这个意义上来说,是电子计算器推动了首款微处理器——英特尔的4位4004芯片的产生。而很快接替它的8位微处理器却有一个非常不同的起源。这个故事始于1969年计算机终端公司(CTC,位于德克萨斯州圣安东尼奥市)Datapoint2200“可编程终端”的开发。

Datapoint2200不仅仅是一个终端,而且是一台真正的通用计算机。它的8位处理器最初由大约100个双极芯片构成。其设计者一直在寻找让处理器消耗较少电量同时产生更少热量的方法。1970年初,CTC安排英特尔打造一个单MOS芯片,来替换Datapoint的处理器板,但不清楚使用单芯片的主意是出自英特尔还是CTC。

1970年6月,英特尔在Datapoint2200架构的基础上制定了芯片的功能参数,然后将项目搁置了6个月。后来这个设计成为了英特尔8008。所以,你认为无论第一款真正实用的单芯片通用微处理器是受计算器启发的4004,亦或是受终端启发的8008,创造它们的都是英特尔,对吗?其实不然。公众号:OpenFPGA

1970年,英特尔开始研制8008的时候,它还只是一家仅有约100名员工的初创企业。获悉英特尔的处理器项目后,德州仪器——一家拥有4.5万名员工的大型企业咨询CTC,它是否也能为Datapoint2200制造一款处理器。CTC把相关的计算机参数给了德州仪器的工程师,让他们放手去干。但当德州仪器返回了一份三芯片设计时,CTC直接问,德州仪器是否能像英特尔那样在一块芯片上进行设计。然后,大约在1970年4月,德州仪器开始为CTC研发一款单芯片CPU。第二年设计完成,它被称为TMX1975(X指“试验”),后来当需要公布这款芯片的原型状态时,其名称演变成了TMC1795。

1971年6月,德州仪器为TMC1795发起了一场媒体宣传活动,描述了这款“单芯片中央处理器”将如何使新款Datapoint2200成为“原机器都无法与其功能相媲美的强大计算机”。尽管如此,TMC1795还是未能被应用到Datapoint2200上:CTC对TMC1795进行测试后,拒绝了这款芯片,选择继续使用一块双极芯片板制作处理器。英特尔芯片也直到1971年底才完成。公众号:OpenFPGA

许多技术历史学家认为,TMC1795当时就流产了。但根据该芯片首席开发者盖里•布恩(Gary Boone)最新公布的文件,TMC1795被CTC拒绝后,德州仪器曾试图将该芯片(经过一些小的改进后,成为了TMC1795A)卖给多家公司。1971年,福特汽车公司对该芯片表示出了兴趣,想用它作为发动机控制器,布恩写道:“我觉得我们已经走进了对我们的‘单芯片CPU’有迫切需求的大众市场。”然而,这些努力也付之一炬,德州仪器停止营销TMC1795,转而将精力放在更加有利可图的计算器芯片上。不过,虽然德州仪器错失了机遇,但第一款8位微处理器的桂冠还是应该落在它的头上。

1971年底,英特尔还在研发8008,但CTC已经对单芯片CPU失去了兴趣,放弃了对该设计的独有权。英特尔则继续推进8008的商业化,1972年4月将其推出市场,并最终生产了几十万个8008。两年后,又根据8008衍生出了英特尔8080微处理器,对8086产生了巨大影响,也打开了英特尔现在的X86芯片生产线的闸门。所以,如果你现在正坐在一台使用X86处理器的电脑前,那么你正在使用一台其设计可追溯至1969年Datapoint2200可编程终端的电脑。公众号:OpenFPGA

就像这段历史告诉我们的,微处理器的进化并不是一条直线。许多都是机会和各种商业决策的结果,而且很可能偏离方向。以CTC为Datapoint2200设计的8位处理器架构为例,它有4种不同的实施方式。CTC使用了两次双极芯片板,第一次是以串行方式交流数据,第二次是以并行方式,速度有所提高。德州仪器和英特尔都满足了CTC使用单芯片的要求,指令集也几乎相同,但这两款芯片在封装、控制信号、指令时序和内部电路方面完全不同。

英特尔使用的技术比德州仪器更加先进,最值得一提的是,用多晶硅制成的自对准栅极,既提高了晶体管的速度,又提高了产出,同时也使晶体管能够被布置得更紧密。结果,就算4004和8008加在一起,也比TMC1795的尺寸小。实际上,英特尔的工程师也曾认为德州仪器的芯片过于庞大,很难得到实际应用,但事实并非如此:德州仪器后来很快推出的TMS0100计算器芯片甚至比TMC1795还要大,但也取得了巨大成功。

所以,到底是谁最早发明了微处理器呢?一种答案是,微处理器并不算是发明,而是大家早已知道迟早会出现的东西。只要等着技术和市场相结合就可以了。我觉得这种观点最有说服力。

另一种观点认为,“微处理器”基本上是英特尔、德州仪器及其他芯片公司根据需要而推出的一个营销术语,用来称呼它们的新产品。布恩虽然是TMC1795的开发者,后来也认为是英特尔将微处理器变成了一种实际可行的产品。在一封没有标明日期的信(明显是针对谁首先发明了微处理器的法律讨论)中,他写道:“在微处理器发展过程中,最主要的是英特尔在1972—1975年间做出的企业贡献……它们在设计、软件和营销方面的创新使这一行业有了发展可能,或者至少加速了它的发展。”

要判断谁创造了第一款微处理器还取决于你如何定义这个词。有些人认为微处理器就是一块芯片上的CPU;有些人则认为仅需一块芯片上的一个算术逻辑单元即可;还有一些人将这些功能封装在几块芯片上,认为它们合起来构成一个微处理器。

在我看来,微处理器的主要特征在于,它是一块单芯片上的CPU(包括ALU、控制功能以及程序计数器等寄存器),而且可编程。但是,微处理器并不是一台完整的计算机:存储器、I/O和其他支持功能还需要其他芯片。

根据这一定义,大多数人认为英特尔4004是第一款微处理器,因为它在一块单芯片上容纳了中央处理单元的所有组件。布恩和费德里科•费金(Federico Faggin,英特尔4004团队成员)都同意,4004比最早的TMX1795样品早出现了一两个月。后者是首款8位微处理器,而英特尔的8008则是首款在商业上取得成功的8位微处理器。

但是如果你的“微处理器”定义没那么严格,那么很多系统都可以被看成是第一款微处理器。那些认为芯片上有算术逻辑单元即为微处理器的人,认为博塞尔在离开仙童公司与他人合办四相系统公司之前不久,于1968年制作出了第一款微处理器。也有人认为四相系统公司的AL1是第一款,因为它在一块单芯片上结合了寄存器和ALU,同时控制电路外置。如果你认为微处理器可以包含多块LSI芯片,那么Autonetics D200也具有成为第一款微处理器的资格。

专利提供了另一个评判微处理器发明的角度。德州仪器很快意识到专利的盈利能力,获得了TMX1795 和TMS0100的多项专利,并在诉讼和授权协议中充分利用了这些专利。

根据这些专利,德州仪器可以被视为微处理器和微控制器(集合了CPU、存储器和各种支持功能的单芯片)的发明者。或许也不是。因为1990年吉尔伯特•海特(Gilbert Hyatt)凭借他在1969年用多块双极芯片板制作16位串行计算机获得了单芯片处理器专利。这使得有人认为海特才是微处理器的发明者,直到经过一场复杂的官司,德州仪器于1996年在专利上击败了海特。

另一位被认为是微处理器发明者的是博塞尔。1995年,在一场法律诉讼(后来被戈登•贝尔戏称为“德州仪器与所有人的对抗”)中,博塞尔利用1969年的一块AL1 ALU单芯片在法庭上演示一台工作计算机,对德州仪器的单芯片处理器专利进行反击。他的行为有效打击了德州仪器,不过我不认为他的演示特别有说服力,因为他用了一些技术手段才赢得了官司。

无论认为哪个是首款微处理器,我们都得接受会有竞争者来争夺这一称谓。可惜的是大多数人试图在这场竞赛中只承认一个获胜者,而许多极好的亚军产品现在几乎都被遗忘了。不过对于我们这些对微计算早期历史感兴趣的人来说,这一丰富的历史将继续存在。

文章来源:21IC

版权归原作者所有

- END -

NOW现在行动!
推荐阅读
【Vivado那些事】如何查找官网例程及如何使用官网例程【Vivado使用误区与进阶】总结篇【Vivado那些事】Vivado下头文件使用注意事项【Vivado那些事】Vivado中常用的快捷键(一)F4键【Vivado那些事】Vivado中常用的快捷键(二)其他常用快捷键
SystemVerilog数字系统设计_夏宇闻 PDFVerilog 里面,always,assign和always@(*)区别
FPGA上如何求32个输入的最大值和次大值:分治新年愿望是什么?先送大家一波开发软件【Vivado那些事】FPGA配置失败,无法启动怎么办你会在github上找项目吗?
图书推荐|ARM Cortex-M0 全可编程SoC原理及实现
简谈:如何学习FPGARISC-V再进阶!世界首款5纳米RISC-V SOC成功流片!
几款开源SDR平台
Xilinx 推出 Kria 自适应系统模块产品组合,在边缘加速创新和 AI应用
RISC-V指令集架构介绍及国内外厂商介绍
Vitis尝鲜(一)
SDR/无线设计中LNA和PA的基本原理
拆解1968年的美国军用电脑,真的怀疑是“穿越”啊!
一文最全科普FPGA技术知识
首个中文CPU指令规范 龙芯推出LoongArch基础架构手册
你见过1-bit CPU吗?高级FPGA设计技巧!多时钟域和异步信号处理解决方案
【Vivado那些事】Vivado中电路结构的网表描述
ZYNQ中裸机开发和Linux开发有什么区别?
现代计算机的雏形-微型计算机MCS-4
【每周一问】如何控制加载FPGA程序时,Xilinx FPGA的IO管脚输出高低电平
【Vivado那些事】vivado生成.bit文件时报错-ERROR: [Drc 23-20]
AD9361 和Zynq及其参考设计说明1202年了,还在使用虚拟机吗?Win10安装Ubuntu子系统及图形化界面详细教程谈谈Xilinx FPGA设计的实现过程
AD936x+ZYNQ搭建收音机(一)
AD936x+ZYNQ搭建收音机(二)含视频演示
点击上方字体即可跳转阅读

世界上第一个微处理器真的是Intel 4004吗?其实这是个很复杂的故事…相关推荐

  1. python真的超过java了吗-JAVA会被Python超越成为世界上第一大编程语言吗?

    关键时刻,第一时间送达! 这个路还还长,暂时不会,未来5年不会,10年有可能,就看现在小学生.初中生学习的怎么样.最近,也在观注这方面的,偶尔看到新闻说python纳入到高考中,想想如果真纳入了,过4 ...

  2. 微型计算机最早提出于,计算机基础题1、世界上第一台电子计算机诞生于A)1943年B-查字典问答网...

    计算机基础题 1.世界上第一台电子计算机诞生于 A)1943年B)1946年 C)1945年D)1949年 2.世界上公认的第一台电子计算机的逻辑元件是 A)继电器B)晶体管 C)电子管D)集成电路 ...

  3. 世界上第一个程序员竟然是女性,难以置信......

    一说到程序员,人们的第一反应可能是–男的! 接着浮现在眼前的程序员标配是:眼镜,双肩包,格子衬衫,牛仔裤,运动鞋- 不难发现,在现代的IT公司里,从事编程工作的女性比例远远低于男性. 细数" ...

  4. 世界上第一位程序员,竟然是诗人拜伦的女儿?

    导读:女神节来了,数据叔终于忍不住要聊一聊这个憋了很久的八卦,世界上第一位程序员,当然也是世界上第一位女程序员--Ada. 作者:数据叔 来源:大数据DT(ID:hzdashuju) 这位女神级的神人 ...

  5. 世界上第一台电子计算机adc,2004山东公务员考试计算机专业理论题

    本试卷分第I卷(选择题)和第II卷两部分.第I卷1至6页,第II卷7至12页,共240分.考试时间150分钟.考试结束,将本试卷和答题卡一并交回. 第I卷(选择题 共100分) 注意事项: 1.答第I ...

  6. 【历史上的今天】12 月 10 日:世界上第一位程序员诞生;Ada 语言发布;第一人称射击游戏的开拓者

    整理 | 王启隆 透过「历史上的今天」,从过去看未来,从现在亦可以改变未来. 今天是 2021 年 12 月 10 日,在 120 年前的今天,瑞典国王和挪威诺贝尔基金会首次颁发了诺贝尔奖.根据诺贝尔 ...

  7. 第一台计算机如何工作原理,世界上第一台计算机是什么原理_世界上第一台计算机...

    世界上第一台电子计算机叫什么 史上第一台笔记本电脑 世界上第一台计算机诞生于 世界上的第一台电子计算机叫什么 今天你如何和远方的他交流 20世纪改变世界的通讯技术 世界上第一台电脑靠什么作为动力 向蒸 ...

  8. 世界上第一台电子计算机名叫试题,计算机应用基础习题填空题1世界上第一台电子计算机名为.DOC...

    PAGE 第 PAGE 1 页 共 NUMPAGES 4 页 计算机应用基础习题 一.填空题 1.世界上第一台电子计算机名为 . 2.计算机硬件主要包括主机和 设备. 3.第 四 代计算机逻辑元件采用 ...

  9. 谁发明了世界上第一台电子计算机

    谁发明了世界上第一台电子计算机 在国内的绝大部分媒体上都会出现世界上第一台电子计算机是上世纪1946年由美国人毛克利(John Mauchly)发明的ENIAC文字记载,我在这里遗憾的说,那是以讹传讹 ...

最新文章

  1. 虚拟化正是云计算所依托的基石
  2. C++之全局函数和成员函数互相转换
  3. 在Python中为什么切片要忽略最后一个元素?
  4. knot in ship
  5. centos 关闭防火墙
  6. ASP.NET 2.0中的Session状态丢失的解决办法
  7. 单KEY业务,数据库水平切分架构实践
  8. automapper自动创建映射_ASP.NET Core教程:ASP.NET Core使用AutoMapper
  9. [转]VB中资源文件.res的使用方法详解
  10. socket编程(四)
  11. docker 私服搭建以及镜像部署
  12. python的第三方库是干什么用的-python标准库和第三方库的区别
  13. UnityShader24:最简单的屏幕后处理例子
  14. Zotero及部分常用插件安装和使用教程
  15. [ffmpeg][goav][issues] goav Dictionary crash double free
  16. kernel日志时间转换函数
  17. 鸟哥私房菜 第十五章、时间服务器: NTP 服务器
  18. flask 将route放置在多个文件中的方法(蓝本)
  19. 电信增值业务学习笔记(转)
  20. CAD图纸如何批量转换JPG格式?

热门文章

  1. 视频中的音频提取如何操作?一分钟教会你
  2. 微信小程序ios端唤醒不了拨打电话或者部分电话拨打不了解决方案
  3. Outlook 2016 pst/ost邮件数据文件迁移实现
  4. sqlmap tamper mysql_Sqlmap Tamper大全(1)
  5. MATLAB 各类二维渐变图
  6. MATLAB中实现图像的空间域滤波和频率域滤波
  7. cmd.exe启动参数详解
  8. CSS3的2D转换和3D转换,你了解了嘛?
  9. beego框架-logs模块学习笔记
  10. 【matlab】机器学习与人工智能期末课设,基于 K-means 聚类算法的图像区域分割系统