设计与开发

56单片机 更快更省更强性能!市面自主架构SoC一览

小编 2024-11-24 设计与开发 23 0

更快更省更强性能!市面自主架构SoC一览

【PConline 杂谈】 由于手机产业的高速发展,许多厂商已经不再满足于ARM公版的IP核架构,而是根据其指令集进一步优化架构,以获得更好的性能与能耗比,从而达到更快更省电更性能的目的,而这种架构我们就称之为自主架构,那么市面上面有哪些公司都在开发相应的自主架构,成品有哪些?或者将来我们能看到的有哪些呢?

一、什么是SoC架构?

System on Chip,简称Soc,也即片上系统。从狭义角度讲,它是信息系统核心的芯片集成,是将系统关键部件集成在一块芯片上;从广义角度讲,,SoC是一个微小型系统,如果说中央处理器(CPU)是大脑,那么SoC就是包括大脑、心脏、眼睛和手的系统。国内外学术界一般倾向将SoC定义为将微处理器、模拟IP核、数字IP核和存储器(或片外存储控制接口)集成在单一芯片上,它通常是客户定制的,或是面向特定用途的标准产品。

SoC有两个显著的特点:一是硬件规模庞大,通常基于IP设计模式;二是软件比重大,需要进行软硬件协同设计。城市相比农村的优势很明显,SoC也有类似城市的特点:配套齐全、交通便利、效率高。

二、市面上自主架构SoC一览

1.苹果A系列处理器:

苹果早年也是采用的ARM公版处理器,但是从苹果A6开始就自行设计SoC架构。苹果A6是属于苹果自己定制的第一个SOC,它不属于常规的cortex a系列架构,严格的说,他不属于A9,更不是A15,而是苹果全新自主开发的架构,当然这个架构还是基于ARM开发,苹果将这个架构取名为Swift,他甚至使用的不是常规的ARMv7指令集,而是基于ARMv7修改得来,苹果同样命名为ARMv7s,此款SoC参数上看起来跟普通的ARMv7没什么区别,但是苹果自己设计的Swift却有超越众多A9高频4核的性能。

苹果公司近几代SoC的性能和规格 Apple SoCCPU性能GPU性能晶粒大小晶体管制程A5~13x~20x122mm²<10亿45nmA6~26x~34x97mm²<10亿32nmA740x56x102mm²>10亿28nmA850x86x89mm²~20亿20nm

目前苹果最新的SoC是搭载在iPhone 6上的苹果A8。Apple A8是苹果公司设计的第二代64位系统单片机(SoC)。在2014年9月9日发布,用于iPhone 6及iPhone 6 Plus。苹果公司宣称它比上代Apple A7在CPU性能高25%,绘图性能高50%,能源效益高50%。

苹果称,A8处理器集成了20亿个晶体管,相比于A7足足翻了一番,但是核心面积反而还小了13%,也就是大约89平方毫米。CPU部分为自家定制的“改良版Cyclone”,上代A7则是“Cyclone”,仍然维持双核心设计,但仍然能够有相当强悍的性能,这让现在动辄四核、八核的Android阵营感到羞愧。

2.高通骁龙系列处理器:

高通早年一直以自主架构闻名,最开始是基于ARMv7的Scorpion架构,随后在骁龙S4系列处理器中开始启用Krait架构。在近两年市场竞争激烈的情况下,高通也开始尝试公版的ARM架构,但是目前又传出消息称高通下一代的Kyro架构也在研发当中,并且将首次应用于骁龙820处理器。

高通在2015年世界移动通信大会(MWC 2015)上利用 Zeroth平台,预演下一代移动体验。Zeroth是高通Technologies的首个认知计算平台,旨在增强终端用户体验,为下一代顶级芯片高通820的处理器提供优化。骁龙820处理器基于领先的FinFET制程工艺,并将采用高通自主定制的64位CPU架构Kryo,预计将于2015年下半年开始出样。

