linux.asm

作者&投稿:大叔疫 (若有异议请与网页底部的电邮联系)
~

计算机语言有后缀名吗?

常见的编程语言源文件后缀名

众所周知,编程语言源文件的后缀名可以帮助我们快速的判断其是哪种语言,从而选择合适的编译器,方便我们后期的学习和操作。

在介绍编程语言源文件后缀名之前,我们先把编程语言分个类:常见的分类为机器语言(由二进制码0和1构成)、汇编语言、高级语言三个。还可以将其分为编译语言(典型的有C、C++、Go、Swift、object-c以及汇编等)和解释性语言(Javascript、python、php、perl、Ruby等)以及混合性语言(Java和C#等)

机器语言

首先我们要明白,机器语言和后缀名没有必然联系;其次,机器语言一般不需要编译和解释,对一般的单片机或嵌入式CPU,机器语言的后缀名一般为.bin(直接的二进制文件)或.hex(16进制文本),对操作系统来说,机器语言就是可执行文件,在windows系统中,典型的是.exe.dll.com.sys等,而在linux系统中机器语言一般没有后缀,因为在Linux中,带有扩展名的文件,只能代表程序的关联,并不能说明文件是可以执行,从这方面来说,Linux的机器语言扩展名没有太大的意义。

简述BootLoader的功能和启动过程?

作用原理

编辑

⒈BootLoader所支持的CPU和嵌入式板

每种不同的CPU体系结构都有不同的BootLoader。有些BootLoader也支持多种体系结构的CPU,比如U-Boot就同时支持ARM体系结构和MIPS体系结构。除了依赖于CPU的体系结构外,BootLoader实际上也依赖于具体的嵌入式板级设备的配置。这也就是说,对于两块不同的嵌入式板而言,即使它们是基于同一种CPU而构建的,要想让运行在一块板子上的BootLoader程序也能运行在另一块板子上,通常也都需要修改BootLoader的源程序。

⒉BootLoader的安装媒介(InstallationMedium)

系统加电或复位后,所有的CPU通常都从某个由CPU制造商预先安排的地址上取指令。比如,基于ARM7TDMIcore的CPU在复位时通常都从地址0x00000000取它的第一条指令。而基于CPU构建的嵌入式系统通常都有某种类型的固态存储设备(比如:ROM、EEPROM或FLASH等)被映射到这个预先安排的地址上。因此在系统加电后,CPU将首先执行BootLoader程序。

⒊用来控制BootLoader的设备或机制

主机和目标机之间一般通过串口建立连接,BootLoader软件在执行时通常会通过串口来进行输入、输出,比如:输出打印信息到串口,从串口读取用户控制字符等。

⒋BootLoader的启动过程

BootLoader的启动过程可分为单阶段(Single-Stage)和多阶段(Multi-Stage)两种。通常多阶段的BootLoader具有更复杂的功能,更好的可移植性。从固态存储设备上启动的BootLoader大多采用两阶段,即启动过程可以分为stage1和stage2:stage1完成初始化硬件,为stage2准备内存空间,并将stage2复制到内存中,设置堆栈,然后跳转到stage2。

⒌BootLoader的操作模式(OperationMode)

大多数BootLoader都包含两种不同的操作模式。启动加载模式和下载模式。

(1)启动加载(Bootloading)模式:这种模式也称为“自主”模式,也即BootLoader从目标机上的某个固态存储设备上将操作系统加载到RAM中运行,整个过程并没有用户的介入。这种模式是BootLoader的正常工作模式。

(2)下载(Downloading)模式:在这种模式下目标机上的BootLoader将通过串口连接或网络连接等通信手段从主机下载文件。从主机下载的文件通常首先被BootLoader保存到目标机的RAM中然后再被BootLoader写到目标机上的固态存储设备中。

⒍BootLoader与主机之间进行文件传输所用的通信设备及协议

分为两种情况。一种是目标机使用串口与主机相连。这时的传输协议通常是xmodem/ymodem/zmodem中的一种。第二种可以用网络连接的方式传输文件,这时使用的协议多为tftp。

解析

编辑

网上关于Linux的BOOTLOADER文章不少了,但是大都是vivi,blob等比较庞大的程序,读起来不太方便,编译出的文件也比较大,而且更多的是面向开发用的引导代码,做成产品时还要裁减,这一定程度影响了开发速度,对初学者学习开销也比较大,在此分析一种简单的BOOTLOADER,是在三星公司提供的2410BOOTLOADER上稍微修改后的结果,编译出来的文件大小不超过4k,希望对大家有所帮助.

重要概念

COMPRESSEDKERNELandDECOMPRESSEDKERNEL

压缩后的KERNEL,按照文档资料,现在不提倡使用DECOMPRESSEDKERNEL,而要使用COMPRESSEDKERNEL,它包括了解压器.因此要在ram分配时给压缩和解压的KERNEL提供足够空间,这样它们不会相互覆盖.

当执行指令跳转到COMPRESSEDKERNEL后,解压器就开始工作,如果解压器探测到解压的代码会覆盖掉COMPRESSEDKERNEL,那它会直接跳到COMPRESSEDKERNEL后存放数据,并且重新定位KERNEL,所以如果没有足够空间,就会出错.

Jffs2FileSystem

可以使armlinux应用中产生的数据保存在FLASH上,我的板子还没用到这个.

RAMDISK

使用RAMDISK可以使ROOTFILESYSTEM在没有其他设备的情况下启动.一般有两种加载方式,最常用的一种是,把COMPRESSEDRAMDISKIMAGE放到指定地址,然后由BOOTLOADER把这个地址通过启动参数的方式ATAG_INITRD2传递给KERNEL.具体看代码分析.

启动参数(摘自IBMdeveloper)

在调用内核之前,应该作一步准备工作,即:设置Linux内核的启动参数。Linux2.4.x以后的内核都期望以标记列表(taggedlist)的形式来传递启动参数。启动参数标记列表以标记ATAG_CORE开始,以标记ATAG_NONE结束。每个标记由标识被传递参数的tag_header结构以及随后的参数值数据结构来组成。数据结构tag和tag_header定义在Linux内核源码的include/asm/setup.h头文件中.

在嵌入式Linux系统中,通常需要由BOOTLOADER设置的常见启动参数有:ATAG_CORE、ATAG_MEM、ATAG_CMDLINE、ATAG_RAMDISK、ATAG_INITRD等。

(注)参数也可以用COMMANDLINE来设定,在我的BOOTLOADER里,我两种都用了.

开发环境

CPU:S3C2410,BANK6上有64M的SDRAM(两块),BANK0上有32MNORFLASH,串口当然是逃不掉的.这样,按照数据手册,地址分配如下:

0x4000_0000开始是4k的片内DRAM.

0x0000_0000开始是32MFLASH16bit宽度

0x3000_0000开始是64MSDRAM32bit宽度

注意:控制寄存器中的BANK6和BANK7部分必须相同.

0x4000_0000(片内DRAM)存放4k以内的BOOTLOADERIMAGE

0x3000_0100开始存放启动参数

0x3120_0000存放COMPRESSEDKERNELIMAGE

0x3200_0000存放COMPRESSEDRAMDISK

0x3000_8000指定为DECOMPRESSEDKERNELIMAGEADDRESS

0x3040_0000指定为DECOMPRESSEDRAMDISKIMAGEADDRESS

开发环境:RedhatLinux,armgcctoolchain,armlinuxKERNEL

如何建立armgcc的编译环境:建议使用toolchain,而不要自己去编译armgcc,偶试过好多次,都以失败告终.

先下载arm-gcc3.3.2toolchain

将arm-linux-gcc-3.3.2.tar.bz2解压到/toolchain

tarjxvfarm-linux-gcc-3.3.2.tar.bz2

mv/usr/local/arm/3.3.2/toolchain

在makefile中在把arch=armCROSS_COMPILE设置成toolchain的路径

还有就是INCLUDE=-I../include-I/root/my/usr/local/arm/3.3.2/include.,否则库函数就不能用了

启动方式

可以放在FLASH里启动,或者用Jtag仿真器.由于使用NORFLASH,根据2410的手册,片内的4KDRAM在不需要设置便可以直接使用,而其他存储器必须先初始化,比如告诉memorycontroller,BANK6里有两块SDRAM,数据宽度是32bit,==.否则memorycontrol会按照复位后的默认值来处理存储器.这样读写就会产生错误.

所以第一步,通过仿真器把执行代码放到0x4000_0000,(在编译的时候,设定TEXT_BAS

E=0x40000000)

第二步,通过AxD把linuxKERNELIMAGE放到目标地址(SDRAM)中,等待调用

第三步,执行BOOTLOADER代码,从串口得到调试数据,引导armlinux

代码分析

讲了那么多执行的步骤,是想让大家对启动有个大概印象,接着就是BOOTLOADER内部的代码分析了,BOOTLOADER文章内容网上很多,我这里精简了下,删除了不必要的功能.

BOOTLOADER一般分为2部分,汇编部分和c语言部分,汇编部分执行简单的硬件初始化,C部分负责复制数据,设置启动参数,串口通信等功能.

BOOTLOADER的生命周期:

⒈初始化硬件,比如设置UART(至少设置一个),检测存储器==.

⒉设置启动参数,这是为了告诉内核硬件的信息,比如用哪个启动界面,波特率==.

⒊跳转到LinuxKERNEL的首地址.

⒋消亡

同时在linux中GRUB(GRandUnifiedBootloader)是一个系统默认自带的多重启动管理器。它可以在多个操作系统共存时选择引导哪个系统。尽管引导操作系统看上去是件平凡且琐碎的任务,但它实际上很重要。如果引导装入器不能很好地完成工作或者不具有弹性,那么就可能锁住系统或者无法引导计算机??

如何编写驱动程序?

代码:#includelinux/module.h>#includelinux/kernel.h>#includeasm/io.h>#includelinux/miscdevice.h>#includelinux/fs.h>#includeasm/uaccess.h>//流水灯代码#defineGPM4CON0x110002e0#defineGPM4DAT0x110002e4staticunsignedlong*ledcon=NULL;staticunsignedlong*leddat=NULL;//自定义write文件操作(不自定义的话,内核有默认的一套文件操作函数)staticssize_ttest_write(structfile*filp,constchar__user*buff,size_tcount,loff_t*offset){intvalue=0;intret=0;ret=copy_from_user(value,buff,4);//底层驱动只定义基本操作动作,不定义功能if(value==1){*leddat|=0x0f;*leddat=0xfe;}if(value==2){*leddat|=0x0f;*leddat=0xfd;}if(value==3){*leddat|=0x0f;*leddat=0xfb;}if(value==4){*leddat|=0x0f;*leddat=0xf7;}return0;}//文件操作结构体初始化staticstructfile_operationsg_tfops={.owner=THIS_MODULE,.write=test_write,};//杂设备信息结构体初始化staticstructmiscdeviceg_tmisc={.minor=MISC_DYNAMIC_MINOR,.name="test_led",.fops=g_tfops,};//驱动入口函数杂设备初始化staticint__inittest_misc_init(void){//IO地址空间映射到内核的虚拟地址空间ledcon=ioremap(GPM4CON,4);leddat=ioremap(GPM4DAT,4);//初始化led*ledcon=0xffff0000;*ledcon|=0x00001111;*leddat|=0x0f;//杂设备注册函数misc_register(g_tmisc);return0;}//驱动出口函数staticvoid__exittest_misc_exit(void){//释放地址映射iounmap(ledcon);iounmap(leddat);}//指定模块的出入口函数module_init(test_misc_init);module_exit(test_misc_exit);MODULE_LICENSE("GPL");扩展资料:include用法:#include命令预处理命令的一种,预处理命令可以将别的源代码内容插入到所指定的位置;可以标识出只有在特定条件下才会被编译的某一段程序代码;可以定义类似标识符功能的宏,在编译时,预处理器会用别的文本取代该宏。插入头文件的内容#include命令告诉预处理器将指定头文件的内容插入到预处理器命令的相应位置。有两种方式可以指定插入头文件:1、#include文件名>2、#include"文件名"如果需要包含标准库头文件或者实现版本所提供的头文件,应该使用第一种格式。如下例所示:#includemath.h>//一些数学函数的原型,以及相关的类型和宏如果需要包含针对程序所开发的源文件,则应该使用第二种格式。采用#include命令所插入的文件,通常文件扩展名是

.h

,文件包括函数原型、宏定义和类型定义。只要使用#include命令,这些定义就可被任何源文件使用。如下例所示:#include"myproject.h"//用在当前项目中的函数原型、类型定义和宏你可以在#include命令中使用宏。如果使用宏,该宏的取代结果必须确保生成正确的#include命令。例1展示了这样的#include命令。【例1】在#include命令中的宏#ifdef_DEBUG_#defineMY_HEADER"myProject_dbg.h"#else#defineMY_HEADER"myProject.h"#endif#includeMY_HEADER当上述程序代码进入预处理时,如果_DEBUG_宏已被定义,那么预处理器会插入

myProject_dbg.h

的内容;如果还没定义,则插入

myProject.h

的内容。




linux0.11\/ asm.s有些问题不太明白,懂内核的帮忙解答一下,谢了!_百度...
movl $0x10,%edx mov %dx,%ds mov %dx,%es mov %dx,%fs 改变的是CPU的寄存器的值,而全局描述符在内存中,怎么可能覆盖呢 全局描叙符需要在ds es fs装入一些值,CPU才知道在描叙符表中去使用哪个描叙符 而中断因为提供了中断号,等于告诉了CPU在描叙符表中去使用哪个描叙符 你混淆了“使用...

文件的扩展名有那些种,各代表什么意思?有劳!
当使用字处理软件编辑高级语言程序时,后缀通常为相应语言的前三个字母(如:*.BAS即BASIC语言源程序,*.PAS为PASCAL语言程序,*.FOR为Fortran语言程序,*.C即为C语言,*.ASM即为汇编语言程序)。 伴随着可执行文件常附有以下几类文件:*.HLP即帮助文件(help)、*.CFG即配置文件(config)、*.DAT即数据文件(data)、*...

linux的内核3.9.6为什么没有asm-arm这个文件夹
文件存放方式改了呗……Linux 内核现在一直就有 arm 的支持,官方源代码支持很多架构的。3.9.6 不需要移植就能跑 arm 上。当然是指 CPU ,arm 更多的是需要驱动和一些接口设置的修改才能完美运行在某个 arm 设备上。

linux中的generic是什么意思?如:asm-generic是跟什么相关的代码,还有inc...
asm:汇编语言 generic:通用的版本,一般指通用CPU的版本,如普通的cpu,还有其他特殊的cpu如sun的sparc,asm-generic: 汇编程序的通用版本

Linux下的内核编译问题 关于没有asm-i386怎么办
???编译内核关 asm-i386 鸟事?编译内核关 usr\/include 鸟事?make menuconfig 出错。那是 menuconfig 这个字符界面所需要的环境的问题,和内核没关系。印象里这个设置界面,需要 readline 等等的一些外部功能支持程序。如果你有内核 config (一般放在内核源代码的根目录,名字是 .config )。那你完全...

请教Linux下 armasm命令
可以这么说 你可以用命令ls -ls asm->asm-arm查看,这个是软链接也就是类似于window下面的快捷方式!

linux7能安装oracle asm吗
可以安装asm,安装与配置步骤如下:1 安装Oracle ASM 使用yum命令网络安装 yum install oracleasm oracleasm-support本地安装 cd \/mnt\/install_DVD\/Packages# rpm -qi oracleasm# rpm -qi oracleasm-support# rpm -qi oracleasm-support-2.1.8-1.el6.x86_64.rpm 2 使用fdisk命令为每个硬盘创建...

如何在Linux内核里增加一个系统调用?
添加新的系统调用后,下一个任务是使Linux内核的其余部分知道该程序的存在。为了从已有的内核程序中增加到新的函数的连接,需要编辑两个文件。 在我们所用的Linux内核版本(RedHat 6.0,内核为2.2.5-15)中,第一个要修改的文件是: \/usr\/src\/linux\/include\/asm-i386\/unistd.h 该文件中包含了系统调用清单,用来给每个...

如何在64位的linux系统上使用汇编和C语言混合编程
C51与汇编语言混合编程(1).C51语言中调用汇编语言程序1、在文件中选中FILEGROUP和C51程序原文件,在配置文件选项中激活“i”产生汇编(SRC)文件,“编译(SRC)文件”和“创建工程(目标)时包含“三个选项。2、根据选择的编译模式,把相应的库文件(如SMALL模式,库文件为KEIL\\C51\\LIB\\C51S.LIB)加入...

如何重新编译linux内核
修改\/usr\/src\/linux-2.6.36\/kernel\/sys.c文件,在文件末尾增加一个系统调用函数。自行编写一个简单的程序即可,只为测试用。修改\/usr\/src\/linux-2.6.36\/arch\/x86\/kernel\/syscall_table_32.S,为新添加的程序配置系统调用号。在\/usr\/src\/linux-2.6.36\/arch\/x86\/include\/asm\/unistd_32.h中...

十大健康食物排行榜 : ·第一名 番茄
·第二名 菠菜
·第三名 坚果
·第四名 椰菜花
·第五名 燕麦
·第六名 鲑鱼
·第七名 大蒜
·第八名 蓝莓
·第九名 绿茶
·第十名 红酒

十大健康水果排行榜 : ·第一名 苹果
·第二名 杏
·第三名 香蕉
·第四名 黑莓
·第五名 蓝莓
·第六名 甜瓜
·第七名 樱桃
·第八名 越橘
·第九名 葡萄柚
·第十名 紫葡萄

黔西县18948585051: 什么是Linux ASM? -
段面生乳: 就是linux下的嵌入式系统开发

黔西县18948585051: linux交叉编译libfad出现asm错误,不知道如何解决 -
段面生乳: 没遇到过这个问题,我编译过libmad,是一个音频解码库.这个"asm",在Linux内核里表示跟CPU体系结构相关的东西.我猜测是不是这个libmad需要单独编译成ARM版本的库,然后再基于这个库编译.我之前编译播放器的时候就是需要单独编一个libmad.以上只是个人推测,如果你找到问题所在,还请把编译方法讲一下,交流学习.QQ:1138354321

黔西县18948585051: linux7能安装oracle asm吗 -
段面生乳: 可以安装asm,安装与配置步骤如下:1 安装Oracle ASM 使用yum命令网络安装# yum install oracleasm oracleasm-support本地安装# cd /mnt/install_DVD/Packages# rpm -qi oracleasm# rpm -qi oracleasm-support# rpm -qi oracleasm-support-2.1....

黔西县18948585051: 怎样在Linux下查看ASM磁盘上的文件 -
段面生乳: 支持一下感觉挺不错的

黔西县18948585051: linux 上磁盘做ASM盘使用一定要先fdisk格式化吗 -
段面生乳: fdisk是分区用的,不是格式化 asm不用格式化

黔西县18948585051: linux内核 asm - i386 asm - x86 什么区别 -
段面生乳: 存放的是基于i386架构的CPU相关的内核程序.因为CPU架构不同,寄存器组也不同,所以一些需要直接与CPU打交道的函数实现会因为CPU架构不同而不同.

黔西县18948585051: asm - > asm - arm 在Linux中我怎么asm - arm是asm的快捷方式呢? -
段面生乳: 可以这么说 你可以用命令ls -ls asm->asm-arm查看,这个是软链接也就是类似于window下面的快捷方式!

黔西县18948585051: linux上安装grid报asm配置错误 -
段面生乳: 【视频教学】Maclean教你用Vbox在Linux 5安装Oracle 11gR2 RAC http://t.askmaclean.com/thread-1061-1-1.html11g RAC按照这个装不会有任何问题

黔西县18948585051: linux中怎样判断文件在磁盘的位置? -
段面生乳: 可以用fdisk & disk - l & df 查看系统硬盘信息和使用情况. 1、fdisk -l,查看硬盘信息.查看硬盘情况.2、df -h查看硬盘各个挂载点信息.

黔西县18948585051: Linux内核编译出错. -
段面生乳: 你的编译环境有问题.as 提示不支持某个参数,而且从上面看你应该在编译 arm 架构的内核,但后面的提示是 as 命令,这种名字的命令(没有架构前缀)应该是本地编译器.我想你不太可能在 arm 上本地编译内核吧(实际上确实可以,而且...

本站内容来自于网友发表,不代表本站立场,仅表示其个人看法,不对其真实性、正确性、有效性作任何的担保
相关事宜请发邮件给我们
© 星空见康网