mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-04 20:19:47 +08:00 
			
		
		
		
	 a9a08845e9
			
		
	
	
		a9a08845e9
		
	
	
	
	
		
			
			This is the mindless scripted replacement of kernel use of POLL*
variables as described by Al, done by this script:
    for V in IN OUT PRI ERR RDNORM RDBAND WRNORM WRBAND HUP RDHUP NVAL MSG; do
        L=`git grep -l -w POLL$V | grep -v '^t' | grep -v /um/ | grep -v '^sa' | grep -v '/poll.h$'|grep -v '^D'`
        for f in $L; do sed -i "-es/^\([^\"]*\)\(\<POLL$V\>\)/\\1E\\2/" $f; done
    done
with de-mangling cleanups yet to come.
NOTE! On almost all architectures, the EPOLL* constants have the same
values as the POLL* constants do.  But they keyword here is "almost".
For various bad reasons they aren't the same, and epoll() doesn't
actually work quite correctly in some cases due to this on Sparc et al.
The next patch from Al will sort out the final differences, and we
should be all done.
Scripted-by: Al Viro <viro@zeniv.linux.org.uk>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
		
	
			
		
			
				
	
	
		
			66 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			66 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| // SPDX-License-Identifier: GPL-2.0
 | |
| /*
 | |
|  *  linux/fs/proc/kmsg.c
 | |
|  *
 | |
|  *  Copyright (C) 1992  by Linus Torvalds
 | |
|  *
 | |
|  */
 | |
| 
 | |
| #include <linux/types.h>
 | |
| #include <linux/errno.h>
 | |
| #include <linux/time.h>
 | |
| #include <linux/kernel.h>
 | |
| #include <linux/poll.h>
 | |
| #include <linux/proc_fs.h>
 | |
| #include <linux/fs.h>
 | |
| #include <linux/syslog.h>
 | |
| 
 | |
| #include <linux/uaccess.h>
 | |
| #include <asm/io.h>
 | |
| 
 | |
| extern wait_queue_head_t log_wait;
 | |
| 
 | |
| static int kmsg_open(struct inode * inode, struct file * file)
 | |
| {
 | |
| 	return do_syslog(SYSLOG_ACTION_OPEN, NULL, 0, SYSLOG_FROM_PROC);
 | |
| }
 | |
| 
 | |
| static int kmsg_release(struct inode * inode, struct file * file)
 | |
| {
 | |
| 	(void) do_syslog(SYSLOG_ACTION_CLOSE, NULL, 0, SYSLOG_FROM_PROC);
 | |
| 	return 0;
 | |
| }
 | |
| 
 | |
| static ssize_t kmsg_read(struct file *file, char __user *buf,
 | |
| 			 size_t count, loff_t *ppos)
 | |
| {
 | |
| 	if ((file->f_flags & O_NONBLOCK) &&
 | |
| 	    !do_syslog(SYSLOG_ACTION_SIZE_UNREAD, NULL, 0, SYSLOG_FROM_PROC))
 | |
| 		return -EAGAIN;
 | |
| 	return do_syslog(SYSLOG_ACTION_READ, buf, count, SYSLOG_FROM_PROC);
 | |
| }
 | |
| 
 | |
| static __poll_t kmsg_poll(struct file *file, poll_table *wait)
 | |
| {
 | |
| 	poll_wait(file, &log_wait, wait);
 | |
| 	if (do_syslog(SYSLOG_ACTION_SIZE_UNREAD, NULL, 0, SYSLOG_FROM_PROC))
 | |
| 		return EPOLLIN | EPOLLRDNORM;
 | |
| 	return 0;
 | |
| }
 | |
| 
 | |
| 
 | |
| static const struct file_operations proc_kmsg_operations = {
 | |
| 	.read		= kmsg_read,
 | |
| 	.poll		= kmsg_poll,
 | |
| 	.open		= kmsg_open,
 | |
| 	.release	= kmsg_release,
 | |
| 	.llseek		= generic_file_llseek,
 | |
| };
 | |
| 
 | |
| static int __init proc_kmsg_init(void)
 | |
| {
 | |
| 	proc_create("kmsg", S_IRUSR, NULL, &proc_kmsg_operations);
 | |
| 	return 0;
 | |
| }
 | |
| fs_initcall(proc_kmsg_init);
 |