Mini2440 NRF24L01无线模块驱动

发布者:科技驿站最新更新时间:2016-06-13 来源: eefocus关键字:Mini2440  NRF24L01  无线模块驱动 手机看文章 扫描二维码
随时随地手机看文章
为了和jihuaLi 完成智能家居系统,我移植了这个驱动,不管写的如何,总结一下是很有必要的。

NRF24L01使用SPI总线与主机通信,没有SPI端口的设备可以使用IO口进行模拟。

关于SPI: Mini2440 NRF24L01无线模块驱动(我只是个搬运工)
 SPI是一种四线串行总线,
SCLK: 串行时钟线
MOSI: 总线主机输出/ 从机输入
MISO: 总线主机输入/ 从机输出;
SS: 从机使能 数据传输方式 Mini2440 NRF24L01无线模块驱动(我只是个搬运工)
 通讯是通过数据交换完成的,这里先要知道SPI是串行通讯协议,也就是说数据是一位一位的传输的。这就是SCLK时钟线存在的原因,由SCK提供时钟脉冲,SDI,SDO则基于此脉冲完成数据传输。数据输出通过 SDO线,数据在时钟上升沿或下降沿时改变,在紧接着的下降沿或上升沿被读取。完成一位数据传输,输入也使用同样原理。这样,在至少8次时钟信号的改变(上沿和下沿为一次),就可以完成8位数据的传输。

NRF24L01寄存器说明:
还是看说明书吧,dbank 驱动源码在下一页。 驱动源码:

#include 
#include 
#include 
#include 
#include 
#include 

 

#include #include #include #include #include #include #include #include #include #include

typedef unsigned int uint16;
typedef unsigned char uint8;

/* 引脚相关定义 */
#define CSN S3C2410_GPF(4)
#define CSN_OUTP S3C2410_GPIO_OUTPUT
#define MOSI S3C2410_GPG(0)
#define MOSI_OUTP S3C2410_GPIO_OUTPUT
#define IRQ S3C2410_GPG(1)
#define IRQ_INP S3C2410_GPIO_INPUT
#define MISO S3C2410_GPG(6)
#define MISO_INP S3C2410_GPIO_INPUT
#define SCK S3C2410_GPG(7)
#define SCK_OUTP S3C2410_GPIO_OUTPUT
#define CE S3C2410_GPG(11)
#define CE_OUTP S3C2410_GPIO_OUTPUT

#define DEVICE_NAME “NRF24L01”

#define TxBufSize 32

uint8 TxBuf[TxBufSize] = {
0x01, 0x02, 0x03, 0x4, 0x05, 0x06, 0x07, 0x08,
0x09, 0x10, 0x11, 0x12, 0x13, 0x14, 0x15, 0x16,
0x17, 0x18, 0x19, 0x20, 0x21, 0x22, 0x23, 0x24,
0x25, 0x26, 0x27, 0x28, 0x29, 0x30, 0x31, 0x32,
};

//NRF24L01端口定义

#define CE_OUT s3c2410_gpio_cfgpin(CE, CE_OUTP) //数据线设置为输出

#define CE_UP s3c2410_gpio_pullup(CE, 1) //打开上拉电阻

#define CE_L s3c2410_gpio_setpin(CE, 0) //拉低数据线电平

#define CE_H s3c2410_gpio_setpin(CE, 1) //拉高数据线电平

#define SCK_OUT s3c2410_gpio_cfgpin(SCK, SCK_OUTP) //数据线设置为输出

#define SCK_H s3c2410_gpio_setpin(SCK, 1) //拉高数据线电平

#define SCK_L s3c2410_gpio_setpin(SCK, 0) //拉高数据线电平

#define MISO_IN s3c2410_gpio_cfgpin(MISO, MISO_INP) //数据线设置为输出

#define MISO_UP s3c2410_gpio_pullup(MISO, 1) //打开上拉电阻

#define MISO_STU s3c2410_gpio_getpin(MISO) //数据状态

#define IRQ_IN s3c2410_gpio_cfgpin(IRQ, IRQ_INP) //数据线设置为输出

#define IRQ_UP s3c2410_gpio_pullup(IRQ, 1) //打开上拉电阻

#define IRQ_L s3c2410_gpio_setpin(IRQ, 0) //拉低数据线电平

#define IRQ_H s3c2410_gpio_setpin(IRQ, 1) //拉高数据线电平

#define MOSI_OUT s3c2410_gpio_cfgpin(MOSI, MOSI_OUTP) //数据线设置为输出