高通的骁龙平台有着与其他处理器供应商与众不同的特点,高通骁龙具备集成通信技术SoC,这大幅度的降低了OEM厂商设计产品的复杂度和成本。从骁龙S4平台问世开始,绝大部分的S4 SoCs皆集成Wi-Fi、GPS/GLONASS和Bluetooth连接能力。此外,骁龙也受惠于先进半导体制造工艺,例如采用28nm制程的S4平台相较于其他使用旧制程的处理器,在电路设计配置、性能和耗能上都获取相当优势。

3.三星Exynos系列处理器:

三星此系列产品线一直都是采用的公版ARM架构,但是目前三星已经开始研发基于ARM v8架构的Morrgens新架构,目前样片已经流出。据悉这款自主架构SoC的代号为“Mongoose”。目前该款SoC已经在KitGuru开发网站、开发库工具GNU Binutils、编译器工具GNU Compiler Collection中均可以查到,这就意味着该款SoC或许已经接近研发完成,并且已经有了样品供软件开发人员进行测试。

三星自主架构“Mongoose”问世

Mongoose在英文中的原意为猫鼬,与我们熟知的高通自主架构Krait(金环蛇)正好是天敌。Mongoose的第一代产品被称为“Exynos M1”,与苹果的Cyclone一样也是基于ARMv8-A指令集修改而来。从初步的测试结果来看,Exynos M1的单核性能较最新的Exynos 7420提升了45%左右,可以说是非常大的性能提升了。如果不出意外,相信明年我们就能够见到。

四、总结

CPU热潮正在衰退,SoC相比CPU有太多的优点,相信最终SoC会越来越流行,所以我们也相信在此之后市面上也会出现更多的SoC。

单片机学习指南

队长 路飞的电子设计宝藏 7月26日

鉴于原文只介绍了51单片机的学习路线(当时STM32刚兴起),与当前流行的STM32等高端单片机相比,显得有些落后,所以笔者更新了此文。

一、51和STM32的区别。

STM32比51主频高、RAM大、FLASH大,那么STM32能处理的事情就更多了。

STM32外设比51多,如:CAN、USB、FSMC等,能让你省点芯片。

STM32有固件库,不再需要看着手册,查寄存器来写代码,网上也有很多例程。

众多优势让STM32成为大众化、主流单片机,所以必须从51过渡到STM32的时代。

二、内核与外设。

外设就是外部的设备,如:GPIO、ADC、IIC、UART、SPI等。

内核就是内部的核心,如:ALU算术逻辑单元、流水线、指令集等。

51的内核仍然叫51。STM32的内核有Cortex M0、M0+、M3、M4、M7等。

因为ARM Cortex系列的芯片分为高端的A系列,中端的R系列、低端的M系列,所以STM32有好几种内核。

三、如何从51过渡到STM32?

尽管51有那么多的不好,但是低成本依然是它的优势。一片OTP(一次性编程)的51低至0.3毛,它适用于众多家电产品。

所以并不能以单纯的技术崇拜而把51贬得一无是处。只不过,我们需要掌握更多的技术,以适应不同的工作环境。

既然要从51过渡到STM32,那么停留在51的时间不宜太久,掌握基本的定时器、串口,就可以转到STM32上来了。

有的学校先教汇编,再教C,但我认为,先学C,再到汇编会比较好,因为汇编枯燥难学,导致单片机还没用起来,兴趣就消减一大半了。正如linus那句话,你得先学会使用它。

一、首先掌握C语言语法。

单片机用的C语言叫C51,C51除了标准C的语法之外,还特意为单片机增添了几个语法而已,没有很大区别,那么我们可以装个VS(别再用VC6.0那个老掉牙的IDE啦)然后,随便找本语法书抄代码,模仿写,不看书做出课后习题就可以了,其中流程控制(包括if,for,while,switch等)以及指针和结构体都是需要掌握的。推荐看视频《边用边学C语言》。

