Device Driver 관련 예제를 분석중입니다
글쓴이: windower / 작성시간: 월, 2004/05/31 - 2:14오후
간단하게 가상 메모리를 동적으로 할당하고
거기에 읽고 쓰는 메모리 Device Driver를 분석하고 있습니다.
간단히 쏘스는 아래와 같습니다.
#include <linux/kernel.h> #include <linux/module.h> #include <linux/fs.h> #include <linux/kdev_t.h> #include <asm/uaccess.h> #define DEVICE_NAME "minibuf" #define BUFFER_LEN 1024 // Global variables static int s_nMajor = 0; static int s_bDeviceOpen = 0; static char s_strBuf[BUFFER_LEN]; static int s_nBufPos = 0, s_nBufEnd = 0; // Function Prototypes static int device_open(struct inode *inode, struct file *flip); static int device_release(struct inode *inode, struct file *flip); static ssize_t device_read(struct file *flip, char *buffer, size_t length,loff_t *offset); static ssize_t device_write(struct file *flip, char *buffer, size_t length, loff_t *offset); static int is_buffer_empty(void); static int is_buffer_full(void); static int read_buffer_char(char *buffer); static int write_buffer_char(char *buffer); static struct file_operations device_fops = { read:device_read, /* read */ write:device_write, /* write */ open:device_open, /* open */ release:device_release /* release */ }; int init_module() { printk("RAM Buffer Module loading...\n"); if( ( s_nMajor = register_chrdev(0, DEVICE_NAME, &device_fops) )<0 ) { printk(DEVICE_NAME" : Device Registration Failed ~! (%d) \n",s_nMajor); return s_nMajor; } printk(DEVICE_NAME" : Device Registration with Major Number = %d\n",s_nMajor); strcpy(s_strBuf,"안녕하세요 세상들이셔~!\n"); s_nBufEnd = strlen(s_strBuf) + 1; return 0; } void cleanup_module(void) { int nRetCode; printk("Unloading RAM Buffer Module\n"); if( (nRetCode = unregister_chrdev(s_nMajor, DEVICE_NAME))<0 ) { printk(DEVICE_NAME" : Device unregisteration failed (%d)\n",nRetCode); } } int device_open(struct inode *inode, struct file *flip) { printk(DEVICE_NAME" : Device open (%d, %d)\n",MAJOR(inode->i_rdev), MINOR(inode->i_rdev) ); if(s_bDeviceOpen) { printk(DEVICE_NAME" : Device already open\n"); return -EBUSY; } ++s_bDeviceOpen; MOD_INC_USE_COUNT; return 0; } int device_release(struct inode *inode, struct file *flip) { printk(DEVICE_NAME" : Device Release (%d, %d)\n",MAJOR(inode->i_rdev), MINOR(inode->i_rdev) ); if(!s_bDeviceOpen) { printk(DEVICE_NAME" : Device has not opened\n"); return -EINVAL; } --s_bDeviceOpen; MOD_DEC_USE_COUNT; return 0; } ssize_t device_read(struct file *filp, char *buffer, size_t length, loff_t *offset) { int count = 0; if (is_buffer_empty()) { printk(DEVICE_NAME " : Read return EOF\n"); return 0; } // end if while (!is_buffer_empty() && length > 1) { read_buffer_char(buffer); ++buffer; --length; ++count; } // end while put_user(0, buffer); ++count; printk(DEVICE_NAME " : read %d bytes\n", count); return count; } // end func ssize_t device_write(struct file *filp, char *buffer, size_t length, loff_t *offset) { return -ENOSYS; } // end func // Buffer Management int is_buffer_empty() { return (s_nBufPos == s_nBufEnd) ? 1 : 0; } // end func int is_buffer_full() { int pos = s_nBufEnd + 1; if (pos == BUFFER_LEN) pos = 0; return (pos == s_nBufPos) ? 1 : 0; } // end func int read_buffer_char(char *buffer) { if (is_buffer_empty()) return -1; put_user(s_strBuf[s_nBufPos], buffer); if (++s_nBufPos == BUFFER_LEN) s_nBufPos = 0; return 0; } // end func int write_buffer_char(char *buffer) { if (is_buffer_full()) return -1; get_user(s_strBuf[s_nBufEnd], buffer); if (++s_nBufEnd == BUFFER_LEN) s_nBufEnd = 0; return 0; } // end func
다름이 아니라 여기에 나온 put_user와 get_user부분에 관련된
manual을 알고 싶은데 man put_user로 해서도 찾을 수 없었습니다.
관련된 부분을 어떻게 찾을 수 있을지요?
그리고 아마 여기서 가장 중요한
함수인듯한데, 간단히라도 좋으니 put_user와
get_user의 기능을 알려주신다면 감사하겠습니다.
Forums:
Re: Device Driver 관련 예제를 분석중입니다
put_user : 커널 메모리의 내용을 User Process 메모리로 복사
get_user : User Process 메모리의 내용을 커널 메모리로 복사
이것입니다. 고운 하루되시길..
=========================
CharSyam ^^ --- 고운 하루
=========================
댓글 달기