什么是 .S 文件?

115

我在各种项目中看到过 .S 文件,例如在Linux内核、FreeBSD内核或其他一些项目中。这些文件的作用是什么?为什么我们不能使用 .c 文件代替呢?

8个回答

112

.S 文件是用汇编语言编写的源代码文件,汇编语言属于一种极低级别的编程语言。这些文件按顺序包含给处理器的汇编指令,并且通常基于所选的体系结构进行编译。例如,在特定体系结构(如x86、sparc、ARM等)的Linux内核中经常看到此类文件。

有关汇编语言的更多信息,请参见以下内容:


16
为什么它不叫做.asm - Liga
10
因为有人更喜欢使用 ".s"。 - user14387228
3
我不知道为什么Unix汇编器最初选择使用.s / .S,但如今在现代的x86上,通常使用.asm作为NASM/YASM/FASM/MASM/JWASM等源文件的扩展名(使用dd指令),而对于GAS/clang汇编源文件,则使用.S扩展名(使用.long指令,并默认采用AT&T语法)。我认为有些人确实会将.asm用于GAS源文件,特别是对于其他架构,如ARM,也许特别是嵌入式开发。(非GAS ARM汇编器,如Keil使用不同的语法。) - Peter Cordes

86

.S 文件通常是汇编语言。

有一些事情没人提到,为什么要用大写的 S

  • .S(大写的 S)代表必须通过一个预处理器的汇编代码。这意味着它可以包含 #include#define等宏定义。它也可以被写成 .sx

  • .s(小写的 s)是纯汇编代码,可以编译成目标文件。

为什么不使用 .c 呢?作为操作系统,不可能全部使用 C 语言编写。实际上,那将是理想的方式,C 语言本身的背景历史与帮助创建操作系统并减少编码所需的汇编量有关。但是许多低级操作太依赖于机器。

下面是一个很好的例子,展示了一个在 Linux 引导中使用 #include <linux/linkage.h>内存复制程序


2
是的,这个答案非常重要。我最近遇到了“.s”问题。代码是从其他项目复制过来的,我只是把“.S”改成了“.s”。我必须将#define SOME_CONST 1更改为SOME_CONST = 1并将其放入.s文件中。这让我很困惑。我检查了编译标志,没有线索......然后我猜可能后缀很重要?然后一次搜索命中了这个链接和答案 :) - bruin

15

.S 文件是汇编文件。

为什么使用 .S 而不是 .c 文件?

因为需要进行机器相关的操作和早期初始化,例如设置缓存和内存,只能使用汇编级别的指令,例如 I/O 指令。

内核没有使用 libc 库来处理各种资源的初始化的豪华条件。

任何时间点的硬件资源甚至在应用程序执行期间都会调用系统调用,这些调用 I/O 程序是用汇编语言编写的。


11
.S扩展名表示汇编语言文件。汇编语言文件的文件扩展名通常是.S,而不是.C,因为原始源代码(无论是人工输入还是编译器生成的)都是汇编代码,而不是C语言。

6

这些文件是汇编代码文件:

汇编语言是一种面向计算机、微处理器、微控制器和其他可编程设备的低级编程语言,其中每个语句对应于单个机器语言指令。与大多数高级编程语言可能更具可移植性不同,汇编语言特定于某种计算机体系结构。

因此,这些文件与C代码文件不同。

请注意,C文件可以嵌入汇编指令


4

.S文件是用汇编语言编写的代码,即编程的低级形式。在Linux内核源代码中,.S通常是内核启动时运行的起始文件(例如:head.S)。我们使用.S而不是.C来编写这个文件,因为此时我们还没有准备好运行.C编译后的.O文件。我们需要使用与体系结构相关的寄存器并启动内核。


4

.S文件是汇编语言文件。它们是一种机器码形式,属于低级编程。所有与机器相关的代码都是用汇编语言编写的,不同处理器的汇编语言是不同的。


3

为了完整起见:还有另一个“.s”文件,它不是汇编文件,而是“SREC”二进制文件(以ASCII编码),用于编程微控制器。

https://en.wikipedia.org/wiki/SREC_(file_format)

打开这样的文件后,你会看到像这样的文本行:
S315000000500C9413110C94D510189518950C949710B0
S31500000060189518950C941010189518950C946A10FC
S31500000070189518950C9403131895189518951895B6
S315000000800C940B1218951895189518950C944912FE
S315000000900C943D101895189518951895189518955F

.s37文件也是SREC文件...在使用Silicon Labs MCU时会遇到 - Frederick

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接