二、少量的实践。

接下来,你可以买一块单片机开发板来做一些小玩意了(只买一块开发板56元即可,不必浪费太多钱),譬如:摇摇棒,光立方,密码锁,超声波测距,红外摇控等等(很多新奇有趣的小玩意都可以在论坛找到)。当然,也不需要每个都做,我们可以选一些差异性较大的来做,这样升级会快一些。推荐视频《十天学会单片机》,也可以看开发板配套的视频,教材《单片机c语言程序设计实训100例——基于8051+proteus仿真》。适当的做几个就行,不要在这个阶段停留太久,重点掌握定时器和串口。

三、养成良好的编码习惯。

在《十天学会单片机》里会出现众多不怎么好的代码,但是我们不能一下子写出优秀的代码,必须有个过渡期,所以建议大家先看郭大侠的视频。那么如何写出高效而且可读性好的代码呢?这里只提到一点,不要用拼音来命名变量或者函数名,像int shi,fen,miao;这些都是不良的编码习惯,必须全部使用英文命名。推荐的做法就是多参考大神们写的代码,在百度文库或者各大电子论坛都可以看到很多优秀的代码。此外,推荐《从单片机初学者迈向单片机工程师》、《MISRA C标准工程师笔记》、《C语言编程规范》、《C51代码风格》。

四、了解汇编语言。

单片机工程师又叫固件工程师,因为他们写的代码都是跟寄存器打交道,而寄存器又可以直接控制硬件,处于最底层的软件而且不用经常改动,所以叫固件。这部分需要数电、模电的基础才好理解,所以在大学都是先教数电、模电再教单片机的。现在你要用汇编语言来玩单片机,你会发现汇编比较棘手,写出来的代码可读性差、可移植性差而且很难维护,但汇编即让你很清晰地感受到单片机是如何工作的,以及理解C语言指针的原理。不过,我们不需要钻研汇编语言,只需要有所了解,比如,精准的延时。

一、编译、编辑、版本控制器。

由于STM32的固件库中,函数名、变量名都是很长,我们不可能逐一输入,这就需要用到先进的工具。

1、编译器。仍然使用keil编译代码。

2、编辑器。编辑器就是写代码的工具,因为keil的代码补全、提示都很差,所以要用其它工具来写代码。这就得开两个软件,一个写代码,一个编译代码。虽然这样有点麻烦,但是相对于输入那一大串函数名来比,不算什么。推荐VS、Eclipse(C/C++版本)。不推荐使用source insight(功能不够强大)。

3、版本控制器。这个东西就是用来备份代码的,不要再用压缩包了。推荐git教程。

二、学会固件库。

有了上一步的准备工作之后,先买一块STM32开发板,带仿真器,248元。这里下载代码可不像51那些,用串口就能下载的了,得另外用一个仿真器。

这里的仿真器有ST link、Ulink等,不推荐使用J link。而仿真器的接口有JTAG和SWD,推荐使用SWD,接3根线就可以了。

推荐教材《STM32开发指南库函数教程》,也可以看开发板配套的视频。这里要掌握STM32的外设,如:ADC、RTC、CAN、IIC、SPI、UART、DMA、SDIO、IAP等。

三、自制PCB。

数电、模电基础差的,需要先补充点理论再来。然后下载一个Altium Designer6.9,看《Altium Designer视频教程》。根据自己感兴趣的小玩意来做一块PCB。画好之后先发到群里,让大家指导一下,然后再发到嘉立创打样,很便宜的,而其它材料则到淘宝上买。主要掌握焊接、维修、原理图、PCB等基本功,自己多动手就能掌握的。

四、单片机外面的世界。

就算你现在能玩转单片机,但也只是打开了一扇小小的窗户而已,下面你可以选一个方向,但是工作中可以会用到几个方向的知识,反正尽量多学点。

1、嵌入式操作系统。不推荐用51单片机跑系统。而STM32可以跑ucos II、ucos III、free RTOS、coos、RT-Thread、RTX等。推荐学ucos II,教材是任哲的《嵌入式实时操作系统ucosII原理及应用》,只要掌握一种嵌入式操作系统,其它都可以触类旁通。移植系统时,会用到汇编。推荐学习free RTOS或者RT-Thread。

2、ucgui/STemwin、Touch GFX。STM32可以通过FSMC接口来驱动TFT LCD屏,这里要用到图形界面库,可以学STemwin,STemwin其实就是ucgui,推荐《STemwin开发手册》,也可以学习Touch GFX。

3、上位机。使用单片机采集信号送到PC机上,而PC机需要一个上位机来控制单片机,这个上位机可以用Labview、C++、C、JAVA、甚至是HTML5来写。其中最常用的是单片机跟PC机的串口通信,上位机建议用C或者QT来写,尽管还有很多企业用MFC(C++库),但是上手比较难,不推荐学MFC。推荐的教材是《C#入门经典》、《QT简介》。

4、数据结构和算法。推荐的教材是周航慈的《嵌入式系统软件中的常用算法》、《数据结构课件》。

5、接口应用。单片机的内部资源比较少,很多时候需要外接一些芯片、传感器。这里需要到用模电、电子测量、计算机网络等知识。推荐的教材是陈尚松等著的《电子测量与仪器》和谢希仁的《计算机网络》。此外,还会用到一些通信模块,比如Zigbee、WIFI、蓝牙、NB-IOT、433模块、NRF24L01、RFID智能卡等,有兴趣可以弄一下,这些都是比较实用的技术。

五、其它问题。

1、单片机的代码是如何运行的?

推荐看《计算机组成原理》。

2、FPGA。

可以参考本博客的《如何学习FPGA》。

3、嵌入式。

很多电子专业的学生就感觉嵌入式很难,那是因为嵌入式涉及很多计算机领域的知识,而这些知识很多是电子专业不开课的,基本功没过关,学起来肯定吃力。具体的学习路线可以参考本博客的《如何学习嵌入式软件》。

4、硬件设计。

可以参考本博客的《如何学习硬件设计——理论篇》、《如何学习硬件设计——实践篇》。

5、开发板的选择。

这里推荐的开发板都是一整板(上面的链接并非广告,只是确实有人不会选开发板才给出来的),里面有很多芯片的。不推荐一个核心板留了很多接口,每个接口都要另外买一块小板,这种板叫子母板,一个母板不贵,但是子板很多,买多几块就花很多钱,而且子板很小,容易丢。

6、为什么学生很难定方案?

因为学生积累的东西并不多,考虑的不那么周全,很多知识似懂非懂,难以制订方案。这时要多接触新事物,只要积累的多,就自然而然的能出方案了,不用太急躁。

7、MDK。

Keil有51版本和ARM版本,其中ARM版本的Keil又称为MDK。

8、stm32 cubemx。

cubemx可以自动生成配置代码,虽然很方便,但不建议初学者使用,会让你懒得不想写代码。

9、为什么编译没问题,下载到单片机却不对?

编译没问题,说明语法没问题,但不能表明逻辑、功能是正确的。

10、为什么网上都有那么多代码可以复制粘贴,还要自己写代码?

因为网上能找到的代码很多,而网上找不到的代码却更多。

11、proteus及multisim仿真。

proteus很适合仿真单片机,但是仿真的效果不能替代实物,一切以实物为准。

multisim适合在学模电时,做一下仿真,以帮助理解电路。

12、为什么有的STM32开发板可以用串口下载代码,还需要仿真器吗?

STM32有个IAP的功能(又称为远程升级),可以用任意的接口来下载代码,但是这种方法是建立在芯片本身有IAP的代码,才可以使用。

在一个没有任何代码的芯片上,不能使用串口下载代码,这时,必须使用仿真器。

13、单片机不就是C语言嘛,还需要学单片机原理?

