Merge tag 'v3.3.7' into 3.3/master
[zen-stable.git] / arch / um / drivers / null.c
blob2b45a1446c86b5bf34f01cfe9d71d19ec1a118cc
1 /*
2 * Copyright (C) 2002 - 2007 Jeff Dike (jdike@{linux.intel,addtoit}.com)
3 * Licensed under the GPL
4 */
6 #include <stddef.h>
7 #include <errno.h>
8 #include <fcntl.h>
9 #include "chan_user.h"
10 #include "os.h"
12 /* This address is used only as a unique identifier */
13 static int null_chan;
15 static void *null_init(char *str, int device, const struct chan_opts *opts)
17 return &null_chan;
20 static int null_open(int input, int output, int primary, void *d,
21 char **dev_out)
23 int fd;
25 *dev_out = NULL;
27 fd = open(DEV_NULL, O_RDWR);
28 return (fd < 0) ? -errno : fd;
31 static int null_read(int fd, char *c_out, void *unused)
33 return -ENODEV;
36 static void null_free(void *data)
40 const struct chan_ops null_ops = {
41 .type = "null",
42 .init = null_init,
43 .open = null_open,
44 .close = generic_close,
45 .read = null_read,
46 .write = generic_write,
47 .console_write = generic_console_write,
48 .window_size = generic_window_size,
49 .free = null_free,
50 .winch = 0,