Chinaunix首页 | 论坛 | 博客
  • 博客访问: 1491801
  • 博文数量: 204
  • 博客积分: 4013
  • 博客等级: 中校
  • 技术积分: 4030
  • 用 户 组: 普通用户
  • 注册时间: 2011-12-29 06:34
文章分类

全部博文(204)

文章存档

2012年(204)

分类: LINUX

2012-10-16 13:24:18

点击(此处)折叠或打开

  1. #
  2. # Makefile for some libs needed in the kernel.
  3. #
  4. # Note! Dependencies are done automagically by 'make dep', which also
  5. # removes any old dependencies. DON'T put your own dependencies here
  6. # unless it's something special (ie not a .c file).
  7. #
  8. # 内核需要用到的libs库文件程序的Makefile。
  9. # 注意!依赖关系是由'make dep'自动进行的,它也会自动去除原来的依赖信息。不要把你自己的
  10. # 依赖关系信息放在这里,除非是特别文件的(也即不是一个.c 文件的信息)。
  11. AR =gar # GNU 的二进制文件处理程序,用于创建、修改以及从归档文件中抽取文件。
  12. AS =gas # GNU 的汇编程序。
  13. LD =gld # GNU 的连接程序。
  14. LDFLAGS =-s -x # 连接程序所有的参数,-s 输出文件中省略所有符号信息。-x 删除所有局部符号
  15. CC =gcc # GNU C 语言编译器。
  16. # C 编译程序选项。-Wall 显示所有的警告信息;-O 优化选项,优化代码长度和执行时间;
  17. # -fstrength-reduce 优化循环执行代码,排除重复变量;-fomit-frame-pointer 省略保存不必要
  18. # 的框架指针;-fcombine-regs 合并寄存器,减少寄存器类的使用;-finline-functions 将所有简
  19. # 单短小的函数代码嵌入调用程序中;-mstring-insns Linus 自己填加的优化选项,以后不再使用;
  20. # -nostdinc -I../include 不使用默认路径中的包含文件,而使用这里指定目录中的(../include)。
  21. CFLAGS =-Wall -O -fstrength-reduce -fomit-frame-pointer -fcombine-regs \
  22. -finline-functions -mstring-insns -nostdinc -I../include
  23. # C 前处理选项。-E 只运行C 前处理,对所有指定的C 程序进行预处理并将处理结果输出到标准输
  24. # 出设备或指定的输出文件中;-nostdinc -I../include 同前。
  25. CPP =gcc -E -nostdinc -I../include
  26. # 下面的规则指示make 利用下面的命令将所有的.c 文件编译生成.s 汇编程序。该规则的命令
  27. # 指使gcc 采用CFLAGS 所指定的选项对C 代码编译后不进行汇编就停止(-S),从而产生与
  28. # 输入的各个C 文件对应的汇编代码文件。默认情况下所产生的汇编程序文件名是原C 文件名
  29. # 去掉.c 而加上.s 后缀。-o 表示其后是输出文件的名称。其中$*.s(或$@)是自动目标变量,
  30. # $<代表第一个先决条件,这里即是符合条件*.c 的文件。
  31. .c.s:
  32. $(CC) $(CFLAGS) \
  33. -S -o $*.s $<
  34. .s.o:
  35. $(AS) -c -o $*.o $<
  36. .c.o:
  37. $(CC) $(CFLAGS) \
  38. -c -o $*.o $<
  39. #下面定义目标文件变量OBJS。
  40. OBJS = ctype.o _exit.o open.o close.o errno.o write.o dup.o setsid.o \
  41. execve.o wait.o string.o
  42. #在有了先决条件OBJS 后使用下面的命令连接成目标lib.a 库文件。
  43. lib.a: $(OBJS)
  44. $(AR) rcs lib.a $(OBJS)
  45. sync
  46. # 下面的规则用于清理工作。当执行'make clean'时,就会执行下面的命令,去除所有编译
  47. # 连接生成的文件。'rm'是文件删除命令,选项-f 含义是忽略不存在的文件,并且不显示删除信息。
  48. clean:
  49. rm -f core *.o *.a tmp_make
  50. for i in *.c;do rm -f `basename $$i .c`.s;done
  51. # 下面得目标或规则用于检查各文件之间的依赖关系。方法如下:
  52. # 使用字符串编辑程序sed 对Makefile 文件(即是本文件)进行处理,输出为删除Makefile
  53. # 文件中'### Dependencies'行后面的所有行(下面从45 开始的行),并生成tmp_make
  54. # 临时文件(39 行的作用)。然后对kernel/blk_drv/目录下的每个C 文件执行gcc 预处理操作.
  55. # -M 标志告诉预处理程序输出描述每个目标文件相关性的规则,并且这些规则符合make 语法。
  56. # 对于每一个源文件,预处理程序输出一个make 规则,其结果形式是相应源程序文件的目标
  57. # 文件名加上其依赖关系--该源文件中包含的所有头文件列表。把预处理结果都添加到临时
  58. # 文件tmp_make 中,然后将该临时文件复制成新的Makefile 文件。
  59. dep:
  60. sed '/\#\#\# Dependencies/q' < Makefile > tmp_make
  61. (for i in *.c;do echo -n `echo $$i | sed 's,\.c,\.s,'`" "; \
  62. $(CPP) -M $$i;done) >> tmp_make
  63. cp tmp_make Makefile
  64. ### Dependencies:

阅读(3126) | 评论(0) | 转发(1) |
给主人留下些什么吧!~~