在工程上会遇到单片机内部资源的调度、IO口的电气特性、带宽等问题,你不懂单片机原理是解决不了这些问题的。

14、单片机的汇编和微机原理的汇编。

微机原理讲的是PC机中x86架构的汇编,和51单片机的汇编是有区别的。不要看错书。

而51单片机的汇编和STM32的汇编也是有区别的,51的是CISC架构,而STM32的是RISC架构。

15、除STM32以外的高端单片机品牌。

有NXP的LPC、新唐、GD32(高仿STM32)、英飞凌、TI的MSP430、Microchip的PIC、瑞萨、ADI、Maxim(美信)、三星。

16、其它单片机品牌。

合泰、辉芒、松瀚、海尔(东软)、STC、义隆、新茂、中颖、ABOV(现代)、Megawin(笙泉)、晟矽微、HOLTEK(盛扬)、九齐、佑华、灵动微。

————————————————

版权声明:本文为CSDN博主「队长-Leader」的原创文章,授权转载

相关问答

51 单片机 中的*** error 56 : can't open file?

1.目标文件存放错误了,重新设置一下你存放目标文件的目录。2.看下:第一个translate(Ctrl+F7)这个只编译不连接,第二个build(F7)这个才会产生链接产生obj...1...

stc15w4k 56 s4 单片机 有什么特点,有多少个引脚,程序存储器和数据存储器分别有多大?

64L封装);数据存储器大小:4KB(4096)...引脚个数:这个主要看封装形式,其引脚分别为44脚(LQFP44封装),40脚(DIP40),48脚(LQFP48),64脚(LQFP64S及L...

单片机 中A=4EH,B=5DH,MULAB怎么计算的结果是AB=1C 56H ?怎么来...

[最佳回答]列算式就可以知道怎么得到的了:01001110;A=4EH,01011101;B=5DH,------------------------;x;MULAB01001110000000000100...

飞思卡尔 单片机 MC 56 F801X与MC9S12X有什么不同?

MC56F系列是飞思卡尔的DSC系列MCU,主打电机控制;而MC9S作为智能车的应用非常多,学习资料和例程也远比DSC的多;更重要的,MC56F系列的单片机的编译器USP-TAP可...

一个 单片机 的乘法指令?

单片机乘法指令是MULAB,只能是累加器A和寄存器B相乘,结果低八位存入A,高八位存入B。比如题中,A=4EH,B=5DH,A*B=1C56H,所以A=56H,B=1CH单片机乘法指令是MULAB,...

单片机 8051的详细资料有哪几种

[最佳回答]MCS-51单片机的引脚描述及片外总线结构一、芯片的引脚描述HMOS制造工艺的MCS-51单片机都采用40引脚的直插封装(DIP方式),制造工艺为CHMOS的80C51/...

单片机 技术与应用”课程标准设计

[回答]1原有教学大纲与新课标的差异原来使用的“单片机技术与应用”课程的教学大纲对知识点分解层层深入,便于学生由浅入深地学习相关知识。但是由于...

单片机 引脚为何接上拉电阻它的大小怎么计算啊】作业帮

[最佳回答]上拉电阻下拉电阻的总结作者:佚名转贴自:网络点击数:68文章录入:admin上拉电阻:1、当TTL电路驱动COMS电路时,如果TTL电路输出的高电平低于COMS电...

单片机 复位电路 复位时间的计算方法-ZOL问答

现在假设你的单片机的输出电阻为RO,电源为VDD,复位电路的电阻和电容分别为R和C。时间常数为(RO+R)C公式如下,Vrst为电容上的电压有用(0)回复pcy56电阻的作...

飞思卡尔 单片机 有什么特点呢?

区别不大,都是对寄存器操作的,熟悉了寄存器规则以及编程方法就行飞思卡尔单片机系列32位Kinetis系列;32位ColdFire系列;32位MPC56xx系列;8位微控制器系列(...

猜你喜欢