diff options
Diffstat (limited to 'drivers/tty/tty_io.c')
-rw-r--r-- | drivers/tty/tty_io.c | 52 |
1 files changed, 48 insertions, 4 deletions
diff --git a/drivers/tty/tty_io.c b/drivers/tty/tty_io.c index 35480dd57a30..464d09d97873 100644 --- a/drivers/tty/tty_io.c +++ b/drivers/tty/tty_io.c | |||
@@ -2627,6 +2627,11 @@ long tty_ioctl(struct file *file, unsigned int cmd, unsigned long arg) | |||
2627 | return put_user(tty->ldisc->ops->num, (int __user *)p); | 2627 | return put_user(tty->ldisc->ops->num, (int __user *)p); |
2628 | case TIOCSETD: | 2628 | case TIOCSETD: |
2629 | return tiocsetd(tty, p); | 2629 | return tiocsetd(tty, p); |
2630 | case TIOCGDEV: | ||
2631 | { | ||
2632 | unsigned int ret = new_encode_dev(tty_devnum(real_tty)); | ||
2633 | return put_user(ret, (unsigned int __user *)p); | ||
2634 | } | ||
2630 | /* | 2635 | /* |
2631 | * Break handling | 2636 | * Break handling |
2632 | */ | 2637 | */ |
@@ -3241,9 +3246,45 @@ static int __init tty_class_init(void) | |||
3241 | postcore_initcall(tty_class_init); | 3246 | postcore_initcall(tty_class_init); |
3242 | 3247 | ||
3243 | /* 3/2004 jmc: why do these devices exist? */ | 3248 | /* 3/2004 jmc: why do these devices exist? */ |
3244 | |||
3245 | static struct cdev tty_cdev, console_cdev; | 3249 | static struct cdev tty_cdev, console_cdev; |
3246 | 3250 | ||
3251 | static ssize_t show_cons_active(struct device *dev, | ||
3252 | struct device_attribute *attr, char *buf) | ||
3253 | { | ||
3254 | struct console *cs[16]; | ||
3255 | int i = 0; | ||
3256 | struct console *c; | ||
3257 | ssize_t count = 0; | ||
3258 | |||
3259 | acquire_console_sem(); | ||
3260 | for (c = console_drivers; c; c = c->next) { | ||
3261 | if (!c->device) | ||
3262 | continue; | ||
3263 | if (!c->write) | ||
3264 | continue; | ||
3265 | if ((c->flags & CON_ENABLED) == 0) | ||
3266 | continue; | ||
3267 | cs[i++] = c; | ||
3268 | if (i >= ARRAY_SIZE(cs)) | ||
3269 | break; | ||
3270 | } | ||
3271 | while (i--) | ||
3272 | count += sprintf(buf + count, "%s%d%c", | ||
3273 | cs[i]->name, cs[i]->index, i ? ' ':'\n'); | ||
3274 | release_console_sem(); | ||
3275 | |||
3276 | return count; | ||
3277 | } | ||
3278 | static DEVICE_ATTR(active, S_IRUGO, show_cons_active, NULL); | ||
3279 | |||
3280 | static struct device *consdev; | ||
3281 | |||
3282 | void console_sysfs_notify(void) | ||
3283 | { | ||
3284 | if (consdev) | ||
3285 | sysfs_notify(&consdev->kobj, NULL, "active"); | ||
3286 | } | ||
3287 | |||
3247 | /* | 3288 | /* |
3248 | * Ok, now we can initialize the rest of the tty devices and can count | 3289 | * Ok, now we can initialize the rest of the tty devices and can count |
3249 | * on memory allocations, interrupts etc.. | 3290 | * on memory allocations, interrupts etc.. |
@@ -3254,15 +3295,18 @@ int __init tty_init(void) | |||
3254 | if (cdev_add(&tty_cdev, MKDEV(TTYAUX_MAJOR, 0), 1) || | 3295 | if (cdev_add(&tty_cdev, MKDEV(TTYAUX_MAJOR, 0), 1) || |
3255 | register_chrdev_region(MKDEV(TTYAUX_MAJOR, 0), 1, "/dev/tty") < 0) | 3296 | register_chrdev_region(MKDEV(TTYAUX_MAJOR, 0), 1, "/dev/tty") < 0) |
3256 | panic("Couldn't register /dev/tty driver\n"); | 3297 | panic("Couldn't register /dev/tty driver\n"); |
3257 | device_create(tty_class, NULL, MKDEV(TTYAUX_MAJOR, 0), NULL, | 3298 | device_create(tty_class, NULL, MKDEV(TTYAUX_MAJOR, 0), NULL, "tty"); |
3258 | "tty"); | ||
3259 | 3299 | ||
3260 | cdev_init(&console_cdev, &console_fops); | 3300 | cdev_init(&console_cdev, &console_fops); |
3261 | if (cdev_add(&console_cdev, MKDEV(TTYAUX_MAJOR, 1), 1) || | 3301 | if (cdev_add(&console_cdev, MKDEV(TTYAUX_MAJOR, 1), 1) || |
3262 | register_chrdev_region(MKDEV(TTYAUX_MAJOR, 1), 1, "/dev/console") < 0) | 3302 | register_chrdev_region(MKDEV(TTYAUX_MAJOR, 1), 1, "/dev/console") < 0) |
3263 | panic("Couldn't register /dev/console driver\n"); | 3303 | panic("Couldn't register /dev/console driver\n"); |
3264 | device_create(tty_class, NULL, MKDEV(TTYAUX_MAJOR, 1), NULL, | 3304 | consdev = device_create(tty_class, NULL, MKDEV(TTYAUX_MAJOR, 1), NULL, |
3265 | "console"); | 3305 | "console"); |
3306 | if (IS_ERR(consdev)) | ||
3307 | consdev = NULL; | ||
3308 | else | ||
3309 | device_create_file(consdev, &dev_attr_active); | ||
3266 | 3310 | ||
3267 | #ifdef CONFIG_VT | 3311 | #ifdef CONFIG_VT |
3268 | vty_init(&console_fops); | 3312 | vty_init(&console_fops); |