blob: d8a509c5d5bd8619fac1d74d526971daa6af34a5 [file] [log] [blame]
Thomas Gleixner2874c5f2019-05-27 08:55:01 +02001// SPDX-License-Identifier: GPL-2.0-or-later
Linus Torvalds1da177e2005-04-16 15:20:36 -07002/*
3 * linux/arch/arm/kernel/isa.c
4 *
5 * Copyright (C) 1999 Phil Blundell
6 *
Russell King7034b0e2006-08-28 12:44:03 +01007 * ISA shared memory and I/O port support, and is required to support
8 * iopl, inb, outb and friends in userspace via glibc emulation.
Linus Torvalds1da177e2005-04-16 15:20:36 -07009 */
Linus Torvalds1da177e2005-04-16 15:20:36 -070010#include <linux/stddef.h>
11#include <linux/types.h>
12#include <linux/fs.h>
13#include <linux/sysctl.h>
14#include <linux/init.h>
Ben Dooks87e0d6c2009-01-08 15:42:40 +000015#include <linux/io.h>
Linus Torvalds1da177e2005-04-16 15:20:36 -070016
17static unsigned int isa_membase, isa_portbase, isa_portshift;
18
Joe Perches37649de2014-06-06 14:37:54 -070019static struct ctl_table ctl_isa_vars[4] = {
Russell King7034b0e2006-08-28 12:44:03 +010020 {
Russell King7034b0e2006-08-28 12:44:03 +010021 .procname = "membase",
22 .data = &isa_membase,
23 .maxlen = sizeof(isa_membase),
24 .mode = 0444,
Eric W. Biederman6d456112009-11-16 03:11:48 -080025 .proc_handler = proc_dointvec,
Russell King7034b0e2006-08-28 12:44:03 +010026 }, {
Russell King7034b0e2006-08-28 12:44:03 +010027 .procname = "portbase",
28 .data = &isa_portbase,
29 .maxlen = sizeof(isa_portbase),
30 .mode = 0444,
Eric W. Biederman6d456112009-11-16 03:11:48 -080031 .proc_handler = proc_dointvec,
Russell King7034b0e2006-08-28 12:44:03 +010032 }, {
Russell King7034b0e2006-08-28 12:44:03 +010033 .procname = "portshift",
34 .data = &isa_portshift,
35 .maxlen = sizeof(isa_portshift),
36 .mode = 0444,
Eric W. Biederman6d456112009-11-16 03:11:48 -080037 .proc_handler = proc_dointvec,
Eric W. Biederman50469612009-04-03 05:11:21 -070038 }, {}
Linus Torvalds1da177e2005-04-16 15:20:36 -070039};
40
41static struct ctl_table_header *isa_sysctl_header;
42
Joe Perches37649de2014-06-06 14:37:54 -070043static struct ctl_table ctl_isa[2] = {
Russell King7034b0e2006-08-28 12:44:03 +010044 {
Russell King7034b0e2006-08-28 12:44:03 +010045 .procname = "isa",
46 .mode = 0555,
47 .child = ctl_isa_vars,
Eric W. Biederman50469612009-04-03 05:11:21 -070048 }, {}
Russell King7034b0e2006-08-28 12:44:03 +010049};
50
Joe Perches37649de2014-06-06 14:37:54 -070051static struct ctl_table ctl_bus[2] = {
Russell King7034b0e2006-08-28 12:44:03 +010052 {
Russell King7034b0e2006-08-28 12:44:03 +010053 .procname = "bus",
54 .mode = 0555,
55 .child = ctl_isa,
Eric W. Biederman50469612009-04-03 05:11:21 -070056 }, {}
Russell King7034b0e2006-08-28 12:44:03 +010057};
Linus Torvalds1da177e2005-04-16 15:20:36 -070058
59void __init
60register_isa_ports(unsigned int membase, unsigned int portbase, unsigned int portshift)
61{
62 isa_membase = membase;
63 isa_portbase = portbase;
64 isa_portshift = portshift;
Eric W. Biederman0b4d4142007-02-14 00:34:09 -080065 isa_sysctl_header = register_sysctl_table(ctl_bus);
Linus Torvalds1da177e2005-04-16 15:20:36 -070066}