⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 s3c2410_spi_cc1100-driver-backup1.c

📁 s3c2410开发板中使用cc1100无线模块的linux驱动
💻 C
字号:
#include <linux/config.h>#include <linux/errno.h>#include <linux/kernel.h>#include <linux/module.h>#include <linux/slab.h>#include <linux/init.h>#include <linux/serio.h>#include <linux/delay.h>#include <asm/io.h>#include <asm/irq.h>#include <linux/sched.h>#include <linux/poll.h>#include <linux/spinlock.h>#include <linux/coda.h>#include <linux/cdev.h>#include <linux/interrupt.h>#include <linux/devfs_fs_kernel.h>#include <asm/io.h>#include <asm/arch/regs-adc.h>#include <asm/arch/regs-gpio.h>#include <asm/irq.h>#include <linux/delay.h>#include <asm/hardware.h>#include <linux/fs.h>#include <linux/ioctl.h>#include <linux/device.h>#include <asm/arch/map.h>#include <asm/hardware/clock.h>#include <asm/arch/hardware.h>#include <asm/arch/regs-spi.h>MODULE_DESCRIPTION("My kernel module");MODULE_AUTHOR("root (root@Figo)");MODULE_LICENSE("GPL");int CC1100_MAJOR=0;int CC1100_MINOR=0;void __iomem *spi_addr_vir=NULL;struct fasync_struct *fasync1; static int cc1100_fasync(int fd,struct file *filp,int on);static int cc1100_open(struct inode * inode,struct file *filp);static int cc1100_release(struct inode * inode,struct file *filp);static ssize_t cc1100_write(struct file *filp,const char *buf,size_t count,loff_t *ppos);static ssize_t cc1100_read(struct file *filp,char __user *buf,size_t count,loff_t *ppos);static int s3c2410_spi_cc1100_probe(struct device *dev);static int s3c2410_spi_cc1100_remove(struct device *dev);static irqreturn_t eint10_irq(int irq,void *dev_id,struct pt_regs *regs);static struct file_operations cc1100_fops={	.owner=		THIS_MODULE,	.open=		cc1100_open,	.write=		cc1100_write,	.read=		cc1100_read,	.release=	cc1100_release,	.fasync=		cc1100_fasync,};static struct device_driver  s3c2410_spi_cc1100_driver={	.name=		"s3c2410_spi_cc1100",	.bus=		&platform_bus_type,	.probe=		s3c2410_spi_cc1100_probe,	.remove=	s3c2410_spi_cc1100_remove,};static int cc1100_open(struct inode * inode,struct file *filp){		int result;	result=request_irq(IRQ_EINT10,eint10_irq,SA_INTERRUPT,"s3c2410_spi_cc1100",NULL);	if(result)	{		printk(KERN_ERR"The SPI0 inerrupt is not free\n");		return -1;	}	return 0;}static irqreturn_t eint10_irq(int irq,void *dev_id,struct pt_regs *regs){	disable_irq(IRQ_EINT10);	if(fasync1)		kill_fasync(&fasync1,SIGIO,POLL_IN);//	printk("EINT10 interrupt occur!\n");	enable_irq(IRQ_EINT10);		return IRQ_HANDLED;}static int cc1100_fasync(int fd,struct file *filp,int on){	int ret;	ret=fasync_helper(fd,filp,on,&fasync1);	if(ret<0)		return ret;	return 0;}static int cc1100_release(struct inode * inode,struct file *filp){	free_irq(IRQ_EINT10,NULL);	cc1100_fasync(-1,filp,0);	return 0;}static ssize_t cc1100_write(struct file *filp,const char __user *buf,size_t count,loff_t *ppos){	char kbuf[4]={0};	disable_irq(IRQ_EINT10);	size_t size=0;	copy_from_user(kbuf,buf,count);	while(s3c2410_gpio_getpin(S3C2410_GPE14));		while(size<count)	{		while(!(ioread8(spi_addr_vir+S3C2410_SPSTA)&S3C2410_SPSTA_READY));		iowrite8(kbuf[size],spi_addr_vir+S3C2410_SPTDAT);		size=size+1;		__udelay(40);	}	enable_irq(IRQ_EINT10);	return count;	}static ssize_t cc1100_read(struct file *filp,char __user *buf,size_t count,loff_t *ppos){	char kbuf[4]={0};	disable_irq(IRQ_EINT10);	size_t size=0;	while(size<count)	{		while(!(ioread8(spi_addr_vir+S3C2410_SPSTA)&S3C2410_SPSTA_READY));		iowrite8(0xff,spi_addr_vir+S3C2410_SPTDAT);		__udelay(22);				while(!(ioread8(spi_addr_vir+S3C2410_SPSTA)&S3C2410_SPSTA_READY));		kbuf[size]=ioread8(spi_addr_vir+S3C2410_SPRDAT);			copy_to_user(&buf[size],&kbuf[size],1);		size=size+1;		__udelay(22);	}	enable_irq(IRQ_EINT10);	return count;	}dev_t cc1100_devt;static struct clk  * spi_clk;static struct cdev * cc1100_cdev;static int s3c2410_spi_cc1100_probe(struct device *dev){	int result;	printk("s3c2410_spi_cc1100_probe!\n");	/*register the driver to system*/	result=alloc_chrdev_region(&cc1100_devt,CC1100_MINOR,1,"s3c2410_spi_cc1100");	CC1100_MAJOR=MAJOR(cc1100_devt);		if(result<0)	{		printk(KERN_ERR"Can`t get the major number %d for CC1100\n",CC1100_MAJOR);		return -1;	}	cc1100_cdev=cdev_alloc();	if(cc1100_cdev!=NULL)	{		cdev_init(cc1100_cdev,&cc1100_fops);		cc1100_cdev->ops=&cc1100_fops;		cc1100_cdev->owner=THIS_MODULE;		if(cdev_add(cc1100_cdev,cc1100_devt,1))			printk(KERN_NOTICE"Can`t add this driver to system!\n");		else			printk(KERN_NOTICE" add this driver to system succefully!\n");	}	else 	{		printk(KERN_ERR"cdev_alloc error!\n");		return -1;	}	devfs_mk_cdev(MKDEV(CC1100_MAJOR,CC1100_MINOR),S_IFCHR|S_IRUSR|S_IWUSR,"cc1100");	/*request the memorary resource*/		if(!request_mem_region((unsigned long)S3C24XX_VA_SPI,SZ_1M,"s3c2410_spi_cc1100"))	{		printk(KERN_ERR"the spi0 region %X is not free\n",S3C24XX_VA_SPI);		return -EBUSY;	}		/*request the clock resource*/	spi_clk=clk_get(NULL,"spi");	if(!spi_clk)	{		printk(KERN_ERR"Can`t get the spi clock\n");		return -1;	}	clk_use(spi_clk);	clk_enable(spi_clk);	/*confiure the GPE14 GPE13,GPE12,GPE11*/	s3c2410_gpio_cfgpin(S3C2410_GPE13,S3C2410_GPE13_SPICLK0);	s3c2410_gpio_cfgpin(S3C2410_GPE12,S3C2410_GPE12_SPIMOSI0);	s3c2410_gpio_cfgpin(S3C2410_GPE11,S3C2410_GPE11_SPIMISO0);	s3c2410_gpio_cfgpin(S3C2410_GPE14,S3C2410_GPE14_INP);	set_irq_type(IRQ_EINT10,IRQT_FALLING);		/*map the phy address to vir address*/	spi_addr_vir=ioremap(S3C2410_PA_SPI,SZ_1M);	if(!spi_addr_vir)	{		printk(KERN_ERR"spi0 ioremap failed\n");			iounmap(S3C2410_PA_SPI);		return -EINVAL;		} 	/*initial the spi*/	iowrite8(0x18,spi_addr_vir+0x0c);	iowrite8(0x1e,spi_addr_vir+0x00);	iowrite8(0x02,spi_addr_vir+S3C2410_SPPIN);	return 0;}static int s3c2410_spi_cc1100_remove(struct device *dev){	//	cdev(s3c2410_spi_cc1100_driver);	unregister_chrdev_region(cc1100_devt,1);	clk_disable(spi_clk);	clk_unuse(spi_clk);	clk_put(spi_clk);	spi_clk=NULL;	iounmap(spi_addr_vir);	return 0;}static int __init s3c2410_spi_cc1100_init_module(void){	printk( KERN_DEBUG "Module s3c2410_spi_cc1100 init\n" );	driver_register(&s3c2410_spi_cc1100_driver);	return 0;}static void __exit s3c2410_spi_cc1100_exit_module(void){	printk( KERN_DEBUG "Module s3c2410_spi_cc1100 exit\n" );	driver_unregister(&s3c2410_spi_cc1100_driver);	cdev_del(cc1100_cdev);	devfs_remove("cc1100");}module_init(s3c2410_spi_cc1100_init_module);module_exit(s3c2410_spi_cc1100_exit_module);

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -