ARM11 LED 设备驱动程序

#include <linux/miscdevice.h>
#include <linux/delay.h>
#include <asm/irq.h>

#include <mach/hardware.h>
#include <linux/kernel.h>
#include <linux/module.h>
#include <linux/init.h>
#include <linux/mm.h>
#include <linux/fs.h>
#include <linux/types.h>
#include <linux/delay.h>
#include <linux/moduleparam.h>
#include <linux/slab.h>
#include <linux/errno.h>
#include <linux/ioctl.h>
#include <linux/cdev.h>
#include <linux/string.h>
#include <linux/list.h>
#include <linux/pci.h>
#include <asm/uaccess.h>
#include <asm/atomic.h>
#include <asm/unistd.h>
#include <mach/map.h>
#include <mach/gpio.h>
#include <mach/regs-clock.h>
#include <mach/regs-gpio.h>
#include <plat/gpio-cfg.h>
#include <mach/gpio-bank-e.h>
#include <mach/gpio-bank-k.h>

#define DEVICE_NAME "misckey"

static long tiny6410_led_ioctl(struct file *filp, unsigned int cmd, unsigned long arg)

 switch(cmd)
 {
  case 0:
   

   writel(0xffff,S3C64XX_GPKDAT);
   break;
  case 1:
   writel(0xff0f,S3C64XX_GPKDAT);
   break;
  default:
   return -EINVAL;
 }
 return 0;
}

static struct file_operations dev_fops = {
 .owner = THIS_MODULE,
 .unlocked_ioctl = tiny6410_led_ioctl,
};

static struct miscdevice misc = {
 .minor = 255,
 .name = DEVICE_NAME,
 .fops = &dev_fops,
};

static int dev_up_init(void)
{
 int ret;

 s3c_gpio_cfgpin(S3C64XX_GPK(4),S3C_GPIO_OUTPUT);
 s3c_gpio_cfgpin(S3C64XX_GPK(5),S3C_GPIO_OUTPUT);
 s3c_gpio_cfgpin(S3C64XX_GPK(6),S3C_GPIO_OUTPUT);
 s3c_gpio_cfgpin(S3C64XX_GPK(7),S3C_GPIO_OUTPUT);

 __raw_writel(0xff0f,S3C64XX_GPKDAT);
 
 ret = misc_register(&misc);
 
 printk("misc is up %d \n",ret);
 
 return ret;
}

static void dev_exit(void)
{
 __raw_writel(0xffff,S3C64XX_GPKDAT);
 
 misc_deregister(&misc);
 printk("see you misc \n");
}

module_init(dev_up_init);
module_exit(dev_exit);

MODULE_LICENSE("GPL");

 

你可能感兴趣的:(linux,嵌入式,单片机,ARM,6410)