linux內核頭文件編譯
A. 為什麼要編譯linux內核(beaglebone的開發板)
1、頭文件不能用,就是說編譯器找不到,要麼是頭文件的位置不對,要麼是根本沒有所需要的頭文件;比如#include<linux/gpio.h>,那就是在你的linux源碼目錄中的include/linux/目錄下要有gpio.h這個文件,如果沒有,自然就編譯通不過了。
2、你所說的光碟資料source文件夾,因為我也沒有你的光碟,所以無法確定它的內容到底是不是內核,makefile文件是編譯器所需要的依賴關系文件,config文件就不清楚了,如果是kconfig文件,那就是內核的配置文件。
B. 編譯LINUX內核的問題
可能是沒有安裝ncurses5,
ubuntu,debian的話,安裝
sudo aptitude install libncurses5-dev
fedora安裝
yum install ncurses ncurses-devel
另外,可能也有可能是/usr/include/目錄下的asm、linux和scsi等鏈接沒有指向要升級的內核源代碼。它們分別鏈向源代碼目錄下的真正的、該計算機體系結構(對於PC機來說,使用的體系結構是i386)所需要的真正的include子目錄。如:asm指向/usr/src/linux/include /asm-i386等,以2.6.32為例,把linux-2.6.32.tar.gz拷貝到/usr/src下
#cd /usr/src
解壓
#tar -xzvf linux-2.6.32.tar.gz
#ln -s linux-2.6.32 linux
#cd /usr/include
#rm -Rf asm linux scsi //刪除原有的鏈接
#ln -s /usr/src/kernels/linux-2.6.23.1/include/asm-i386 asm
#ln -s /usr/src/kernels/linux-2.6.23.1/include/linux linux
#ln -s /usr/src/kernels/linux-2.6.23.1/include/scsi scsi
#cd /usr/src/linux
然後執行
#make menuconfig
GOOD LUCK
C. 關於在linux下用gcc編譯頭文件的問題。
我用一個例子來告訴你怎麼樣在 C++ 里使用C的頭文件/函數。
比方說我有一個C的頭文件叫 c.h, C的源碼文件叫 c.c,內容分別是
c.h:
#ifndef _ASDFD_INCLUDED_
#define _ASDFD_INCLUDED_
#include <stdio.h>
extern int test(int a);
#endif
c.c:
#include "c.h"
int test(int a)
{
printf("A = %d\n", a);
return a*a;
}
現在我想在c++中使用c.c中提供的函數test(),我的c++文件名字叫 a.cpp,那麼裡面跟C有關的部分就要用 extern "C" {} 大括弧括起來,看看我的
a.cpp:
#include <iostream>
using namespace std;
extern "C"
{
#include "c.h"
}
int main()
{
int b = 12;
b = test(b);
cout<<"b = "<<b<<endl;
return 0;
}
看到了吧,#include "c.h" 被 extern "C" {}括起來了。
然後是如何編譯,先把C文件編出目標文件(.o)來
gcc -c c.c
你會看到生成了 c.o,其實,有目標文件就夠了,如果你一定要做成(靜態/動態)庫文件,也是可以的,不過我這里就不深入了,做成庫和直接用目標文件對解決你的問題沒有任何區別。
然後再編譯C++文件,也就是我的 a.cpp
g++ -o hello a.cpp c.o
看到了吧,我在編譯 a.cpp 的時候把C生成的 c.o也加上了。 然後生成 可執行的 hello, 運行
./hello
就可以看到
A = 12
b = 144
關於創建靜態庫,假定你有3個C文件, a.c, b.c, c.c 提供了你C++要用到的介面,那麼可以把這三個C文件編譯出來的目標文件放到一個庫文件里供C++使用,方法為
先編譯出目標文件
gcc -c a.c b.c c.c
這時候你應該看到有 a.o b.o c.o了
然後創建庫文件
ar cr libtest.a a.o b.o c.o
這三個目標文件就放入 libtest.a 這個靜態庫中了,然後編譯C++程序 (你的C++程序應該已經按照我前面說的用 extern "C" 把C的介面都括起來了),假定你的 libtest.a 放在 /home/aaa/lib下
g++ -o my.exe my.cpp -L/home/aaa/lib -ltest
就會生成可執行文件 my.exe了。
D. linux為什麼要編譯內核
Linux內核版本是不斷更新的,通常,更新的內核會支持更多的硬體,具備更好的進程管理能力,運行速度更快、 更穩定,並且一般會修復老版本中發現的許多漏洞等。而已安裝好的Linux系統如果不是滾動升級的,或者沒有內核更新選擇的話,如果用戶想要使用這些新特性,或想根據自己的硬體平台定製一個更高效,更穩定,更快速的內核,就需要重新編譯內核。
下載源碼編譯內核,如果不做相關優化,直接編譯,結果就跟現在正在使用的系統沒什麼區別。
學習linux驅動,必須要有實踐的平台環境吧,至於需不需要購置平台,要看你的學習目的了。
E. linux內核模塊,怎麼編譯
我來說下吧 本身你這個問題問的有點歧義 不知道你問的是內核編譯 還是模塊編譯 兩個不是一個東西 盡管模塊載入後 也是內核的一部分 看看其他的回答 以為是單純的內核的編譯了 模塊本身在linux下面是可以分為靜態和動態載入的 要是採用靜態載入的話 就是從新編譯內核 和內核的編譯基本是一回事 但是多採用動態載入 這個也簡單點
從你的下面的模版可以看出 你是想寫驅動程序吧 驅動一般作為動態載入的就可以了 寫好你的c文件 格式和上面的差不多 然後GCC編譯 生成.o文件,不要生成可執行文件 ( 如果是玩Embedded 就下載到目標板了 minicom 的使用) 如果是就在linux機器上 直接執行 insmod lsmod rmmod 這些就好了 這里也是簡單的說下了 內核的編譯 寫驅動程序 本身就是個比較難得事情了 要個很長的時間去學習了 慢慢積累 好運
F. linux 文件系統 內核編譯
1、第一條命令沒問題;
2、第二條命令:
#mkfs.ext2 myfs
myfs is not a block special device.
無路如何也要繼續?(y,n)
這時要輸入y
3、第三條命令,linux kernel不支持myext2文件系統。我猜你是想要在紅帽或ubuntu上mount一個ext2文件系統的loop設備,但是想使用myext2的文件系統驅動,對吧。我沒有這么做過,猜不出你的myext2摘出來之後是什麼樣子的。我以前試過在linux安裝新的文件系統支持,比如fuse系統,源碼編譯通過後會生成一個.ko的模塊文件,使用insmod命令將其加入內核,才能獲得內核對該文件系統的支持。我想你可能也應該這樣做,你應該需要生成一個類似myext2.ko的模塊,然後將其insmod到內核中去。
G. 不修改Linux內核文件,直接用makefile編譯驅動,是不是要先把內核編譯一遍
不需要重新編譯內核。需要重新製作文件系統,如果你的文件系統是nfs掛載的,那麼你只需要將
micro2440_leds.ko復制過去,然後insmod進去。