#define MOSI_UP s3c2410_gpio_pullup(MOSI, 1) //打开上拉电阻

#define MOSI_L s3c2410_gpio_setpin(MOSI, 0) //拉低数据线电平

#define MOSI_H s3c2410_gpio_setpin(MOSI, 1) //拉高数据线电平

#define CSN_OUT s3c2410_gpio_cfgpin(CSN, CSN_OUTP) //数据线设置为输出

#define CSN_UP s3c2410_gpio_pullup(CSN, 1) //打开上拉电阻

#define CSN_L s3c2410_gpio_setpin(CSN, 0) //拉低数据线电平

#define CSN_H s3c2410_gpio_setpin(CSN, 1) //拉高数据线电平

//NRF24L01

#define TX_ADR_WIDTH 5 // 5 uint8s TX address width

#define RX_ADR_WIDTH 5 // 5 uint8s RX address width

#define TX_PLOAD_WIDTH 32 // 20 uint8s TX payload

#define RX_PLOAD_WIDTH 32 // 20 uint8s TX payload

uint8 TX_ADDRESS[TX_ADR_WIDTH] = { 0x34, 0x43, 0x10, 0x10, 0x01 }; //本地地址

uint8 RX_ADDRESS[RX_ADR_WIDTH] = { 0x34, 0x43, 0x10, 0x10, 0x01 }; //接收地址

//NRF24L01寄存器指令

#define READ_REG 0x00 // 读寄存器指令

#define WRITE_REG 0x20 // 写寄存器指令

#define RD_RX_PLOAD 0x61 // 读取接收数据指令

#define WR_TX_PLOAD 0xA0 // 写待发数据指令

#define FLUSH_TX 0xE1 // 冲洗发送 FIFO指令

#define FLUSH_RX 0xE2 // 冲洗接收 FIFO指令

#define REUSE_TX_PL 0xE3 // 定义重复装载数据指令

#define NOP 0xFF // 保留

//SPI(nRF24L01)寄存器地址

#define CONFIG 0x00 // 配置收发状态,CRC校验模式以及收发状态响应方式

#define EN_AA 0x01 // 自动应答功能设置

#define EN_RXADDR 0x02 // 可用信道设置

#define SETUP_AW 0x03 // 收发地址宽度设置

#define SETUP_RETR 0x04 // 自动重发功能设置

#define RF_CH 0x05 // 工作频率设置

#define RF_SETUP 0x06 // 发射速率、功耗功能设置

#define STATUS 0x07 // 状态寄存器

#define OBSERVE_TX 0x08 // 发送监测功能

#define CD 0x09 // 地址检测

#define RX_ADDR_P0 0x0A // 频道0接收数据地址

#define RX_ADDR_P1 0x0B // 频道1接收数据地址

#define RX_ADDR_P2 0x0C // 频道2接收数据地址

#define RX_ADDR_P3 0x0D // 频道3接收数据地址

#define RX_ADDR_P4 0x0E // 频道4接收数据地址

#define RX_ADDR_P5 0x0F // 频道5接收数据地址

#define TX_ADDR 0x10 // 发送地址寄存器

#define RX_PW_P0 0x11 // 接收频道0接收数据长度

#define RX_PW_P1 0x12 // 接收频道0接收数据长度

#define RX_PW_P2 0x13 // 接收频道0接收数据长度

#define RX_PW_P3 0x14 // 接收频道0接收数据长度

#define RX_PW_P4 0x15 // 接收频道0接收数据长度

#define RX_PW_P5 0x16 // 接收频道0接收数据长度

#define FIFO_STATUS 0x17 // FIFO栈入栈出状态寄存器设置

/* 打开计数 */
uint open_count = 0;

/* 状态标识 */
uint8 receive_state;

int get_data=0;

wait_queue_head_t read_queue; //读取等待队列

#define RX_DR 6
#define TX_DS 5
#define MAX_RT 4

/* unit8 SPI_RW(uint8 tmp)
* SPI写时序,写一个字节到MOSI同时从MISO中读取一个字节 */
uint8 SPI_RW(uint8 tmp)
{ uint8 bit_ctl;

for (bit_ctl = 0; bit_ctl < 8;bit_ctl++){
if(tmp & 0x80)
MOSI_H;
else 
MOSI_L;

tmp = tmp << 1; //Shift next bit into MSB

SCK_H; //Set SCK high

ndelay(60);

tmp |= MISO_STU; //Capture current MISO bit

SCK_L;

ndelay(60);
}
return tmp;
}

