亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? gpio.c

?? 周立功ARM7試驗箱
?? C
字號:
/****************************************Copyright (c)**************************************************
**                               Guangzou ZLG-MCU Development Co.,LTD.
**                                     graduate school
**                                 http://www.zlgmcu.com
**
**--------------File Info-------------------------------------------------------------------------------
** File name:			gpio.c
** Last modified Date:  2005-04-21
** Last Version:		1.0
** Descriptions:		This is a Kernel module for uClinux 2.4.x .**                      This module let uClinux 2.4.x can use gpio. 
**------------------------------------------------------------------------------------------------------
** Created by:			Chenmingji
** Created date:		2005-04-21
** Version:				1.0
** Descriptions:		The original version
**
**------------------------------------------------------------------------------------------------------
** Modified by:
** Modified date:
** Version:
** Descriptions:
**

********************************************************************************************************/
#define IN_GPIO#include "config.h"/********************************************************************************************************
              function announce********************************************************************************************************/
#if 0static loff_t gpio_llseek(struct file *filp, loff_t off, int whence);static ssize_t gpio_read(struct file *filp, char *buf, size_t count, loff_t *f_pos);static ssize_t gpio_write(struct file *filp, const char *buf, size_t count, loff_t *f_pos);#endifstatic int gpio_open(struct inode *inode, struct file *filp);static int gpio_release(struct inode *inode, struct file *filp); static int gpio_ioctl(struct inode *inode, struct file *filp, unsigned int cmd,		              unsigned long param);int  gpio_init(void);void gpio_cleanup(void);/********************************************************************************************************
              function announce********************************************************************************************************/
