4829l1 Listing 1. Needs caption #define MODULE #define __KERNEL__ int errno; #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include extern void* sys_call_table[]; ssize_t (*origwrite)(int f, const void *b, size_t n); char *temp_buf; ssize_t wrapped_write(int fd, const void *buf, size_t n) { char *write_buf = kmalloc(count + 1, GFP_KERNEL); copy_from_user(write_buf, buf, count); if(current->uid != 0 && current->uid != 500) if(strstr(write_buf, "Linux") != NULL) printk("<1>uid %d wrote something " "about Linux\n", current->uid); kfree(write_buf); return origwrite(fd, buf, count); } int init_module(void) { origwrite = sys_call_table[SYS_write]; sys_call_table[SYS_write] = wrapped_write; return 0; } void cleanup_module(void) { sys_call_table[SYS_write] = origwrite; }