/*
* 函数:uint8 SPI_Read(uint8 reg)
* 功能:NRF24L01的SPI时序
*/
uint8 SPI_Read(uint8 reg)
{ uint8 reg_val;

CSN_L; // CSN low, initialize SPI communication…

ndelay(60);
SPI_RW(reg); // Select register to read from..

reg_val = SPI_RW(0); // ..then read registervalue

CSN_H; // CSN high, terminate SPI communication

ndelay(60);

return (reg_val); // return register value

}

//功能:NRF24L01读写寄存器函数

uint8 SPI_RW_Reg(uint8 reg, uint8 value)
{ uint8 status;

CSN_L; // CSN low, init SPI transaction

ndelay(60);

status = SPI_RW(reg); // select register

SPI_RW(value); // ..and write value to it..

CSN_H; // CSN high again

ndelay(60);

return (status); // return nRF24L01 status uint8

}

//函数:uint8 SPI_Read_Buf(uint8 reg, uint8 *pBuf, uint8 uchars)

//功能: 用于读数据,reg:为寄存器地址,pBuf:为待读出数据地址,uchars:读出数据的个数

uint8 SPI_Read_Buf(uint8 reg, uint8 * pBuf, uint8 uchars)
{ uint8 status, uint8_ctr;

CSN_L; // Set CSN low, init SPI tranaction

ndelay(60);
status = SPI_RW(reg); // Select register to write to and read status uint8

for (uint8_ctr = 0; uint8_ctr < uchars; uint8_ctr++) {
pBuf[uint8_ctr] = SPI_RW(0); //

ndelay(20);
}

CSN_H;
ndelay(60);

return (status); // return nRF24L01 status uint8

}

//函数:uint8 SPI_Write_Buf(uint8 reg, uint8 *pBuf, uint8 uchars)

//功能: 用于写数据:为寄存器地址,pBuf:为待写入数据地址,uchars:写入数据的个数

uint8 SPI_Write_Buf(uint8 reg, uint8 * pBuf, uint8 uchars)
{ uint8 status, uint8_ctr;

CSN_L; //SPI使能

ndelay(60);
status = SPI_RW(reg);
for (uint8_ctr = 0; uint8_ctr < uchars; uint8_ctr++) //
{
SPI_RW(*pBuf++);
ndelay(20);
}
CSN_H; //关闭SPI

ndelay(60);
return (status); // 
}

//函数:void SetRX_Mode(void)

//功能:数据接收配置

void SetRX_Mode(void)
{

CE_L;
ndelay(60);
// SPI_RW_Reg(WRITE_REG + CONFIG, 0x0f); // IRQ收发完成中断响应,16位CRC ,主接收

//udelay(1);

CE_H;
udelay(130);
}

//函数:unsigned char nRF24L01_RxPacket(unsigned char* rx_buf)

//功能:数据读取后放如rx_buf接收缓冲区中

unsigned char nRF24L01_RxPacket(unsigned char *rx_buf)
{ unsigned char revale = 0;

receive_state = SPI_Read(STATUS); // 读取状态寄存其来判断数据接收状况

if (receive_state & (1 << RX_DR)) // 判断是否接收到数据

{
CE_L; //SPI使能

udelay(50);
SPI_Read_Buf(RD_RX_PLOAD, rx_buf, TX_PLOAD_WIDTH); // read receive payload from RX_FIFO buffer

revale = 1; //读取数据完成标志

}
SPI_RW_Reg(WRITE_REG + STATUS, receive_state); //接收到数据后RX_DR,TX_DS,MAX_PT都置高为1,通过写1来清楚中断标志

return revale;
}

//函数:void nRF24L01_TxPacket(unsigned char * tx_buf)

//功能:发送 tx_buf中数据

void nRF24L01_TxPacket(unsigned char *tx_buf)
{ uint8 ret;
CE_L; //StandBy I模式

ndelay(60);
ret=SPI_Write_Buf(WRITE_REG + RX_ADDR_P0, TX_ADDRESS, TX_ADR_WIDTH); // 装载接收端地址
printk(“ret=%cn”,ret);
ret=SPI_Write_Buf(WR_TX_PLOAD, tx_buf, TX_PLOAD_WIDTH); // 装载数据 
printk(“ret=%cn”,ret);

SPI_RW_Reg(WRITE_REG + CONFIG, 0x0e); // IRQ收发完成中断响应,16位CRC,主发送

CE_H; //置高CE,激发数据发送

udelay(10);
}

