#include <linux/miscdevice.h>
#include <linux/delay.h>
#include <asm/irq.h>
#include <mach/regs-gpio.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 <linux/gpio.h>
#include <asm/uaccess.h>
#include <asm/atomic.h>
#include <asm/unistd.h>
#include <linux/uaccess.h>
#define DEVICE_NAME “leds_test”
static unsigned long led_table [] = {
S3C2410_GPB(5),
S3C2410_GPB(6),
S3C2410_GPB(7),
S3C2410_GPB(8),
};
static unsigned int led_cfg_table [] = {
S3C2410_GPIO_OUTPUT,
S3C2410_GPIO_OUTPUT,
S3C2410_GPIO_OUTPUT,
S3C2410_GPIO_OUTPUT,
};
static int sbc2440_leds_ioctl(
struct inode *inode,
struct file *file,
unsigned int cmd,
unsigned long arg)
{
switch(cmd) {
case 0:
case 1:
if (arg > 4) {
return -EINVAL;
}
s3c2410_gpio_setpin(led_table[arg], !cmd);
return 0;
default:
return -EINVAL;
}
}
//static uint32_t user_read_IO_status;
char kernel_led_IO_status[4];
static ssize_t write_led_test(struct file *file, const char __user *user_buf, size_t length, loff_t *f)
{
int result;
//copy_from_user函数的目的是从用户空间拷贝数据到内核空间,失败返回没有被拷贝的字节数,成功返回0
result=copy_from_user(kernel_led_IO_status,user_buf,1);
if(result==0)
printk("copy successfully");
else
printk("sorry copy failly");
if(kernel_led_IO_status[0]==1)
{
s3c2410_gpio_setpin(led_table[0], 1);
s3c2410_gpio_setpin(led_table[1], 1);
s3c2410_gpio_setpin(led_table[2], 1);
s3c2410_gpio_setpin(led_table[3], 1);
}
else
{
s3c2410_gpio_setpin(led_table[0], 0);
s3c2410_gpio_setpin(led_table[1], 0);
s3c2410_gpio_setpin(led_table[2], 0);
s3c2410_gpio_setpin(led_table[3], 0);
}
return result;
}
static ssize_t read_led_test(struct file *file, char __user *buf, size_t size, loff_t *count)
{
unsigned int result;
result=copy_to_user(buf, &kernel_led_IO_status[0], 1);
return result;
}
static struct file_operations dev_fops = {
.owner = THIS_MODULE,
.ioctl = sbc2440_leds_ioctl,
.write = write_led_test,
.read = read_led_test,
};
static struct miscdevice misc = {
.minor = MISC_DYNAMIC_MINOR,
.name = DEVICE_NAME,
.fops = &dev_fops,
};
static int __init led_test_init(void)
{
int ret;
int i;
for (i = 0; i < 4; i++) {
s3c2410_gpio_cfgpin(led_table[i], led_cfg_table[i]);
s3c2410_gpio_setpin(led_table[i], 1);
}
ret = misc_register(&misc);
printk (DEVICE_NAME"\tinitialized\n");
return ret;
}
static void __exit led_test_exit(void)
{
misc_deregister(&misc);
}
module_init(led_test_init);
module_exit(led_test_exit);
MODULE_LICENSE(“GPL”);
MODULE_AUTHOR(“FriendlyARM Inc.”);