當(dāng)前位置:首頁(yè) > 單片機(jī) > 單片機(jī)
[導(dǎo)讀]1. 配置內(nèi)核首先,修改arch/arm/plat-s3c24xx/Kconfig,這一步的目的是為了可以在內(nèi)核中使能SPI0的配置函數(shù)。修改后的內(nèi)容如下:config S3C24XX_SPI_BUS0_GPE11_GPE12_GPE13 bool " S3C24XX_SPI_BUS0_GPE11_GPE12_GP

1. 配置內(nèi)核

首先,修改arch/arm/plat-s3c24xx/Kconfig,這一步的目的是為了可以在內(nèi)核中使能SPI0的配置函數(shù)。

修改后的內(nèi)容如下:

config S3C24XX_SPI_BUS0_GPE11_GPE12_GPE13
bool " S3C24XX_SPI_BUS0_GPE11_GPE12_GPE13"
help
SPI GPIO configuration code for BUS0 when connected to
GPE11, GPE12 and GPE13.

接著配置內(nèi)核,首先打開(kāi)S3C24XX_SPI_BUS0_GPE11_GPE12_GPE13選項(xiàng),這樣編譯的時(shí)候會(huì)將

arch/arm/plat-s3c24xx/spi-bus0-gpe11_12_13.c一起進(jìn)行編譯。

該源文件中的函數(shù)void s3c24xx_spi_gpiocfg_bus0_gpe11_12_13(struct s3c2410_spi_info *spi, int enable)將用于配置spi控制器0的管腳。



接著,使能SPI功能,這里打開(kāi)2440的SPI控制器驅(qū)動(dòng)和通用的protocol驅(qū)動(dòng)spidev。


2. 修改源碼

修改arch/arm/mach-s3c2440/mach-smdk2440.c

增加內(nèi)容:

#include

#include

static struct s3c2410_spi_info s3c2410_spi0_platdata={

.pin_cs = S3C2410_GPG(2),

.num_cs = 1,

.bus_num = 0,

.gpio_setup =s3c24xx_spi_gpiocfg_bus0_gpe11_12_13,

};

static struct spi_board_info s3c2410_spi0_board[]={

[0] = {

.modalias = “spidev”,

.bus_num = 0,

.chip_select = 0,

.max_speed_hz = 500 * 1000,

},

};

在smdk2440_devices[]中增加

&s3c_device_spi0,

在smdk2440_mach_init函數(shù)中增加

s3c_device_spi0.dev.platform_data = &s3c2410_spi0_platdata;

spi_register_board_info(s3c2410_spi0_board,ARRAY_SIZE(s3c2410_spi0_board));

修改完畢以后,重新編譯內(nèi)核,并下載內(nèi)核。查看下設(shè)備節(jié)點(diǎn):

[root@yj423 /dev]#ls /dev/spidev0.0
/dev/spidev0.0


3.測(cè)試

用杜邦線將MOSI和MISO管腳相連。

在內(nèi)核源碼中提供了SPI測(cè)試程序。源碼位于Documentation/spi/spidev_test.c,編譯之后,下到開(kāi)發(fā)板并執(zhí)行。

[root@yj423 yj423]#./spidev_test -D /dev/spidev0.0
spi mode: 0
bits per word: 8
max speed: 500000 Hz (500 KHz)

FF FF FF FF FF FF
40 00 00 00 00 95
FF FF FF FF FF FF
FF FF FF FF FF FF
FF FF FF FF FF FF
DE AD BE EF BA AD
F0 0D
NOTE:如果你只是為了移植而移植,那么后面的內(nèi)容就不要看了。想知道WHY,那請(qǐng)繼續(xù)往下看。


4.原理

首先,在第二小結(jié)中我們看到定義了兩個(gè)數(shù)據(jù)結(jié)構(gòu),之所以要定義那是因?yàn)轵?qū)動(dòng)程序需要用到,詳見(jiàn)

基于S3C2440的嵌入式Linux驅(qū)動(dòng)——SPI子系統(tǒng)解讀(二)

需要這兩個(gè)數(shù)據(jù)結(jié)構(gòu)的地方,均用紅色字體說(shuō)明了。

數(shù)據(jù)s3c2410_spi0_platdata是作為平臺(tái)的私有數(shù)據(jù),因此使用了s3c_device_spi0.dev.platform_data = &s3c2410_spi0_platdata來(lái)添加該數(shù)據(jù)。

而s3c2410_spi0_board必須通過(guò)函數(shù)spi_register_board_info添加到內(nèi)核中,

最重要的一個(gè)問(wèn)題,這些數(shù)據(jù)結(jié)構(gòu)的值是怎么給出的?

先來(lái)看看這兩個(gè)數(shù)據(jù)結(jié)構(gòu):


structspi_board_info{

/*thedevicenameandmodulenamearecoupled,likeplatform_bus;

*"modalias"isnormallythedrivername.

*

*platform_datagoestospi_device.dev.platform_data,

*controller_datagoestospi_device.controller_data,

*irqiscopiedtoo

*/

charmodalias[32];

constvoid*platform_data;

void*controller_data;

intirq;

/*slowersignalingonnoisyorlowvoltageboards*/

u32max_speed_hz;

/*bus_numisboardspecificandmatchesthebus_numofsome

*spi_masterthatwillprobablyberegisteredlater.

*

*chip_selectreflectshowthischipiswiredtothatmaster;

*it'slessthannum_chipselect.

*/

u16bus_num;

u16chip_select;

/*modebecomesspi_device.mode,andisessentialforchips

*wherethedefaultofSPI_CS_HIGH=0iswrong.

*/

u8mode;

/*...mayneedadditionalspi_devicechipconfigdatahere.

*avoidstuffprotocoldriverscanset;butincludestuff

*neededtobehavewithoutbeingboundtoadriver:

*-quirkslikeclockratematteringwhennotselected

*/

};