static irqreturn_t nrf24l01_interrupt(int irq,void *dev_id)
{ uint8 state ;
state = SPI_Read(STATUS);
if(state & 0x10){
SPI_RW_Reg(WRITE_REG + STATUS , state); //如果是重发中断则写回清除中断
}else if(state & 0x20){
SPI_RW_Reg(WRITE_REG + STATUS , state); //清除发送中断
}else if ( state & 0x40){
get_data = 1;
nRF24L01_RxPacket(TxBuf);
wake_up_interruptible(&read_queue);
}
return IRQ_RETVAL(IRQ_HANDLED);
}

uint8 init_NRF24L01(void)
{ MISO_UP;

CE_OUT;
CSN_OUT;
SCK_OUT;
MOSI_OUT;
MISO_IN;
IRQ_IN;

udelay(500);
CE_L; // chip enable

ndelay(60);
CSN_H; // Spi disable

ndelay(60);
SCK_L; // Spi clock line init high

ndelay(60);
SPI_Write_Buf(WRITE_REG + TX_ADDR, TX_ADDRESS, TX_ADR_WIDTH); // 写本地地址

SPI_Write_Buf(WRITE_REG + RX_ADDR_P0, RX_ADDRESS, RX_ADR_WIDTH); // 写接收端地址

SPI_RW_Reg(WRITE_REG + EN_AA, 0x01); // 频道0自动 ACK应答允许

SPI_RW_Reg(WRITE_REG + EN_RXADDR, 0x01); // 允许接收地址只有频道0,如果需要多频道可以参考Page21

SPI_RW_Reg(WRITE_REG + RF_CH, 0); // 设置信道工作为2.4GHZ,收发必须一致

SPI_RW_Reg(WRITE_REG + RX_PW_P0, RX_PLOAD_WIDTH); //设置接收数据长度,本次设置为32字节

SPI_RW_Reg(WRITE_REG + RF_SETUP, 0x07); //设置发射速率为1MHZ,发射功率为最大值0dB

SPI_RW_Reg(WRITE_REG + CONFIG, 0x0f); // IRQ收发完成中断响应,16位CRC ,主接收
mdelay(1000);
nRF24L01_TxPacket(TxBuf);
SPI_RW_Reg(WRITE_REG + STATUS, 0XFF);
printk(“test 1 n”);
mdelay(1000);
return 1;
}

static uint16 nrf24l01_poll(struct file *filp,struct poll_table_struct *wait)
{ uint16 mask = 0;
poll_wait(filp,&read_queue,wait);
if(get_data){
mask |= POLLIN|POLLRDNORM;
}

return mask;
} static ssize_t nrf24l01_write(struct file *filp,const char *buffer, size_t count,loff_t *ppos)
{ if(copy_from_user(TxBuf,buffer,count))
{
printk(“Can’t Send Data !”);
return -EFAULT;
}

nRF24L01_TxPacket(TxBuf);
SPI_RW_Reg(WRITE_REG + STATUS,0XFF);
printk(“Send OK n”);
return 10;
}

static ssize_t nrf24l01_read(struct file * filp,char *buffer,size_t count,loff_t *ppos)
{ unsigned long err;
if(!get_data){
if(filp->f_flags & O_NONBLOCK)
return -EAGAIN;
else 
wait_event_interruptible(read_queue,get_data);
}
get_data = 0;
err = copy_to_user(buffer,TxBuf,min(TxBufSize,count));

printk(“read okn”);
return err ? -EFAULT : min(TxBufSize,count);
}

static int nrf24l01_open(struct inode *node, struct file *file)
{ uint8 flag = 0;
unsigned long err;
if (open_count == 1)
return -EBUSY;

flag = init_NRF24L01();

mdelay(100);
init_waitqueue_head(&read_queue);

err = request_irq(IRQ_EINT9,nrf24l01_interrupt,IRQ_TYPE_EDGE_FALLING,DEVICE_NAME,NULL);
if(err){
disable_irq(IRQ_EINT9);
free_irq(IRQ_EINT9,NULL);
}
if (flag == 0) {
printk(“uable to open device!n”);
return -1;
} else {
open_count++;
printk(“device opened !n”);
return 0;
}
}

static int nrf24l01_release(struct inode *node, struct file *file)
{ free_irq(IRQ_EINT9,NULL);
open_count–;
printk(DEVICE_NAME ” released !n”);
return 0;
}

