#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");