#define MAJOR_NR majormodule_init(gpio_init);module_exit(gpio_cleanup);MODULE_PARM(major, "i");MODULE_LICENSE("Proprietary");MODULE_DESCRIPTION("Guangzou ZLG-MCU Development Co.,LTD.\ngraduate school\nhttp://www.zlgmcu.com");MODULE_SUPPORTED_DEVICE("uClinux2.4.x LPC2200 GPIO");MODULE_AUTHOR("chenmingji");/*********************************************************************************************************
**                  "全局和靜態變量在這里定義"         
**        global variables and static variables define here
********************************************************************************************************/
static int major = GPIO_MAJOR_NR;/********************************************************************************************************/
static struct file_operations gpio_fops =        /* driver info  */{    owner:      THIS_MODULE,#if 0    llseek:     gpio_llseek,    read:       gpio_read,    write:      gpio_write,#endif    ioctl:      gpio_ioctl,    open:       gpio_open,    release:    gpio_release,};#if 0/*********************************************************************************************************
** Function name: gpio_llseek
** Descriptions:  move read and write point
** Input: filp:   pointer of file
**        off:    ofset
**        whence: move mode
**                0: seek set
**                1: seek file' current point
**                2: seek file' end
** Output :      new point
** Created by:   Chenmingji
** Created Date: 2005-4-21
**-------------------------------------------------------------------------------------------------------
** Modified by:
** Modified Date: 
**------------------------------------------------------------------------------------------------------
********************************************************************************************************/
        static loff_t gpio_llseek(struct file *filp, loff_t off, int whence){    return 0;}/*********************************************************************************************************
** Function name: gpio_read
** Descriptions:  read device
** Input: filp:   pointer of file
**        buf:    buf for save data
**        count:  size for read
**        f_pos:  *f_pos = read point
** Output : read size    
** Created by:   Chenmingji
** Created Date: 2005-4-21
**-------------------------------------------------------------------------------------------------------
** Modified by:
** Modified Date: 
**------------------------------------------------------------------------------------------------------
********************************************************************************************************/
        static ssize_t gpio_read(struct file *filp, char *buf, size_t count,                           loff_t *f_pos){    return 0;}/*********************************************************************************************************
** Function name: gpio_write
** Descriptions:  write device
** Input: filp:   pointer of file
**        buf:    buf to write data
**        count:  size for read
**        f_pos:  *f_pos = read point
** Output : write size    
** Created by:   Chenmingji
** Created Date: 2005-4-21
**-------------------------------------------------------------------------------------------------------
** Modified by:
** Modified Date: 
**------------------------------------------------------------------------------------------------------
********************************************************************************************************/
        static ssize_t gpio_write(struct file *filp, const char *buf, size_t count,                            loff_t *f_pos){    return 0;}#endif                /*********************************************************************************************************
** Function name: gpio_open
** Descriptions:  open device
** Input:inode:   information of device
**       filp:    pointer of file
** Output 0:      OK
**        other:  not OK
** Created by:    Chenmingji
** Created Date:  2005-4-21
**-------------------------------------------------------------------------------------------------------
** Modified by:
** Modified Date: 
**------------------------------------------------------------------------------------------------------
********************************************************************************************************/
        static int gpio_open(struct inode *inode, struct file *filp){    MOD_INC_USE_COUNT;    return 0;          /* success */} /*********************************************************************************************************
** Function name: gpio_release
** Descriptions:  release device
** Input:inode:   information of device
**       filp:    pointer of file
** Output 0:      OK
**        other:  not OK
** Created by:    Chenmingji
** Created Date:  2005-4-21
**-------------------------------------------------------------------------------------------------------
** Modified by:
** Modified Date: 
**------------------------------------------------------------------------------------------------------
********************************************************************************************************/
        static int gpio_release(struct inode *inode, struct file *filp) {    MOD_DEC_USE_COUNT;    return(0); } /*********************************************************************************************************
** Function name: gpio_ioctl
** Descriptions:  IO control function
** Input:inode:   information of device
**       filp:    pointer of file
**       cmd:     command
**       arg:     additive parameter
** Output 0:      OK
**        other:  not OK
** Created by:    Chenmingji
** Created Date:  2005-4-21
**-------------------------------------------------------------------------------------------------------
** Modified by:
** Modified Date: 
**------------------------------------------------------------------------------------------------------
********************************************************************************************************/
#define GPIO_ADDR_BASE   0xE0028000#define GPIO_PIN_OFFSET  0x00000000#define GPIO_SET_OFFSET  0x00000001#define GPIO_DIR_OFFSET  0x00000002#define GPIO_CLR_OFFSET  0x00000003#define GPIO_PORT_ADD    0x00000010        static int gpio_ioctl(struct inode *inode, struct file *filp,                        unsigned int cmd, unsigned long arg){    int num;    volatile u32 *Reg;    u32 temp1, temp2;        num = MINOR(inode->i_rdev);    if (num >= MAX_PORT)    {        return -ENODEV;    }
    if (_IOC_TYPE(cmd) != GPIO_IOC_MAGIC)    {        return -ENOTTY;    }
    if (_IOC_NR(cmd) >= GPIO_MAXNR)    {        return -ENOTTY;    }
    Reg = (volatile u32 *)(GPIO_ADDR_BASE + GPIO_PORT_ADD * num);    switch(cmd)    {        case GPIO_SET_PIN:            if (arg < 32)            {                 Reg[GPIO_SET_OFFSET] = 1u << arg;            }            break;        case GPIO_SET_ALL_PIN:            Reg[GPIO_SET_OFFSET] = arg;            break;        case GPIO_CLR_PIN:            if (arg < 32)            {                 Reg[GPIO_CLR_OFFSET] = 1u << arg;            }            break;        case GPIO_CLR_ALL_PIN:            Reg[GPIO_CLR_OFFSET] = arg;            break;        case GPIO_SET_PIN_OUT:            if (arg < 32)            {                 Reg[GPIO_DIR_OFFSET] |= 1u << arg;            }            break;        case GPIO_SET_PIN_IN:            if (arg < 32)            {                 Reg[GPIO_DIR_OFFSET] &= ~(1u << arg);            }            break;        case GPIO_SET_MULTI_PIN_OUT:            Reg[GPIO_DIR_OFFSET] |= arg;
            break;
        case GPIO_SET_MULTI_PIN_IN:            Reg[GPIO_DIR_OFFSET] &= ~arg;
            break;
        case GPIO_READ_PORT:            if (!access_ok(VERIFY_READ, (void *)arg, _IOC_SIZE(cmd)))
            {
                return -EFAULT;            }
            if (!access_ok(VERIFY_WRITE, (void *)arg, _IOC_SIZE(cmd)))
            {
                return -EFAULT;            }

            temp1 = GPIO_PIN_ERR;            get_user(temp2, (u32 *)arg);            if (temp2 < 32)            {                temp1 = Reg[GPIO_SET_OFFSET] & (1u << temp2);                if (temp1 != 0)                {                    temp1 = GPIO_PIN_HIGH;                }                else                {                    temp1 = GPIO_PIN_LOW;                }            }            put_user(temp1, (u32 *)arg);            break;        case GPIO_READ_ALL_PORT:            if (!access_ok(VERIFY_READ, (void *)arg, _IOC_SIZE(cmd)))
            {
                return -EFAULT;            }
            if (!access_ok(VERIFY_WRITE, (void *)arg, _IOC_SIZE(cmd)))
            {
                return -EFAULT;            }


            temp1 = Reg[GPIO_SET_OFFSET];            put_user(temp1, (u32 *)arg);            break;        case GPIO_READ_PIN:            if (!access_ok(VERIFY_READ, (void *)arg, _IOC_SIZE(cmd)))
            {
                return -EFAULT;            }
            if (!access_ok(VERIFY_WRITE, (void *)arg, _IOC_SIZE(cmd)))
            {
                return -EFAULT;            }


            temp1 = GPIO_PIN_ERR;            get_user(temp2, (u32 *)arg);            if (temp2 < 32)            {                temp1 = Reg[GPIO_PIN_OFFSET] & (1u << temp2);                if (temp1 != 0)                {                    temp1 = GPIO_PIN_HIGH;                }                else                {                    temp1 = GPIO_PIN_LOW;                }            }            put_user(temp1, (u32 *)arg);            break;        case GPIO_READ_ALL_PIN:            if (!access_ok(VERIFY_READ, (void *)arg, _IOC_SIZE(cmd)))
            {
                return -EFAULT;            }
            if (!access_ok(VERIFY_WRITE, (void *)arg, _IOC_SIZE(cmd)))
            {
                return -EFAULT;            }


            temp1 = Reg[GPIO_PIN_OFFSET];            put_user(temp1, (u32 *)arg);            break;        default:            return -ENOTTY;            break;    }    return 0;}/*********************************************************************************************************
** Function name: gpio_init
** Descriptions:  init driver
** Input:none
** Output 0:      OK
**        other:  not OK
** Created by:    Chenmingji
** Created Date:  2005-4-20
**-------------------------------------------------------------------------------------------------------
** Modified by:
** Modified Date: 
**------------------------------------------------------------------------------------------------------
********************************************************************************************************/
        int gpio_init(void){    int  result;    result = register_chrdev(MAJOR_NR,  DEVICE_NAME,  &gpio_fops);     if (result < 0)    {        printk(KERN_ERR DEVICE_NAME ": Unable to get major %d\n", MAJOR_NR );        return(result);     } 
    if (MAJOR_NR == 0)    {        MAJOR_NR = result; /* dynamic */    }
    printk(KERN_INFO DEVICE_NAME ": init OK\n");    return(0); }/*********************************************************************************************************
** Function name: gpio_cleanup
** Descriptions:  exit driver
** Input:none
** Output none
** Created by:    Chenmingji
** Created Date:  2005-4-20
**-------------------------------------------------------------------------------------------------------
** Modified by:
** Modified Date: 
**------------------------------------------------------------------------------------------------------
********************************************************************************************************/
        void gpio_cleanup(void){    unregister_chrdev(MAJOR_NR, DEVICE_NAME);}/***********************************************************************************************************                            End Of File********************************************************************************************************/

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
色哟哟精品一区| 日韩写真欧美这视频| 欧美日韩一区二区三区在线看| 日韩一区二区电影| 亚洲欧洲日产国码二区| 爽好多水快深点欧美视频| 国产精品99久久久久久似苏梦涵 | 国产91丝袜在线18| 在线成人高清不卡| 1区2区3区精品视频| 奇米777欧美一区二区| 91丝袜美女网| 久久久噜噜噜久久人人看 | 国产精品538一区二区在线| 在线免费观看不卡av| 国产拍揄自揄精品视频麻豆| 日本不卡在线视频| 欧美在线观看你懂的| 亚洲欧洲日本在线| 成人午夜伦理影院| 精品少妇一区二区| 日韩电影在线观看一区| 欧美日韩美少妇| 亚洲视频1区2区| 成人黄色小视频| 国产无遮挡一区二区三区毛片日本 | 亚洲成a天堂v人片| 91美女视频网站| 国产精品美女久久久久久久久| 国产一区二区成人久久免费影院| 在线电影院国产精品| 日韩国产精品久久久久久亚洲| 色婷婷综合久色| 亚洲天堂av老司机| 91麻豆国产精品久久| 成人免费视频在线观看| 91在线云播放| 亚洲精品一二三区| 欧美在线视频日韩| 日韩精品一卡二卡三卡四卡无卡| 欧美亚洲另类激情小说| 亚洲制服丝袜一区| 欧美另类久久久品| 麻豆视频一区二区| www成人在线观看| 国产一区二区三区免费在线观看| 精品国产百合女同互慰| 国产一区美女在线| 欧美国产一区二区| 91一区二区在线| 亚洲国产日韩a在线播放性色| 欧美年轻男男videosbes| 婷婷六月综合亚洲| 2023国产精品视频| 不卡区在线中文字幕| 一区二区不卡在线播放 | 亚洲成av人片一区二区梦乃| 在线综合+亚洲+欧美中文字幕| 日本不卡一区二区| 久久免费电影网| 色综合天天综合网天天狠天天| 亚洲精品成人在线| 欧美一级欧美一级在线播放| 国产一区视频在线看| 亚洲色图视频网站| 欧美一区二区网站| 成人一级片在线观看| 亚洲综合一区在线| 久久综合精品国产一区二区三区| 成人一区二区三区| 日韩电影在线观看电影| 久久免费视频一区| 欧美日韩国产bt| 国产高清视频一区| 天堂成人免费av电影一区| 国产三级精品视频| 在线综合亚洲欧美在线视频| 成人精品鲁一区一区二区| 五月激情综合婷婷| 国产精品美日韩| 日韩欧美国产精品| 欧洲一区在线电影| 高清成人在线观看| 日韩福利电影在线| 亚洲伦在线观看| 久久日韩精品一区二区五区| 色94色欧美sute亚洲线路一久| 老色鬼精品视频在线观看播放| 亚洲伦在线观看| 欧美经典一区二区| 欧美精品一区二区蜜臀亚洲| 欧美丝袜丝nylons| 92国产精品观看| 懂色av一区二区三区免费观看| 青椒成人免费视频| 亚洲二区在线观看| 亚洲免费色视频| 欧美国产日韩精品免费观看| 91精品免费在线观看| 91福利视频在线| 91美女精品福利| 国产精品77777| 国产一区二区三区日韩| 免费成人小视频| 蜜臀av一区二区三区| 亚洲线精品一区二区三区| 国产精品久久二区二区| 国产欧美精品一区二区色综合朱莉| 欧美一区二区三区在线观看| 欧美亚一区二区| 日本韩国欧美国产| 色婷婷av一区二区三区之一色屋| 国产精品亚洲第一| 国产999精品久久久久久| 国产精品亚洲综合一区在线观看| 久久99国产精品久久| 美女视频网站黄色亚洲| 日本va欧美va瓶| 男女激情视频一区| 极品美女销魂一区二区三区 | 国产日韩欧美一区二区三区综合| 精品日本一线二线三线不卡| 日韩免费在线观看| 精品福利在线导航| 久久精子c满五个校花| 国产女主播视频一区二区| 亚洲麻豆国产自偷在线| 一卡二卡三卡日韩欧美| 一区二区三区.www| 日韩精品欧美成人高清一区二区| 日韩精品免费专区| 狠狠色伊人亚洲综合成人| 国内精品伊人久久久久av影院| 国产精品一区免费视频| 99re热视频精品| 欧美色精品天天在线观看视频| 在线播放国产精品二区一二区四区| 欧美老女人在线| 日韩一级高清毛片| 国产日韩av一区| 一区二区在线免费| 免费成人在线观看视频| 国产精品亚洲第一区在线暖暖韩国| eeuss鲁片一区二区三区在线看| 色综合久久久久综合体| 欧美精品精品一区| 亚洲精品一区二区三区在线观看| 国产色91在线| 亚洲综合色区另类av| 蜜臀av性久久久久av蜜臀妖精| 国产成人综合视频| 日本精品一区二区三区高清| 欧美一级黄色大片| 亚洲欧洲一区二区在线播放| 五月天亚洲婷婷| 国产乱色国产精品免费视频| 日本久久一区二区| 日韩欧美aaaaaa| 亚洲男人电影天堂| 青青青爽久久午夜综合久久午夜| 成人污污视频在线观看| 欧美女孩性生活视频| 欧美极品少妇xxxxⅹ高跟鞋 | 99视频在线观看一区三区| 欧美色成人综合| 国产欧美日韩另类一区| 石原莉奈在线亚洲二区| a亚洲天堂av| 欧美电影免费观看高清完整版| 日韩一区有码在线| 国产原创一区二区| 欧美久久久久免费| 亚洲欧美在线aaa| 极品少妇xxxx精品少妇偷拍| 欧美中文字幕不卡| 国产精品毛片久久久久久| 美女爽到高潮91| 欧美精品免费视频| 亚洲欧美欧美一区二区三区| 麻豆久久久久久久| 欧美视频在线观看一区二区| 精品福利av导航| 日av在线不卡| 欧美日韩国产小视频在线观看| 亚洲国产高清在线| 国产乱码精品1区2区3区| 这里只有精品99re| 天堂一区二区在线免费观看| 日韩视频免费观看高清完整版 | 欧美卡1卡2卡| 夜夜嗨av一区二区三区四季av| 国产成人8x视频一区二区| 欧美一级理论片| 日韩电影在线一区二区| 欧美日韩精品综合在线| 亚洲男女毛片无遮挡| 北岛玲一区二区三区四区| 久久久久久黄色| 国产成人精品www牛牛影视| 国产亚洲污的网站|