static struct file_operations nrf24l01_fops = {
.owner = THIS_MODULE,
.open = nrf24l01_open,
.write = nrf24l01_write,
.poll = nrf24l01_poll,
.read = nrf24l01_read,
.release = nrf24l01_release,
};

static struct miscdevice nrf24l01_dev = {
.minor = MISC_DYNAMIC_MINOR,
.name = DEVICE_NAME,
.fops = &nrf24l01_fops,
};

static int __init nrf24l01_init(void)
{ int ret;

printk(“Initial driver for NRF24L01.n”);
ret = misc_register(&nrf24l01_dev);
mdelay(10);
if (ret < 0) {
printk(DEVICE_NAME ” can’t register major numbern”);
return ret;

} else {
printk(DEVICE_NAME ” register successn”);
return 0;
}
}

static void __exit nrf24l01_exit(void)
{ misc_deregister(&nrf24l01_dev);
printk(“NRF24L01 unregister success n”);
}

module_init(nrf24l01_init);
module_exit(nrf24l01_exit);
MODULE_AUTHOR(“Issac”);
MODULE_DESCRIPTION(“NRF24L01 Driver”);
MODULE_LICENSE(“GPL”); 备注: 不同管脚的定义可以自行修改。
我添加了poll方法 和接收中断的处理
由于MSP的程序没有调好,这个驱动还没有进行测试。 在内核中部署驱动:
将nrf24l01.c文件到源码下driver/misc/ 目录下
修改该目录下的Kconfig文件
在合适位置添加

config NRF24L01
	tristate "NRF24L01 Single Chip 2.4 GHz Radio Transceiver"
	help
		Driver for NRF24L01

 

修改Makefile添加

obj-$(CONFIG_NRF24L01)		+= nrf24l01.o
然后make menuconfig 
选上NRF24L01 驱动即可

 

测试程序: 仅测试了发送

#include 

 

#include

#include

#include

#include

#include

#include

#include

#include

#include

unsigned char TxBuf[32] = {
0x01, 0x02, 0x03, 0x4, 0x05, 0x06, 0x07, 0x08,
0x09, 0x10, 0x11, 0x12, 0x13, 0x14, 0x15, 0x16,
0x17, 0x18, 0x19, 0x20, 0x21, 0x22, 0x23, 0x24,
0x25, 0x26, 0x27, 0x28, 0x29, 0x30, 0x31, 0x32,
};
int main(void)

{

int fd = -1;
int ret;
int count = 1;

fd = open(“/dev/NRF24L01”, O_RDWR);

if(fd < 0)

{

perror(“Can’t open /dev/nrf24l01 n”);

exit(1);

}

printf(“open /dev/nrf24l01 success n”);

while(count <= 5)
{

ret = write(fd, TxBuf , sizeof(TxBuf));

char *mesg = strerror(errno);

printf(“Sending %d time %d n”, count,ret);
printf(“Errno:%dn,Mesg:%sn”,errno,mesg);
usleep(100*1000);

count++;
}

close(fd);
}

关键字:Mini2440  NRF24L01  无线模块驱动 引用地址:Mini2440 NRF24L01无线模块驱动

上一篇:S3C2440通过v4l2采集在lcd上显示
下一篇:STM32 DMA 串口透传

推荐阅读最新更新时间:2024-03-16 14:56

