0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

基于Linux和EMBEST S3C4510B開發(fā)板實(shí)現(xiàn)擴(kuò)展板硬件電路設(shè)計(jì)

牽手一起夢(mèng) ? 來(lái)源:?jiǎn)纹瑱C(jī)與嵌入式系統(tǒng)應(yīng)用 ? 作者:邵仕泉,張紅雨 ? 2020-10-04 17:33 ? 次閱讀

USB設(shè)備已經(jīng)進(jìn)入我們工作、生活的方方面面,它給我們帶來(lái)了許多便利。因此,帶有USB功能已經(jīng)成為現(xiàn)在許多系統(tǒng)的一個(gè)基本要求。三星公司針對(duì)ARM7開發(fā)的S3C4510B是目前業(yè)界使用非常頻繁的一款芯片。它的強(qiáng)大功能使其成為基于諸多傳統(tǒng)的51等系列單片機(jī)開發(fā)思想的終結(jié)者。通過(guò)對(duì)它移植uClinux操作系統(tǒng),猶如為虎添翼。穩(wěn)定的Linux系統(tǒng)和強(qiáng)大的S3C4510B硬件緊密結(jié)合,形成了一個(gè)強(qiáng)大的開發(fā)平臺(tái),帶來(lái)了嶄新的開發(fā)理念。本文采用的是深圳英蓓特公司開發(fā)的EMBEST S3C4510B開發(fā)板,介紹在這樣一個(gè)強(qiáng)大的平臺(tái)上擴(kuò)展基于CYPRESS公司開發(fā)的SL811HS(HOST)的USB-HOST;展示基于這個(gè)平臺(tái)的區(qū)別于傳統(tǒng)系統(tǒng)開發(fā)的嶄新思想,同時(shí)進(jìn)一步豐富該系統(tǒng)的功能。

1 擴(kuò)展板硬件電路設(shè)計(jì)

英蓓特公司基于uClinux2.4.x+S3C4510B的開發(fā)板實(shí)現(xiàn)時(shí),把程序放在由ROMCON0控制基地址的ROM/ARAM/FLASH組0;系統(tǒng)起動(dòng)時(shí),將放在該組的程序拷貝到SDRAM0組。本文將SL811HS的地址配到ROM/ARAM/Flash組1,由ROMCON1控制它的基地址,使用外部中斷0接收SL811HS的中斷信號(hào)。由于SL811HS沒(méi)有將數(shù)據(jù)和地址總線分開,D0~D7將分時(shí)復(fù)用。這是由SL811HS的A0線控制;A0為低時(shí),D0~D7上傳輸?shù)氖堑刂?a target="_blank">信息;A0為高時(shí),D0~D7上傳輸?shù)氖菙?shù)據(jù)信息。由此,用S3C4510B的ADDR10來(lái)控制A0,從而將SL811HS的數(shù)據(jù)和內(nèi)部地址分離。USB-HOST擴(kuò)展板原理簡(jiǎn)圖如圖1所示。

2 內(nèi)核修改

要把SL811HS配置到ROMCON1控制的Bank1,主要應(yīng)用對(duì)以下兩個(gè)文件作改動(dòng)。

①…armnommusnds100.h

將Line216的

#define DSR1 (0》16)》16)《《20)

#definerROMCON1_R(ROM_NEXT1_R|ROM_BASE1_R|tACC0|tPA0|PMC0)

#define rROMCON0_B

(ROM_NEXT1_B|ROM_BASE1_tACC0|tPA0|PMC0)

這里ROM_x_R是指在系統(tǒng)復(fù)位后的值,也是系統(tǒng)在啟動(dòng)時(shí)的值。而ROM_x_B指的是系統(tǒng)在啟動(dòng)后,要將程序拷貝到SDRAM中運(yùn)行,所以原來(lái)的FLASH-BANK0就不能再使用0地址,而應(yīng)該由SDRAM0使用0地址。這個(gè)ROM_x_B就是當(dāng)程序在SDRAM中運(yùn)行時(shí)相應(yīng)Flash組的新地址。

②….s

將line 162的

ldr r1,=0x200000

改為ldr r1,=0x300000

這是告訴系統(tǒng),要將多大空間的內(nèi)容從Flash存儲(chǔ)中拷貝到SDRAM中去。

將line 259的

.word rROMCON1

改為.word rROMCON1_R

將line 272的

.word rROMCON1

改為 .word rROMCON1_B

這樣就對(duì)rROMCON1在reset和boot兩種不同模式下的配置值用不同的寄存器保存了。但是程序在運(yùn)行的時(shí)候并不由這個(gè)值決定,而由rROMCON1決定的,所以程序必須在適當(dāng)?shù)臅r(shí)候?qū)⑦@兩種模式下的其中一個(gè)值賦給rROMCON1,以供系統(tǒng)使用。

3 硬件電路檢測(cè)

經(jīng)過(guò)以上兩步,就將SL811HS配置到由rROMCON1控制的ROM/ARAM/Flash組1了,其數(shù)據(jù)端口地址為0x1200400,地址端口地址為0x1200000。中斷為外部中斷0??梢圆捎孟旅娴男〕绦騺?lái)測(cè)試能否對(duì)SL811HS的內(nèi)部寄存器進(jìn)行正確的讀寫操作。

/***filename:test811.c****/

int main(void){

unsigned char *addr,*data,I,j,x,val;

int k,m;

addr=0x1200000;

data=0x1200400;

for(i=0x10;i《0x100;i++)

{mywriteb(i,addr);

mywriteb(i,data);}

printf(“test now!”);

for(i=0x10;i《0x100;i++)

{mywriteb(i,addr);

val=myreadb(data);

if(val!=i)

printf(“error in test address %d”,i);}

}

char myreadb(int addr)

{ unsigned char *addr1;

unsigned char data;

addr1=addr;

data=*addr1;

return(data);}

void mywrited(unsigned char data,int addr)

{ unsigned char*addr1;

addr1=addr;

*addr=data;}

把該程序作為一個(gè)應(yīng)用程序,與內(nèi)核一起整體編譯。具體方法可以參考文件/documentation/adding-user-apps-howto.txt;

內(nèi)核編譯通過(guò)后,下載到開發(fā)板,然后啟動(dòng)系統(tǒng),上位機(jī)利用超級(jí)終端監(jiān)測(cè)。系統(tǒng)啟動(dòng)后,運(yùn)行該應(yīng)用程序。如果沒(méi)有錯(cuò)誤,則表明硬件連接正確了。

4 驅(qū)動(dòng)移植

USB-HOST(SL811HS)的驅(qū)動(dòng)程序不需要單獨(dú)編寫,Linux內(nèi)核中有現(xiàn)成的代碼可以借鑒,也可以到CYPRESS網(wǎng)站去下載。但是這個(gè)驅(qū)動(dòng)程序是針對(duì)sal100設(shè)計(jì)的,所以必須作相應(yīng)改動(dòng)才能在我們的S3C4510B系統(tǒng)上使用。

這里的改動(dòng)主要是對(duì)文件hc_s1811.c的修改。該文件位于…/driver/usb/

首先要修改硬件地址,因?yàn)镾L811HS的數(shù)據(jù)和地址端口地址分別為0x1200400和0x1200000。修改line 106、107的

static int base_addr=0xd3800000;

static int data_reg_addr=0xd3810000;

為 static int base_addr=0x1200000;

static int data_reg_addr=0x1200400;

修改line 130、131的

#define SL811HC_IOPORT0 0xa000000

為 #define SL811HC_IOPORT0 0x1200000

#define SL811HC_IODATAPORT0 0x120040

由于將SL811HS的中斷分配為中斷0,所以應(yīng)該修改line 108的

