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

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

?? access.c

?? 典型的linux驅動程序
?? C
字號:
/* * access.c -- the files with access control on open * * Copyright (C) 2001 Alessandro Rubini and Jonathan Corbet * Copyright (C) 2001 O'Reilly & Associates * * The source code in this file can be freely used, adapted, * and redistributed in source or binary form, so long as an * acknowledgment appears in derived source files.  The citation * should list that the code comes from the book "Linux Device * Drivers" by Alessandro Rubini and Jonathan Corbet, published * by O'Reilly & Associates.   No warranty is attached; * we cannot take responsibility for errors or fitness for use. * * $Id: access.c,v 1.17 2004/09/26 07:29:56 gregkh Exp $ *//* FIXME: cloned devices as a use for kobjects? */ #include <linux/kernel.h> /* printk() */#include <linux/module.h>#include <linux/slab.h>   /* kmalloc() */#include <linux/fs.h>     /* everything... */#include <linux/errno.h>  /* error codes */#include <linux/types.h>  /* size_t */#include <linux/fcntl.h>#include <linux/cdev.h>#include <linux/tty.h>#include <asm/atomic.h>#include <linux/list.h>#include "scull.h"        /* local definitions */static dev_t scull_a_firstdev;  /* Where our range begins *//* * These devices fall back on the main scull operations. They only * differ in the implementation of open() and close() *//************************************************************************ * * The first device is the single-open one, *  it has an hw structure and an open count */static struct scull_dev scull_s_device;static atomic_t scull_s_available = ATOMIC_INIT(1);static int scull_s_open(struct inode *inode, struct file *filp){	struct scull_dev *dev = &scull_s_device; /* device information */	if (! atomic_dec_and_test (&scull_s_available)) {		atomic_inc(&scull_s_available);		return -EBUSY; /* already open */	}	/* then, everything else is copied from the bare scull device */	if ( (filp->f_flags & O_ACCMODE) == O_WRONLY)		scull_trim(dev);	filp->private_data = dev;	return 0;          /* success */}static int scull_s_release(struct inode *inode, struct file *filp){	atomic_inc(&scull_s_available); /* release the device */	return 0;}/* * The other operations for the single-open device come from the bare device */struct file_operations scull_sngl_fops = {	.owner =	THIS_MODULE,	.llseek =     	scull_llseek,	.read =       	scull_read,	.write =      	scull_write,	.ioctl =      	scull_ioctl,	.open =       	scull_s_open,	.release =    	scull_s_release,};/************************************************************************ * * Next, the "uid" device. It can be opened multiple times by the * same user, but access is denied to other users if the device is open */static struct scull_dev scull_u_device;static int scull_u_count;	/* initialized to 0 by default */static uid_t scull_u_owner;	/* initialized to 0 by default */static spinlock_t scull_u_lock = SPIN_LOCK_UNLOCKED;static int scull_u_open(struct inode *inode, struct file *filp){	struct scull_dev *dev = &scull_u_device; /* device information */	spin_lock(&scull_u_lock);	if (scull_u_count && 			(scull_u_owner != current->uid) &&  /* allow user */			(scull_u_owner != current->euid) && /* allow whoever did su */			!capable(CAP_DAC_OVERRIDE)) { /* still allow root */		spin_unlock(&scull_u_lock);		return -EBUSY;   /* -EPERM would confuse the user */	}	if (scull_u_count == 0)		scull_u_owner = current->uid; /* grab it */	scull_u_count++;	spin_unlock(&scull_u_lock);/* then, everything else is copied from the bare scull device */	if ((filp->f_flags & O_ACCMODE) == O_WRONLY)		scull_trim(dev);	filp->private_data = dev;	return 0;          /* success */}static int scull_u_release(struct inode *inode, struct file *filp){	spin_lock(&scull_u_lock);	scull_u_count--; /* nothing else */	spin_unlock(&scull_u_lock);	return 0;}/* * The other operations for the device come from the bare device */struct file_operations scull_user_fops = {	.owner =      THIS_MODULE,	.llseek =     scull_llseek,	.read =       scull_read,	.write =      scull_write,	.ioctl =      scull_ioctl,	.open =       scull_u_open,	.release =    scull_u_release,};/************************************************************************ * * Next, the device with blocking-open based on uid */static struct scull_dev scull_w_device;static int scull_w_count;	/* initialized to 0 by default */static uid_t scull_w_owner;	/* initialized to 0 by default */static DECLARE_WAIT_QUEUE_HEAD(scull_w_wait);static spinlock_t scull_w_lock = SPIN_LOCK_UNLOCKED;static inline int scull_w_available(void){	return scull_w_count == 0 ||		scull_w_owner == current->uid ||		scull_w_owner == current->euid ||		capable(CAP_DAC_OVERRIDE);}static int scull_w_open(struct inode *inode, struct file *filp){	struct scull_dev *dev = &scull_w_device; /* device information */	spin_lock(&scull_w_lock);	while (! scull_w_available()) {		spin_unlock(&scull_w_lock);		if (filp->f_flags & O_NONBLOCK) return -EAGAIN;		if (wait_event_interruptible (scull_w_wait, scull_w_available()))			return -ERESTARTSYS; /* tell the fs layer to handle it */		spin_lock(&scull_w_lock);	}	if (scull_w_count == 0)		scull_w_owner = current->uid; /* grab it */	scull_w_count++;	spin_unlock(&scull_w_lock);	/* then, everything else is copied from the bare scull device */	if ((filp->f_flags & O_ACCMODE) == O_WRONLY)		scull_trim(dev);	filp->private_data = dev;	return 0;          /* success */}static int scull_w_release(struct inode *inode, struct file *filp){	int temp;	spin_lock(&scull_w_lock);	scull_w_count--;	temp = scull_w_count;	spin_unlock(&scull_w_lock);	if (temp == 0)		wake_up_interruptible_sync(&scull_w_wait); /* awake other uid's */	return 0;}/* * The other operations for the device come from the bare device */struct file_operations scull_wusr_fops = {	.owner =      THIS_MODULE,	.llseek =     scull_llseek,	.read =       scull_read,	.write =      scull_write,	.ioctl =      scull_ioctl,	.open =       scull_w_open,	.release =    scull_w_release,};/************************************************************************ * * Finally the `cloned' private device. This is trickier because it * involves list management, and dynamic allocation. *//* The clone-specific data structure includes a key field */struct scull_listitem {	struct scull_dev device;	dev_t key;	struct list_head list;    };/* The list of devices, and a lock to protect it */static LIST_HEAD(scull_c_list);static spinlock_t scull_c_lock = SPIN_LOCK_UNLOCKED;/* A placeholder scull_dev which really just holds the cdev stuff. */static struct scull_dev scull_c_device;   /* Look for a device or create one if missing */static struct scull_dev *scull_c_lookfor_device(dev_t key){	struct scull_listitem *lptr;	list_for_each_entry(lptr, &scull_c_list, list) {		if (lptr->key == key)			return &(lptr->device);	}	/* not found */	lptr = kmalloc(sizeof(struct scull_listitem), GFP_KERNEL);	if (!lptr)		return NULL;	/* initialize the device */	memset(lptr, 0, sizeof(struct scull_listitem));	lptr->key = key;	scull_trim(&(lptr->device)); /* initialize it */	init_MUTEX(&(lptr->device.sem));	/* place it in the list */	list_add(&lptr->list, &scull_c_list);	return &(lptr->device);}static int scull_c_open(struct inode *inode, struct file *filp){	struct scull_dev *dev;	dev_t key; 	if (!current->signal->tty) { 		PDEBUG("Process \"%s\" has no ctl tty\n", current->comm);		return -EINVAL;	}	key = tty_devnum(current->signal->tty);	/* look for a scullc device in the list */	spin_lock(&scull_c_lock);	dev = scull_c_lookfor_device(key);	spin_unlock(&scull_c_lock);	if (!dev)		return -ENOMEM;	/* then, everything else is copied from the bare scull device */	if ( (filp->f_flags & O_ACCMODE) == O_WRONLY)		scull_trim(dev);	filp->private_data = dev;	return 0;          /* success */}static int scull_c_release(struct inode *inode, struct file *filp){	/*	 * Nothing to do, because the device is persistent.	 * A `real' cloned device should be freed on last close	 */	return 0;}/* * The other operations for the device come from the bare device */struct file_operations scull_priv_fops = {	.owner =    THIS_MODULE,	.llseek =   scull_llseek,	.read =     scull_read,	.write =    scull_write,	.ioctl =    scull_ioctl,	.open =     scull_c_open,	.release =  scull_c_release,};/************************************************************************ * * And the init and cleanup functions come last */static struct scull_adev_info {	char *name;	struct scull_dev *sculldev;	struct file_operations *fops;} scull_access_devs[] = {	{ "scullsingle", &scull_s_device, &scull_sngl_fops },	{ "sculluid", &scull_u_device, &scull_user_fops },	{ "scullwuid", &scull_w_device, &scull_wusr_fops },	{ "sullpriv", &scull_c_device, &scull_priv_fops }};#define SCULL_N_ADEVS 4/* * Set up a single device. */static void scull_access_setup (dev_t devno, struct scull_adev_info *devinfo){	struct scull_dev *dev = devinfo->sculldev;	int err;	/* Initialize the device structure */	dev->quantum = scull_quantum;	dev->qset = scull_qset;	init_MUTEX(&dev->sem);	/* Do the cdev stuff. */	cdev_init(&dev->cdev, devinfo->fops);	kobject_set_name(&dev->cdev.kobj, devinfo->name);	dev->cdev.owner = THIS_MODULE;	err = cdev_add (&dev->cdev, devno, 1);        /* Fail gracefully if need be */	if (err) {		printk(KERN_NOTICE "Error %d adding %s\n", err, devinfo->name);		kobject_put(&dev->cdev.kobj);	} else		printk(KERN_NOTICE "%s registered at %x\n", devinfo->name, devno);}int scull_access_init(dev_t firstdev){	int result, i;	/* Get our number space */	result = register_chrdev_region (firstdev, SCULL_N_ADEVS, "sculla");	if (result < 0) {		printk(KERN_WARNING "sculla: device number registration failed\n");		return 0;	}	scull_a_firstdev = firstdev;	/* Set up each device. */	for (i = 0; i < SCULL_N_ADEVS; i++)		scull_access_setup (firstdev + i, scull_access_devs + i);	return SCULL_N_ADEVS;}/* * This is called by cleanup_module or on failure. * It is required to never fail, even if nothing was initialized first */void scull_access_cleanup(void){	struct scull_listitem *lptr, *next;	int i;	/* Clean up the static devs */	for (i = 0; i < SCULL_N_ADEVS; i++) {		struct scull_dev *dev = scull_access_devs[i].sculldev;		cdev_del(&dev->cdev);		scull_trim(scull_access_devs[i].sculldev);	}    	/* And all the cloned devices */	list_for_each_entry_safe(lptr, next, &scull_c_list, list) {		list_del(&lptr->list);		scull_trim(&(lptr->device));		kfree(lptr);	}	/* Free up our number space */	unregister_chrdev_region(scull_a_firstdev, SCULL_N_ADEVS);	return;}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
中文字幕中文字幕一区二区| 韩国在线一区二区| 久久国产精品色婷婷| 4438成人网| 蜜臀精品一区二区三区在线观看| 日韩欧美色电影| 国产成人综合亚洲91猫咪| 欧美国产日韩在线观看| 99国内精品久久| 亚洲成年人网站在线观看| 欧美喷水一区二区| 另类小说欧美激情| 精品一区二区三区在线播放| 亚洲日本va午夜在线影院| 欧美日韩免费观看一区三区| 国产精品自在在线| 日韩精品视频网| 中文字幕一区二区三区不卡在线| 91精品国产日韩91久久久久久| 不卡av电影在线播放| 亚洲成人av在线电影| 日精品一区二区三区| 久久99久久精品欧美| 国产成人精品亚洲777人妖 | 国产一区欧美日韩| 亚洲制服丝袜一区| 国产肉丝袜一区二区| 欧美美女激情18p| 99国产精品久久久久久久久久| 色妞www精品视频| 一区二区三区在线播放| 久久久欧美精品sm网站| 欧美日韩高清不卡| 久久久国际精品| 一区二区欧美视频| 韩国三级电影一区二区| 色综合久久久网| 精品久久久久av影院| 欧美精品色一区二区三区| 欧美精品一区二区在线观看| 日韩欧美你懂的| 国产精品色婷婷| 欧美激情综合五月色丁香| 一区二区三区在线看| 韩国欧美国产1区| 91精彩视频在线观看| 日韩欧美成人一区二区| 亚洲免费观看视频| 亚洲黄色av一区| 亚洲综合在线五月| 精品一区二区三区在线视频| 在线亚洲免费视频| 欧美日韩在线电影| 国产精品女同一区二区三区| 人人狠狠综合久久亚洲| 麻豆国产精品视频| 在线亚洲人成电影网站色www| 亚洲精品在线三区| 热久久免费视频| 欧美午夜精品免费| 欧美videos大乳护士334| 一区二区三区国产精华| 成人综合日日夜夜| 色综合天天天天做夜夜夜夜做| 粉嫩aⅴ一区二区三区四区五区| 不卡一区二区三区四区| 精品国内二区三区| 老司机精品视频在线| 欧美一区二区性放荡片| 午夜不卡av在线| 国产精品一区二区三区四区| 精品裸体舞一区二区三区| 亚洲成人黄色影院| 欧美日韩一区不卡| 亚洲成a人片在线观看中文| 在线免费av一区| 一区二区三区在线影院| 91丨porny丨最新| 欧美色涩在线第一页| 亚洲自拍偷拍图区| 在线观看亚洲a| 亚洲柠檬福利资源导航| 91色.com| 亚洲动漫第一页| 国产成人午夜精品影院观看视频 | 一区二区三区四区精品在线视频| 91美女蜜桃在线| 亚洲一区在线视频观看| 欧美日韩免费一区二区三区| 蜜臀av性久久久久蜜臀aⅴ| 日韩视频一区二区三区在线播放| 亚洲视频中文字幕| 色综合天天综合狠狠| 亚洲午夜激情av| 日韩精品最新网址| 国产99久久久精品| 一区二区三区在线观看欧美| 正在播放亚洲一区| 高清不卡在线观看| 亚洲免费在线观看视频| 欧美一区二区三区性视频| 精品一区二区在线免费观看| 国产精品久久久久7777按摩| 91九色最新地址| 日本最新不卡在线| 欧美日韩免费不卡视频一区二区三区| 午夜精品久久久| 国产无遮挡一区二区三区毛片日本| 三级一区在线视频先锋 | 午夜精品久久久久久| 欧美www视频| 色婷婷综合久久久| 老司机精品视频导航| 亚洲欧洲另类国产综合| 欧美日韩一区二区三区免费看| 久久成人精品无人区| 亚洲欧美aⅴ...| 国产性色一区二区| 欧美一区三区四区| 91在线观看地址| 国产一区二区看久久| 亚洲一区二区欧美日韩| 久久久精品国产99久久精品芒果 | 日本最新不卡在线| 日韩码欧中文字| 精品处破学生在线二十三| 欧美午夜一区二区三区免费大片| 国产老妇另类xxxxx| 天天av天天翘天天综合网色鬼国产| 国产精品入口麻豆九色| 欧美大片在线观看一区二区| 欧美手机在线视频| 91小视频免费观看| 国产成人av电影在线观看| 全国精品久久少妇| 午夜不卡av在线| 夜夜嗨av一区二区三区四季av | 亚洲成精国产精品女| 中文字幕欧美一| 国产精品天天看| 久久综合九色综合97_久久久| 国产综合色在线| 日韩av在线播放中文字幕| 一区二区三区免费| 国产精品美女视频| 中文字幕乱码久久午夜不卡| 久久蜜桃一区二区| 精品国产91洋老外米糕| 精品国产一区二区在线观看| 欧美乱妇15p| 91 com成人网| 欧美二区三区的天堂| 欧美日韩精品电影| 91精品国产高清一区二区三区蜜臀| 91猫先生在线| 欧美影院午夜播放| 欧美私人免费视频| 337p亚洲精品色噜噜| 日韩写真欧美这视频| 日韩欧美成人一区二区| 亚洲精品一区二区三区在线观看| 日韩一区二区三区在线观看| 日韩欧美在线网站| 精品久久久网站| 国产精品国产自产拍高清av | 国产高清不卡一区二区| 国产高清不卡一区| 91亚洲资源网| 欧美中文字幕一区| 91精品欧美福利在线观看| 日韩一区二区高清| 久久久久久久国产精品影院| 国产欧美日本一区视频| 亚洲欧洲av色图| 亚洲国产日韩a在线播放| 蜜臀久久久久久久| 国产福利不卡视频| 一本久久a久久精品亚洲| 欧美日韩和欧美的一区二区| 日韩三级中文字幕| 久久精品视频一区二区| 亚洲人妖av一区二区| 五月激情六月综合| 福利一区二区在线| 欧美日韩亚洲综合在线| 欧美精品一区二区三区一线天视频| 欧美国产精品中文字幕| 亚洲综合无码一区二区| 国产精品一区一区| 在线影视一区二区三区| 亚洲精品一区二区三区福利| 日韩理论片在线| 精品一区二区三区久久| 色综合久久久久久久久| 久久久久久亚洲综合影院红桃| 一区二区三区欧美亚洲| 国产乱码一区二区三区| 欧美精品一卡二卡| 亚洲精品日日夜夜| 国产成人免费视|