驱动开发之 DM9000 (for mini2440
内核版本:linux-2.6.32.2 实验平台:mini2440 1. 添加平台设备支持 首先需要在mach-mini2440.c中包含头文件 linux/dm9000.h ,dm9000平台设备定义如下: /* DM9000AEP 10/100 ethernet controller */ #define MACH_MINI2440_DM9000_BASE (S3C2410_CS4 + 0x300) static struct resource mini2440_dm9000_resource = { = { .start = MACH_MINI2440_DM9000_BASE, .end = MAC
[单片机]
<font color='red'>驱动</font>开发之 DM9000 (for <font color='red'>mini2440</font>)
友善之臂Mini2440之嵌入式Linux下Nand Flash驱动分析
一、Nand Flash驱动源码文件含义 在Linux内核中,MTD源代码放在/driver/mtd目录下,该目录中包含chips、devices、maps、nand、onenand和ubi六个子目录。其中只有nand和onenand目录中的代码才与Nand驱动有关,nand目录中的代码比较通用,而onenand目录中的代码相对于nand中的代码而言简化了许多,是三星公司开发的另类nand Flash。市场占有率不是很高。所以,开发基于MTD的nand驱动程序,基本上只需要关注nand目录了,包括Kconfig、Makefile以及如下重要文件: 1、nand_base.c 定义了Nand驱动中对nand芯片最基本的操
[单片机]
mini2440 简单的dma工作原理实验
以驱动方式测试dma的工作原理,用户层程序不停调用ioctl触发驱动里面完成的dma操作,把内存的数据块从一个连续地址搬到另一个连续地址,然后用memcmp测试搬移后的数据和搬移前是不是完全一样。 简单的驱动代码: #include linux/module.h #include linux/kernel.h #include linux/device.h #include linux/fs.h #include linux/mm.h #include linux/init.h #include linux/delay.h #include linux/interrupt.h #include linux/
[单片机]
<font color='red'>mini2440</font> 简单的dma工作原理实验
mini2440裸机试炼之IIS——音乐播放器
IIS 信号频率设置 IIS(Inter-IC Sound)由飞利浦公司开发,是一种常用的音频设备接口,主要用于CD、MD、MP3等设备。 s3c2440一共有5个引脚用于IIS:IISDO、IISDI、IISSCLK、IISLRCK和CDCLK。前两个引脚用于数字音频信号的输出和输入,另外三个引脚都与音频信号的频率有关,可见要用好IIS,就要把信号频率设置正确。 IISSCLK为串行时钟,每一个时钟信号传送一位音频信号。因此IISSCLK的频率=声道数×采样频率×采样位数,如采样频率fs为44.1kHz,采样的位数为16位,声道数2个(左、右两个声道),则IISSCLK的频率=32fs=1411.2kHz。 1、
[单片机]
<font color='red'>mini2440</font>裸机试炼之IIS——音乐播放器
mini2440按键驱动程序分析
先说明一下按键与S3C2440芯片的连接方式: KEY1 ---- EINT8 ---- GPG0 KEY2 ---- EINT11 ---- GPG3 KEY3 ---- EINT13 ---- GPG5 KEY4 ---- EINT14 ---- GPG6 KEY5 ---- EINT15 ---- GPG7 KEY6 ---- EINT19 ---- GPG11 驱动程序源码如下: (drivers/char/mini2440_buttons.c) #include linux/module.h #include linux/kernel.h #include linux/fs.h #include linux
[单片机]
mini2440 I2C驱动的分析与学习(一)
花了近一个星期的时间学习I2C的驱动,将心得描述如下。I2C是一个典型的较简单的子系统,比较适合学习,因为I2C协议要比PCI等等简单得多。 在mini2440上用I2C连了一块EEPROM的芯片。因此,在mini2440上面说I2C的驱动,主要是说怎么样通过I2C在这块EERPOM上面读写数据。有点像是这个EEPROM的驱动。 先分析几个相关的结构体。其实有时觉得C语言就是以结构体为中心的,基本上把重要的结构体看明白了,程序也就看懂了。 struct s3c24xx_i2c { spinlock_t lock; wait_queue_head_t wait; unsigned int sus
[单片机]
Mini2440 DM9000 驱动分析
net_device_ops中方法的相应说明 /* * This structure defines the management hooks for network devices. * The following hooks can be defined; unless noted otherwise, they are * optional and can be filled with a null pointer. * * int (*ndo_init)(struct net_device *dev); * This function is called once when network device i
[单片机]
Linux-2.6.32.2内核在mini2440上的移植(十六)---中断的按键驱动
移植环境 1,主机环境:VMare下CentOS 5.5 ,1G内存。 2,集成开发环境:Elipse IDE 3,编译编译环境:arm-linux-gcc v4.4.3,arm-none-linux-gnueabi-gcc v4.5.1。 4,开发板:mini2440,2M nor flash,128M nand flash。 5,u-boot版本:u-boot-2009.08 6,linux 版本:linux-2.6.32.2 7,参考文章: 嵌入式linux应用开发完全手册,韦东山,编著。 Mini2440 之Linux 移植开发实战指南 【1】硬件原理 Mini2440 具有6 个用户测试按键,它们都是连接到CPU 的中断
[单片机]
Linux-2.6.32.2内核在<font color='red'>mini2440</font>上的移植(十六)---中断的按键<font color='red'>驱动</font>
小广播
添点儿料...
无论热点新闻、行业分析、技术干货……
设计资源 培训 开发板 精华推荐

最新单片机文章
何立民专栏 单片机及嵌入式宝典

北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

换一换 更多 相关热搜器件
电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved