新聞中心

EEPW首頁 > 模擬技術 > 設計應用 > 基于S3C4480X的嵌入式以太網(wǎng)接口設計

基于S3C4480X的嵌入式以太網(wǎng)接口設計

作者:胡健生,夏靖波 時間:2008-05-15 來源:《電子工程師》 收藏

  0引言

本文引用地址:http://butianyuan.cn/article/82658.htm

  在互聯(lián)網(wǎng)絡和局域網(wǎng)絡飛速發(fā)展的今天,計算機進行網(wǎng)絡互聯(lián)的同時,各種家電設備、儀器儀表、工業(yè)生產(chǎn)中的數(shù)據(jù)采集和控制正在走向網(wǎng)絡化。(Ethemet)由于它的普遍性及低廉的價格,因而已經(jīng)作為一種最通用的網(wǎng)絡,廣泛應用于生產(chǎn)和生活中。另一方面,設備在價格、體積及實時性等方面是通用計算機無法比擬的,也已廣泛應用于自動化控制、數(shù)據(jù)采集、通信網(wǎng)絡等領域。因此,技術有著廣闊的前景,首先要解決的問題就是問題。

  本文基于最常用的嵌入式S3C44B0X和以太網(wǎng)RTL8019AS來設計了一款嵌入式以太網(wǎng)。本設計的特點是,既可僅用于嵌入式以太網(wǎng)驅(qū)動設備,方便簡單,又可進行擴展其他模塊,必要時可以移植操作系統(tǒng),應用于其他復雜領域。本文從RTL8019AS的內(nèi)部結(jié)構(gòu)工作原理出發(fā),介紹了基于S3C44B0X的硬件接口電路,詳細說明了基于硬件層的驅(qū)動程序C語言的設計。

  1以太網(wǎng)幀結(jié)構(gòu)

  一個標準的以太網(wǎng)物理傳輸幀由7部分組成:PR(同步位)、SD(分隔位)、DA(目的地址)、SA(源地址位)、TYPE(類型字段)、DATA(數(shù)據(jù)段)、FCS(幀校驗)。

  其傳輸幀結(jié)構(gòu)(及各部分長度)如圖1所示。

       

  除了數(shù)據(jù)段的長度不定外,其他部分的長度固定不變。數(shù)據(jù)段為46~1500字節(jié)。以太網(wǎng)規(guī)定整個傳輸包的最大長度不能超過1514字節(jié)(14字節(jié)為DA、SA、TYPE),最小不能小于60字節(jié)。需填充時,填充字符的個數(shù)不包括在長度字段中;超過1 500字節(jié)時,需拆成多個幀傳送。事實上,發(fā)送數(shù)據(jù)時,PR、SD、FCS及填充字段這幾個數(shù)據(jù)段由以太網(wǎng)控制器自動產(chǎn)生;而接收數(shù)據(jù)時,PR、SD被跳過,控制器一旦檢測到有效的前序字段(即PR、SD),就認為接收數(shù)據(jù)開始。

  2簡介

  S3C44B0X是三星公司使用ARM7TDMI核生產(chǎn)的16/32位RISC(精簡指令集計算機),它提供了豐富的內(nèi)置模塊,包括:8 kB Cache和內(nèi)部SRAM,LCD(液晶顯示器)控制器,2通道的UART,4通道的DMA(直接存儲器存取),存儲器管理,帶PWM(脈寬調(diào)制)的定時器,I/O口,8通道10位的A/D轉(zhuǎn)換器,IIC、IIS總線,同步SIO接口和PLL(鎖相環(huán))倍頻器,可根據(jù)需要進行接口擴展,并且價格低廉,目前已被廣泛應用于嵌入式領域中。

  RTL8019AS是在嵌入式領域應用廣泛且性價比很高的網(wǎng)絡控制。RTL8019AS的主要性能有:符號EthernetⅡ與IEEE 802.3(10Base5、10Base2、10BaseT)標準;全雙工,收發(fā)可同時達到10 Mbit/s的速率;內(nèi)置16 kB的SRAM,用于收發(fā)緩沖,降低對主的速度要求;支持8/16位數(shù)據(jù)總線,8個中斷申請線以及16個I/O基地址選擇;支持UTP、AUI、BNC自動檢測,還支持對10BaseT拓撲結(jié)構(gòu)的自動極性修正;允許4個診斷LED引腳可編程輸出。

  RTL8019AS可分為以下幾部分功能模塊:

  a)遠程DMA接口:處理器與RTL8019AS收發(fā)緩沖的連接通道,處理器只需對遠程DMA操作。

  b)本地DMA接口:RTL8019AS與網(wǎng)線的連接通道,完成控制器與網(wǎng)線的數(shù)據(jù)交換。

  c)MAC(介質(zhì)訪問控制)邏輯:完成對遠程DMA和本地DMA數(shù)據(jù)包傳輸、中斷的產(chǎn)生等自動控制。

  d)地址識別邏輯:將接收到的數(shù)據(jù)幀中的目的地址和地址寄存器中的地址進行比較,判斷其是否為發(fā)到本地的幀。

  e)CRC(循環(huán)冗余校驗)產(chǎn)生校驗邏輯:在發(fā)送數(shù)據(jù)時,產(chǎn)生CRC碼,對接收幀進行CRC。

  f)協(xié)議PCA:負責實施以太網(wǎng)規(guī)范。

  RTL8019AS內(nèi)部有16kB SRAM,分為64頁,256字節(jié)/頁,組成環(huán)形隊列作為收發(fā)緩沖區(qū),只能按頁操作,頁地址從0x4000~0x7FFF??梢酝ㄟ^相關的寄存器讀寫操作,可以對緩沖區(qū)進行設置及狀態(tài)的讀取。由于接收緩沖區(qū)是按頁即256 B來操作的,與緩沖區(qū)地址有關的寄存器中只需存儲緩沖區(qū)的高16位地址即可。在本設計中,將前32頁(0x400~0x5fff)作為接收緩沖區(qū),將后32頁(0x6000~0x7ff)作為發(fā)送緩沖區(qū)。

  RTL8019AS具有32位輸入輸出地址,地址偏移量為00H~1FH。其中,00H~0FH共16個地址為寄存器地址。遠程DMA地址包括10H~17H,都可以用來做遠程DMA端口,只要用其中的一個就可以了。復位端口包括18H~1FH共8個地址,功能相同,用于RTL8019AS復位。RTL8019AS的內(nèi)部I/O基址是00H,但微處理器要訪問8019的地址卻不是00H,該地址是由處理器與網(wǎng)絡控制器的連線決定的。

  RTL8019AS寄存器分為4頁,即PAGE0~PAGE3,每一頁的地址偏移量均為0x00~0x1f由RTL8019AS的CR(命令寄存器)中的PS1、PS0位來決定要訪問的頁,每一頁中的寄存器由SA0~SA3尋址。第0頁和第1頁的寄存器很重要,用于數(shù)據(jù)收發(fā)的控制和中斷管理等,使用前必須對其進行配置。第2頁和第3頁只用于診斷和其他一些配置,很少使用。

linux操作系統(tǒng)文章專題:linux操作系統(tǒng)詳解(linux不再難懂)

上一頁 1 2 下一頁

評論


相關推薦

技術專區(qū)

關閉