static int irq=34;

為 static int irq=0;

修改line 139的

#define Sl811HC_IRQ0 27

為 #define SL811HC_IRQ0 0

并且需要重新編寫函數(shù)void init_irq(void)

為void init_irq(void)

{

INT_ENABLE(irq);

IntPend=0x1FFFFF;

IntMode=INT_MODE_IRQ;

}

然后再開始內(nèi)核編譯。在內(nèi)核配置的時(shí)候,選上SL811HS項(xiàng),將編譯成功的內(nèi)核燒到板子上,然后啟動(dòng)。用上位機(jī)的超級(jí)終端監(jiān)測(cè),可以看見系統(tǒng)已經(jīng)為SL811HS分配了地址和中斷等資源。至此USB-HOST的擴(kuò)展就完成了。

結(jié)語(yǔ)

USB設(shè)備的廣泛應(yīng)用使許多系統(tǒng)都將考慮到對(duì)它的擴(kuò)展,以滿足廣大客戶的需求。本文介紹了在英蓓特公司的EMBEST3SC4510B開發(fā)板上擴(kuò)展SL811HS(host)的詳細(xì)步驟,并給出一個(gè)自編的測(cè)試程序,為硬件的檢測(cè)提供了一個(gè)簡(jiǎn)單而有力的工具,為進(jìn)一步開發(fā)移植USB設(shè)備驅(qū)動(dòng)程序提供了硬件平臺(tái)。

責(zé)任編輯:gt

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • 三星電子
    +關(guān)注

    關(guān)注

    34

    文章

    15846

    瀏覽量

    180861
  • Linux
    +關(guān)注

    關(guān)注

    87

    文章

    11210

    瀏覽量

    208721
  • 開發(fā)板
    +關(guān)注

    關(guān)注

    25

    文章

    4898

    瀏覽量

    97061
收藏 人收藏

    評(píng)論

    相關(guān)推薦

    μClinux在S3C4510B上的移植

    說(shuō)明了如何搭建移植環(huán)境,然后著重討論了在該開發(fā)板上Bootloader的設(shè)計(jì)實(shí)現(xiàn)以及t~Clinux內(nèi)核的移植方法,最后對(duì)在這種基于UClinux的嵌入式系統(tǒng)環(huán)境下如何開發(fā)應(yīng)用程序做了簡(jiǎn)單說(shuō)明。關(guān)鍵詞:嵌入式系統(tǒng);移植;UCli
    發(fā)表于 03-28 13:18

    ARM 應(yīng)用系統(tǒng)開發(fā)詳解─基于S3C4510B 的系統(tǒng)設(shè)計(jì)--ARM教程全集(good!)

    ARM 應(yīng)用系統(tǒng)開發(fā)詳解─基于S3C4510B 的系統(tǒng)設(shè)計(jì)--ARM教程全集(good!)
    發(fā)表于 04-28 11:15

    ARM 應(yīng)用系統(tǒng)開發(fā)詳解──基于S3C4510B 的系統(tǒng)設(shè)計(jì)--ARM嵌入式

    ARM 應(yīng)用系統(tǒng)開發(fā)詳解──基于S3C4510B 的系統(tǒng)設(shè)計(jì)--ARM嵌入式
    發(fā)表于 04-28 11:16

    應(yīng)用系統(tǒng)開發(fā)詳解_基于S3C4510B的系統(tǒng)設(shè)計(jì)

    應(yīng)用系統(tǒng)開發(fā)詳解_基于S3C4510B的系統(tǒng)設(shè)計(jì) 好資料,與你供享。只供學(xué)習(xí)!
    發(fā)表于 03-25 15:50 ?40次下載

    基于S3C4510B的應(yīng)用系統(tǒng)設(shè)計(jì)與調(diào)試

    主要介紹基于S3C4510B硬件系統(tǒng)的詳細(xì)設(shè)計(jì)步驟、實(shí)現(xiàn)細(xì)節(jié)、硬件系統(tǒng)的調(diào)試方法等,通過(guò)對(duì)本章的閱讀,可以使絕大多數(shù)的讀者具有根據(jù)自身的需求、設(shè)計(jì)特定應(yīng)用系統(tǒng)的能力。
    發(fā)表于 09-09 14:56 ?0次下載

    s3c4510b pdf datasheet (16/32-

    s3c4510b p
    發(fā)表于 10-14 10:43 ?36次下載

    s3c4510b中文手冊(cè),s3c4510b用戶手冊(cè)

    s3c4510b中文手冊(cè),s3c4510b用戶手冊(cè):ARM(Advanced RISC Machines),既可以認(rèn)為是一個(gè)公司的名字,也可以認(rèn)為是對(duì)一類微處理器的通稱,還可以認(rèn)為是一種技術(shù)的名字。1991年ARM公司成立
    發(fā)表于 10-14 10:54 ?421次下載

    基于uCLinux和S3C4510B的網(wǎng)絡(luò)通信設(shè)計(jì)

    基于uCLinux和S3C4510B的網(wǎng)絡(luò)通信設(shè)計(jì)
    發(fā)表于 03-28 09:49 ?17次下載

    μClinux在S3C4510B上的移植

    Linux是一種支持多種體系結(jié)構(gòu)處理器的操作系統(tǒng).有很強(qiáng)的移植性。描述了將UClinux移植到基于S3C4510B處理器目標(biāo)板上的方法與過(guò)程。首先介紹了S3C4510B處理器和UClinux,并簡(jiǎn)單說(shuō)明了如
    發(fā)表于 03-28 09:51 ?16次下載

    S3C4510B系統(tǒng)中對(duì)觸摸屏控制的研究與實(shí)現(xiàn)

    S3C4510B系統(tǒng)中對(duì)觸摸屏控制的研究與實(shí)現(xiàn)
    發(fā)表于 03-28 09:51 ?17次下載

    基于S3C4510B的系統(tǒng)設(shè)計(jì)

    基于S3C4510B的系統(tǒng)設(shè)計(jì)   arm開發(fā)詳解全集 1991 年ARM 公司成立于英
    發(fā)表于 02-09 14:22 ?845次閱讀

    S3C4510B開發(fā)板(含原理圖和PCB)資料下載

    S3C4510B開發(fā)板(原理圖和PCB)
    發(fā)表于 01-19 10:22 ?28次下載

    關(guān)于ARM7 S3C4510B上μClinux移植問(wèn)題

    分享到 μClinux 移植到基于 S3C4510B 處理器目標(biāo)板上的方法與過(guò)程。首先介紹了S3C4510B處理器和μClinux,并簡(jiǎn)單說(shuō)明了如何搭建移植環(huán)境,然后著重討論了在該開發(fā)板
    發(fā)表于 04-10 11:17 ?2377次閱讀
    關(guān)于ARM7 <b class='flag-5'>S3C4510B</b>上μClinux移植問(wèn)題

    基于ARM的S3C4510B開發(fā)板原理圖下載

    基于ARM的S3C4510B開發(fā)板原理圖下載
    發(fā)表于 04-26 11:17 ?4次下載

    ARM應(yīng)用系統(tǒng)開發(fā)詳解——基于S3C4510B的系統(tǒng)設(shè)計(jì)

    電子發(fā)燒友網(wǎng)站提供《ARM應(yīng)用系統(tǒng)開發(fā)詳解——基于S3C4510B的系統(tǒng)設(shè)計(jì).rar》資料免費(fèi)下載
    發(fā)表于 11-08 15:35 ?0次下載
    ARM應(yīng)用系統(tǒng)<b class='flag-5'>開發(fā)</b>詳解——基于<b class='flag-5'>S3C4510B</b>的系統(tǒng)設(shè)計(jì)