structs3c2410_spi_info{

intpin_cs;/*simplegpiocs*/

unsignedintnum_cs;/*totalchipselects*/

intbus_num;/*busnumbertouse.*/

void(*gpio_setup)(structs3c2410_spi_info*spi,intenable);

void(*set_cs)(structs3c2410_spi_info*spi,intcs,intpol);

};

4.1 s3c2410_spi_info


pin_cs:表示哪個(gè)管腳用輸出片選信號(hào),這里使用GPG2管腳,具體的管腳請(qǐng)參看你的datasheet。

bus_num:表示總線接口。這里使用0,表示使用SPI0控制器。S3C2440有兩個(gè)SPI控制器,分別為SPI0和SPI1。

num_cs:表示該SPI控制器控制幾個(gè)SPI從設(shè)備,這里為1,僅有一個(gè)設(shè)備。

s3c2410_spi_info作為平臺(tái)數(shù)據(jù),在s3c24xx_spi_probe函數(shù)中,bus_cs和bus_num將被復(fù)制給master中的相應(yīng)字段。也就是說(shuō),該master為SPI0控制器,有1個(gè)從設(shè)備。

而pin_cs將由函數(shù)s3c24xx_spi_gpiocs使用,該函數(shù)使能片選信號(hào)。


staticvoids3c24xx_spi_gpiocs(structs3c2410_spi_info*spi,intcs,intpol)

{

gpio_set_value(spi->pin_cs,pol);

}

gpio_setup: 這里設(shè)置為函數(shù)s3c24xx_spi_gpiocfg_bus0_gpe11_12_13, 該函數(shù)用于初始化SPI控制器的管腳。

該函數(shù)將在主控制驅(qū)動(dòng)的s3c24xx_spi_initialsetup函數(shù)中被調(diào)用:



4.2spi_board_info

首先,我們知道spi_board_info作為SPI設(shè)備的板級(jí)信息,在spi_new_device函數(shù)中將該板級(jí)信息全部復(fù)制給spi_device。

modalias:將用于綁定驅(qū)動(dòng)和設(shè)備。我們看下match方法:


staticintspi_match_device(structdevice*dev,structdevice_driver*drv)

{

conststructspi_device*spi=to_spi_device(dev);

returnstrcmp(spi->modalias,drv->name)==0;

}

而drv->name為在spi_driver中定義,如下



staticstructspi_driverspidev_spi={

.driver={

.name="spidev",

.owner=THIS_MODULE,

},

.probe=spidev_probe,

.remove=__devexit_p(spidev_remove),

/*NOTE:suspend/resumemethodsarenotnecessaryhere.

* We don't do anything except pass the

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請(qǐng)聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請(qǐng)及時(shí)聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車(chē)的華為或?qū)⒋呱龈蟮莫?dú)角獸公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

倫敦2024年8月29日 /美通社/ -- 英國(guó)汽車(chē)技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車(chē)工程師從創(chuàng)意到認(rèn)證的所有需求的工具,可用于創(chuàng)建軟件定義汽車(chē)。 SODA V工具的開(kāi)發(fā)耗時(shí)1.5...

關(guān)鍵字: 汽車(chē) 人工智能 智能驅(qū)動(dòng) BSP

北京2024年8月28日 /美通社/ -- 越來(lái)越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運(yùn)行,同時(shí)企業(yè)卻面臨越來(lái)越多業(yè)務(wù)中斷的風(fēng)險(xiǎn),如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報(bào)道,騰訊和網(wǎng)易近期正在縮減他們對(duì)日本游戲市場(chǎng)的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國(guó)國(guó)際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)開(kāi)幕式在貴陽(yáng)舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國(guó)國(guó)際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語(yǔ)權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機(jī) 衛(wèi)星通信

要點(diǎn): 有效應(yīng)對(duì)環(huán)境變化,經(jīng)營(yíng)業(yè)績(jī)穩(wěn)中有升 落實(shí)提質(zhì)增效舉措,毛利潤(rùn)率延續(xù)升勢(shì) 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長(zhǎng) 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競(jìng)爭(zhēng)力 堅(jiān)持高質(zhì)量發(fā)展策略,塑強(qiáng)核心競(jìng)爭(zhēng)優(yōu)勢(shì)...

關(guān)鍵字: 通信 BSP 電信運(yùn)營(yíng)商 數(shù)字經(jīng)濟(jì)

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺(tái)與中國(guó)電影電視技術(shù)學(xué)會(huì)聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會(huì)上宣布正式成立。 活動(dòng)現(xiàn)場(chǎng) NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長(zhǎng)三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會(huì)上,軟通動(dòng)力信息技術(shù)(集團(tuán))股份有限公司(以下簡(jiǎn)稱"軟通動(dòng)力")與長(zhǎng)三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