Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
L
linux
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
nexedi
linux
Commits
c2e2d4f7
Commit
c2e2d4f7
authored
Jun 03, 2003
by
Linus Torvalds
Browse files
Options
Browse Files
Download
Plain Diff
Merge
bk://ldm.bkbits.net/linux-2.5-core
into home.transmeta.com:/home/torvalds/v2.5/linux
parents
ed2110ce
6f79387d
Changes
17
Hide whitespace changes
Inline
Side-by-side
Showing
17 changed files
with
727 additions
and
271 deletions
+727
-271
arch/i386/kernel/smp.c
arch/i386/kernel/smp.c
+0
-11
arch/ia64/kernel/smp.c
arch/ia64/kernel/smp.c
+0
-18
arch/ppc64/kernel/smp.c
arch/ppc64/kernel/smp.c
+0
-11
drivers/ide/ide-proc.c
drivers/ide/ide-proc.c
+1
-35
drivers/ide/ide.c
drivers/ide/ide.c
+4
-2
fs/bio.c
fs/bio.c
+1
-1
fs/dquot.c
fs/dquot.c
+79
-13
fs/libfs.c
fs/libfs.c
+1
-1
include/asm-i386/smp.h
include/asm-i386/smp.h
+0
-1
include/asm-ia64/smp.h
include/asm-ia64/smp.h
+0
-2
include/asm-ppc64/smp.h
include/asm-ppc64/smp.h
+0
-1
include/asm-x86_64/smp.h
include/asm-x86_64/smp.h
+0
-1
include/linux/ide.h
include/linux/ide.h
+0
-1
include/linux/smp.h
include/linux/smp.h
+0
-1
kernel/exec_domain.c
kernel/exec_domain.c
+62
-20
kernel/resource.c
kernel/resource.c
+13
-2
kernel/sysctl.c
kernel/sysctl.c
+566
-150
No files found.
arch/i386/kernel/smp.c
View file @
c2e2d4f7
...
...
@@ -460,17 +460,6 @@ void smp_send_reschedule(int cpu)
send_IPI_mask
(
1
<<
cpu
,
RESCHEDULE_VECTOR
);
}
/*
* this function sends a reschedule IPI to all (other) CPUs.
* This should only be used if some 'global' task became runnable,
* such as a RT task, that must be handled now. The first CPU
* that manages to grab the task will run it.
*/
void
smp_send_reschedule_all
(
void
)
{
send_IPI_allbutself
(
RESCHEDULE_VECTOR
);
}
/*
* Structure and data for smp_call_function(). This is designed to minimise
* static memory requirements. It also looks cleaner.
...
...
arch/ia64/kernel/smp.c
View file @
c2e2d4f7
...
...
@@ -205,24 +205,6 @@ smp_send_reschedule (int cpu)
platform_send_ipi
(
cpu
,
IA64_IPI_RESCHEDULE
,
IA64_IPI_DM_INT
,
0
);
}
/*
* This function sends a reschedule IPI to all (other) CPUs. This should only be used if
* some 'global' task became runnable, such as a RT task, that must be handled now. The
* first CPU that manages to grab the task will run it.
*/
void
smp_send_reschedule_all
(
void
)
{
int
i
;
int
cpu
=
get_cpu
();
/* disable preemption */
for
(
i
=
0
;
i
<
NR_CPUS
;
i
++
)
if
(
cpu_online
(
i
)
&&
i
!=
cpu
)
smp_send_reschedule
(
i
);
put_cpu
();
}
void
smp_flush_tlb_all
(
void
)
{
...
...
arch/ppc64/kernel/smp.c
View file @
c2e2d4f7
...
...
@@ -392,17 +392,6 @@ void smp_send_reschedule(int cpu)
smp_message_pass
(
cpu
,
PPC_MSG_RESCHEDULE
,
0
,
0
);
}
/*
* this function sends a reschedule IPI to all (other) CPUs.
* This should only be used if some 'global' task became runnable,
* such as a RT task, that must be handled now. The first CPU
* that manages to grab the task will run it.
*/
void
smp_send_reschedule_all
(
void
)
{
smp_message_pass
(
MSG_ALL_BUT_SELF
,
PPC_MSG_RESCHEDULE
,
0
,
0
);
}
#ifdef CONFIG_XMON
void
smp_send_xmon_break
(
int
cpu
)
{
...
...
drivers/ide/ide-proc.c
View file @
c2e2d4f7
...
...
@@ -712,7 +712,6 @@ void create_proc_ide_drives(ide_hwif_t *hwif)
for
(
d
=
0
;
d
<
MAX_DRIVES
;
d
++
)
{
ide_drive_t
*
drive
=
&
hwif
->
drives
[
d
];
ide_driver_t
*
driver
=
drive
->
driver
;
if
(
!
drive
->
present
)
continue
;
...
...
@@ -720,13 +719,8 @@ void create_proc_ide_drives(ide_hwif_t *hwif)
continue
;
drive
->
proc
=
proc_mkdir
(
drive
->
name
,
parent
);
if
(
drive
->
proc
)
{
if
(
drive
->
proc
)
ide_add_proc_entries
(
drive
->
proc
,
generic_drive_entries
,
drive
);
if
(
driver
)
{
ide_add_proc_entries
(
drive
->
proc
,
generic_subdriver_entries
,
drive
);
ide_add_proc_entries
(
drive
->
proc
,
driver
->
proc
,
drive
);
}
}
sprintf
(
name
,
"ide%d/%s"
,
(
drive
->
name
[
2
]
-
'a'
)
/
2
,
drive
->
name
);
ent
=
proc_symlink
(
drive
->
name
,
proc_ide_root
,
name
);
if
(
!
ent
)
return
;
...
...
@@ -735,34 +729,6 @@ void create_proc_ide_drives(ide_hwif_t *hwif)
EXPORT_SYMBOL
(
create_proc_ide_drives
);
void
recreate_proc_ide_device
(
ide_hwif_t
*
hwif
,
ide_drive_t
*
drive
)
{
struct
proc_dir_entry
*
ent
;
struct
proc_dir_entry
*
parent
=
hwif
->
proc
;
char
name
[
64
];
if
(
drive
->
present
&&
!
drive
->
proc
)
{
drive
->
proc
=
proc_mkdir
(
drive
->
name
,
parent
);
if
(
drive
->
proc
)
ide_add_proc_entries
(
drive
->
proc
,
generic_drive_entries
,
drive
);
/*
* assume that we have these already, however, should test FIXME!
* if (driver) {
* ide_add_proc_entries(drive->proc, generic_subdriver_entries, drive);
* ide_add_proc_entries(drive->proc, driver->proc, drive);
* }
*
*/
sprintf
(
name
,
"ide%d/%s"
,
(
drive
->
name
[
2
]
-
'a'
)
/
2
,
drive
->
name
);
ent
=
proc_symlink
(
drive
->
name
,
proc_ide_root
,
name
);
if
(
!
ent
)
return
;
}
}
EXPORT_SYMBOL
(
recreate_proc_ide_device
);
void
destroy_proc_ide_device
(
ide_hwif_t
*
hwif
,
ide_drive_t
*
drive
)
{
ide_driver_t
*
driver
=
drive
->
driver
;
...
...
drivers/ide/ide.c
View file @
c2e2d4f7
...
...
@@ -2349,8 +2349,10 @@ int ide_register_subdriver (ide_drive_t *drive, ide_driver_t *driver, int versio
}
drive
->
suspend_reset
=
0
;
#ifdef CONFIG_PROC_FS
ide_add_proc_entries
(
drive
->
proc
,
generic_subdriver_entries
,
drive
);
ide_add_proc_entries
(
drive
->
proc
,
driver
->
proc
,
drive
);
if
(
drive
->
driver
!=
&
idedefault_driver
)
{
ide_add_proc_entries
(
drive
->
proc
,
generic_subdriver_entries
,
drive
);
ide_add_proc_entries
(
drive
->
proc
,
driver
->
proc
,
drive
);
}
#endif
return
0
;
}
...
...
fs/bio.c
View file @
c2e2d4f7
...
...
@@ -53,7 +53,7 @@ struct biovec_pool {
* unsigned short
*/
#define BV(x) {
x,
"biovec-" #x }
#define BV(x) {
.nr_vecs = x, .name =
"biovec-" #x }
static
struct
biovec_pool
bvec_array
[
BIOVEC_NR_POOLS
]
=
{
BV
(
1
),
BV
(
4
),
BV
(
16
),
BV
(
64
),
BV
(
128
),
BV
(
BIO_MAX_PAGES
),
};
...
...
fs/dquot.c
View file @
c2e2d4f7
...
...
@@ -1348,25 +1348,91 @@ struct quotactl_ops vfs_quotactl_ops = {
};
static
ctl_table
fs_dqstats_table
[]
=
{
{
FS_DQ_LOOKUPS
,
"lookups"
,
&
dqstats
.
lookups
,
sizeof
(
int
),
0444
,
NULL
,
&
proc_dointvec
},
{
FS_DQ_DROPS
,
"drops"
,
&
dqstats
.
drops
,
sizeof
(
int
),
0444
,
NULL
,
&
proc_dointvec
},
{
FS_DQ_READS
,
"reads"
,
&
dqstats
.
reads
,
sizeof
(
int
),
0444
,
NULL
,
&
proc_dointvec
},
{
FS_DQ_WRITES
,
"writes"
,
&
dqstats
.
writes
,
sizeof
(
int
),
0444
,
NULL
,
&
proc_dointvec
},
{
FS_DQ_CACHE_HITS
,
"cache_hits"
,
&
dqstats
.
cache_hits
,
sizeof
(
int
),
0444
,
NULL
,
&
proc_dointvec
},
{
FS_DQ_ALLOCATED
,
"allocated_dquots"
,
&
dqstats
.
allocated_dquots
,
sizeof
(
int
),
0444
,
NULL
,
&
proc_dointvec
},
{
FS_DQ_FREE
,
"free_dquots"
,
&
dqstats
.
free_dquots
,
sizeof
(
int
),
0444
,
NULL
,
&
proc_dointvec
},
{
FS_DQ_SYNCS
,
"syncs"
,
&
dqstats
.
syncs
,
sizeof
(
int
),
0444
,
NULL
,
&
proc_dointvec
},
{},
{
.
ctl_name
=
FS_DQ_LOOKUPS
,
.
procname
=
"lookups"
,
.
data
=
&
dqstats
.
lookups
,
.
maxlen
=
sizeof
(
int
),
.
mode
=
0444
,
.
proc_handler
=
&
proc_dointvec
,
},
{
.
ctl_name
=
FS_DQ_DROPS
,
.
procname
=
"drops"
,
.
data
=
&
dqstats
.
drops
,
.
maxlen
=
sizeof
(
int
),
.
mode
=
0444
,
.
proc_handler
=
&
proc_dointvec
,
},
{
.
ctl_name
=
FS_DQ_READS
,
.
procname
=
"reads"
,
.
data
=
&
dqstats
.
reads
,
.
maxlen
=
sizeof
(
int
),
.
mode
=
0444
,
.
proc_handler
=
&
proc_dointvec
,
},
{
.
ctl_name
=
FS_DQ_WRITES
,
.
procname
=
"writes"
,
.
data
=
&
dqstats
.
writes
,
.
maxlen
=
sizeof
(
int
),
.
mode
=
0444
,
.
proc_handler
=
&
proc_dointvec
,
},
{
.
ctl_name
=
FS_DQ_CACHE_HITS
,
.
procname
=
"cache_hits"
,
.
data
=
&
dqstats
.
cache_hits
,
.
maxlen
=
sizeof
(
int
),
.
mode
=
0444
,
.
proc_handler
=
&
proc_dointvec
,
},
{
.
ctl_name
=
FS_DQ_ALLOCATED
,
.
procname
=
"allocated_dquots"
,
.
data
=
&
dqstats
.
allocated_dquots
,
.
maxlen
=
sizeof
(
int
),
.
mode
=
0444
,
.
proc_handler
=
&
proc_dointvec
,
},
{
.
ctl_name
=
FS_DQ_FREE
,
.
procname
=
"free_dquots"
,
.
data
=
&
dqstats
.
free_dquots
,
.
maxlen
=
sizeof
(
int
),
.
mode
=
0444
,
.
proc_handler
=
&
proc_dointvec
,
},
{
.
ctl_name
=
FS_DQ_SYNCS
,
.
procname
=
"syncs"
,
.
data
=
&
dqstats
.
syncs
,
.
maxlen
=
sizeof
(
int
),
.
mode
=
0444
,
.
proc_handler
=
&
proc_dointvec
,
},
{
.
ctl_name
=
0
},
};
static
ctl_table
fs_table
[]
=
{
{
FS_DQSTATS
,
"quota"
,
NULL
,
0
,
0555
,
fs_dqstats_table
},
{},
{
.
ctl_name
=
FS_DQSTATS
,
.
procname
=
"quota"
,
.
mode
=
0555
,
.
child
=
fs_dqstats_table
,
},
{
.
ctl_name
=
0
},
};
static
ctl_table
sys_table
[]
=
{
{
CTL_FS
,
"fs"
,
NULL
,
0
,
0555
,
fs_table
},
{},
{
.
ctl_name
=
CTL_FS
,
.
procname
=
"fs"
,
.
mode
=
0555
,
.
child
=
fs_table
,
},
{
.
ctl_name
=
0
},
};
/* SLAB cache for dquot structures */
...
...
fs/libfs.c
View file @
c2e2d4f7
...
...
@@ -336,7 +336,7 @@ int simple_commit_write(struct file *file, struct page *page,
int
simple_fill_super
(
struct
super_block
*
s
,
int
magic
,
struct
tree_descr
*
files
)
{
static
struct
super_operations
s_ops
=
{
statfs
:
simple_statfs
};
static
struct
super_operations
s_ops
=
{
.
statfs
=
simple_statfs
};
struct
inode
*
inode
;
struct
dentry
*
root
;
struct
dentry
*
dentry
;
...
...
include/asm-i386/smp.h
View file @
c2e2d4f7
...
...
@@ -41,7 +41,6 @@ extern int cpu_sibling_map[];
extern
void
smp_flush_tlb
(
void
);
extern
void
smp_message_irq
(
int
cpl
,
void
*
dev_id
,
struct
pt_regs
*
regs
);
extern
void
smp_send_reschedule
(
int
cpu
);
extern
void
smp_send_reschedule_all
(
void
);
extern
void
smp_invalidate_rcv
(
void
);
/* Process an NMI */
extern
void
(
*
mtrr_hook
)
(
void
);
extern
void
zap_low_mappings
(
void
);
...
...
include/asm-ia64/smp.h
View file @
c2e2d4f7
...
...
@@ -136,8 +136,6 @@ extern void smp_do_timer (struct pt_regs *regs);
extern
int
smp_call_function_single
(
int
cpuid
,
void
(
*
func
)
(
void
*
info
),
void
*
info
,
int
retry
,
int
wait
);
extern
void
smp_send_reschedule
(
int
cpu
);
extern
void
smp_send_reschedule_all
(
void
);
#endif
/* CONFIG_SMP */
#endif
/* _ASM_IA64_SMP_H */
include/asm-ppc64/smp.h
View file @
c2e2d4f7
...
...
@@ -34,7 +34,6 @@ extern void smp_send_tlb_invalidate(int);
extern
void
smp_send_xmon_break
(
int
cpu
);
struct
pt_regs
;
extern
void
smp_message_recv
(
int
,
struct
pt_regs
*
);
extern
void
smp_send_reschedule_all
(
void
);
#define NO_PROC_ID 0xFF
/* No processor magic marker */
...
...
include/asm-x86_64/smp.h
View file @
c2e2d4f7
...
...
@@ -42,7 +42,6 @@ extern int pic_mode;
extern
void
smp_flush_tlb
(
void
);
extern
void
smp_message_irq
(
int
cpl
,
void
*
dev_id
,
struct
pt_regs
*
regs
);
extern
void
smp_send_reschedule
(
int
cpu
);
extern
void
smp_send_reschedule_all
(
void
);
extern
void
smp_invalidate_rcv
(
void
);
/* Process an NMI */
extern
void
(
*
mtrr_hook
)
(
void
);
extern
void
zap_low_mappings
(
void
);
...
...
include/linux/ide.h
View file @
c2e2d4f7
...
...
@@ -1115,7 +1115,6 @@ typedef struct {
#ifdef CONFIG_PROC_FS
extern
void
proc_ide_create
(
void
);
extern
void
proc_ide_destroy
(
void
);
extern
void
recreate_proc_ide_device
(
ide_hwif_t
*
,
ide_drive_t
*
);
extern
void
destroy_proc_ide_device
(
ide_hwif_t
*
,
ide_drive_t
*
);
extern
void
destroy_proc_ide_drives
(
ide_hwif_t
*
);
extern
void
create_proc_ide_interfaces
(
void
);
...
...
include/linux/smp.h
View file @
c2e2d4f7
...
...
@@ -110,7 +110,6 @@ void smp_prepare_boot_cpu(void);
#define smp_call_function(func,info,retry,wait) ({ 0; })
#define on_each_cpu(func,info,retry,wait) ({ func(info); 0; })
static
inline
void
smp_send_reschedule
(
int
cpu
)
{
}
static
inline
void
smp_send_reschedule_all
(
void
)
{
}
#define cpu_online_map 1
#define cpu_online(cpu) ({ BUG_ON((cpu) != 0); 1; })
#define num_online_cpus() 1
...
...
kernel/exec_domain.c
View file @
c2e2d4f7
...
...
@@ -32,11 +32,12 @@ static u_long ident_map[32] = {
};
struct
exec_domain
default_exec_domain
=
{
"Linux"
,
/* name */
default_handler
,
/* lcall7 causes a seg fault. */
0
,
0
,
/* PER_LINUX personality. */
ident_map
,
/* Identity map signals. */
ident_map
,
/* - both ways. */
.
name
=
"Linux"
,
/* name */
.
handler
=
default_handler
,
/* lcall7 causes a seg fault. */
.
pers_low
=
0
,
/* PER_LINUX personality. */
.
pers_high
=
0
,
/* PER_LINUX personality. */
.
signal_map
=
ident_map
,
/* Identity map signals. */
.
signal_invmap
=
ident_map
,
/* - both ways. */
};
...
...
@@ -247,24 +248,65 @@ u_int abi_traceflg;
int
abi_fake_utsname
;
static
struct
ctl_table
abi_table
[]
=
{
{
ABI_DEFHANDLER_COFF
,
"defhandler_coff"
,
&
abi_defhandler_coff
,
sizeof
(
int
),
0644
,
NULL
,
&
proc_doulongvec_minmax
},
{
ABI_DEFHANDLER_ELF
,
"defhandler_elf"
,
&
abi_defhandler_elf
,
sizeof
(
int
),
0644
,
NULL
,
&
proc_doulongvec_minmax
},
{
ABI_DEFHANDLER_LCALL7
,
"defhandler_lcall7"
,
&
abi_defhandler_lcall7
,
sizeof
(
int
),
0644
,
NULL
,
&
proc_doulongvec_minmax
},
{
ABI_DEFHANDLER_LIBCSO
,
"defhandler_libcso"
,
&
abi_defhandler_libcso
,
sizeof
(
int
),
0644
,
NULL
,
&
proc_doulongvec_minmax
},
{
ABI_TRACE
,
"trace"
,
&
abi_traceflg
,
sizeof
(
u_int
),
0644
,
NULL
,
&
proc_dointvec
},
{
ABI_FAKE_UTSNAME
,
"fake_utsname"
,
&
abi_fake_utsname
,
sizeof
(
int
),
0644
,
NULL
,
&
proc_dointvec
},
{
0
}
{
.
ctl_name
=
ABI_DEFHANDLER_COFF
,
.
procname
=
"defhandler_coff"
,
.
data
=
&
abi_defhandler_coff
,
.
maxlen
=
sizeof
(
int
),
.
mode
=
0644
,
.
proc_handler
=
&
proc_doulongvec_minmax
,
},
{
.
ctl_name
=
ABI_DEFHANDLER_ELF
,
.
procname
=
"defhandler_elf"
,
.
data
=
&
abi_defhandler_elf
,
.
maxlen
=
sizeof
(
int
),
.
mode
=
0644
,
.
proc_handler
=
&
proc_doulongvec_minmax
,
},
{
.
ctl_name
=
ABI_DEFHANDLER_LCALL7
,
.
procname
=
"defhandler_lcall7"
,
.
data
=
&
abi_defhandler_lcall7
,
.
maxlen
=
sizeof
(
int
),
.
mode
=
0644
,
.
proc_handler
=
&
proc_doulongvec_minmax
,
},
{
.
ctl_name
=
ABI_DEFHANDLER_LIBCSO
,
.
procname
=
"defhandler_libcso"
,
.
data
=
&
abi_defhandler_libcso
,
.
maxlen
=
sizeof
(
int
),
.
mode
=
0644
,
.
proc_handler
=
&
proc_doulongvec_minmax
,
},
{
.
ctl_name
=
ABI_TRACE
,
.
procname
=
"trace"
,
.
data
=
&
abi_traceflg
,
.
maxlen
=
sizeof
(
u_int
),
.
mode
=
0644
,
.
proc_handler
=
&
proc_dointvec
,
},
{
.
ctl_name
=
ABI_FAKE_UTSNAME
,
.
procname
=
"fake_utsname"
,
.
data
=
&
abi_fake_utsname
,
.
maxlen
=
sizeof
(
int
),
.
mode
=
0644
,
.
proc_handler
=
&
proc_dointvec
,
},
{
.
ctl_name
=
0
}
};
static
struct
ctl_table
abi_root_table
[]
=
{
{
CTL_ABI
,
"abi"
,
NULL
,
0
,
0555
,
abi_table
},
{
0
}
{
.
ctl_name
=
CTL_ABI
,
.
procname
=
"abi"
,
.
mode
=
0555
,
.
child
=
abi_table
,
},
{
.
ctl_name
=
0
}
};
static
int
__init
...
...
kernel/resource.c
View file @
c2e2d4f7
...
...
@@ -20,8 +20,19 @@
#include <asm/io.h>
struct
resource
ioport_resource
=
{
"PCI IO"
,
0x0000
,
IO_SPACE_LIMIT
,
IORESOURCE_IO
};
struct
resource
iomem_resource
=
{
"PCI mem"
,
0UL
,
~
0UL
,
IORESOURCE_MEM
};
struct
resource
ioport_resource
=
{
.
name
=
"PCI IO"
,
.
start
=
0x0000
,
.
end
=
IO_SPACE_LIMIT
,
.
flags
=
IORESOURCE_IO
,
};
struct
resource
iomem_resource
=
{
.
name
=
"PCI mem"
,
.
start
=
0UL
,
.
end
=
~
0UL
,
.
flags
=
IORESOURCE_MEM
,
};
static
rwlock_t
resource_lock
=
RW_LOCK_UNLOCKED
;
...
...
kernel/sysctl.c
View file @
c2e2d4f7
...
...
@@ -149,123 +149,408 @@ static void unregister_proc_table(ctl_table *, struct proc_dir_entry *);
/* The default sysctl tables: */
static
ctl_table
root_table
[]
=
{
{
CTL_KERN
,
"kernel"
,
NULL
,
0
,
0555
,
kern_table
},
{
CTL_VM
,
"vm"
,
NULL
,
0
,
0555
,
vm_table
},
{
.
ctl_name
=
CTL_KERN
,
.
procname
=
"kernel"
,
.
mode
=
0555
,
.
child
=
kern_table
,
},
{
.
ctl_name
=
CTL_VM
,
.
procname
=
"vm"
,
.
mode
=
0555
,
.
child
=
vm_table
,
},
#ifdef CONFIG_NET
{
CTL_NET
,
"net"
,
NULL
,
0
,
0555
,
net_table
},
{
.
ctl_name
=
CTL_NET
,
.
procname
=
"net"
,
.
mode
=
0555
,
.
child
=
net_table
,
},
#endif
{
CTL_PROC
,
"proc"
,
NULL
,
0
,
0555
,
proc_table
},
{
CTL_FS
,
"fs"
,
NULL
,
0
,
0555
,
fs_table
},
{
CTL_DEBUG
,
"debug"
,
NULL
,
0
,
0555
,
debug_table
},
{
CTL_DEV
,
"dev"
,
NULL
,
0
,
0555
,
dev_table
},
{
0
}
{
.
ctl_name
=
CTL_PROC
,
.
procname
=
"proc"
,
.
mode
=
0555
,
.
child
=
proc_table
,
},
{
.
ctl_name
=
CTL_FS
,
.
procname
=
"fs"
,
.
mode
=
0555
,
.
child
=
fs_table
,
},
{
.
ctl_name
=
CTL_DEBUG
,
.
procname
=
"debug"
,
.
mode
=
0555
,
.
child
=
debug_table
,
},
{
.
ctl_name
=
CTL_DEV
,
.
procname
=
"dev"
,
.
mode
=
0555
,
.
child
=
dev_table
,
},
{
.
ctl_name
=
0
}
};
static
ctl_table
kern_table
[]
=
{
{
KERN_OSTYPE
,
"ostype"
,
system_utsname
.
sysname
,
64
,
0444
,
NULL
,
&
proc_doutsstring
,
&
sysctl_string
},
{
KERN_OSRELEASE
,
"osrelease"
,
system_utsname
.
release
,
64
,
0444
,
NULL
,
&
proc_doutsstring
,
&
sysctl_string
},
{
KERN_VERSION
,
"version"
,
system_utsname
.
version
,
64
,
0444
,
NULL
,
&
proc_doutsstring
,
&
sysctl_string
},
{
KERN_NODENAME
,
"hostname"
,
system_utsname
.
nodename
,
64
,
0644
,
NULL
,
&
proc_doutsstring
,
&
sysctl_string
},
{
KERN_DOMAINNAME
,
"domainname"
,
system_utsname
.
domainname
,
64
,
0644
,
NULL
,
&
proc_doutsstring
,
&
sysctl_string
},
{
KERN_PANIC
,
"panic"
,
&
panic_timeout
,
sizeof
(
int
),
0644
,
NULL
,
&
proc_dointvec
},
{
KERN_CORE_USES_PID
,
"core_uses_pid"
,
&
core_uses_pid
,
sizeof
(
int
),
0644
,
NULL
,
&
proc_dointvec
},
{
KERN_CORE_PATTERN
,
"core_pattern"
,
core_pattern
,
64
,
0644
,
NULL
,
&
proc_dostring
,
&
sysctl_string
},
{
KERN_TAINTED
,
"tainted"
,
&
tainted
,
sizeof
(
int
),
0644
,
NULL
,
&
proc_dointvec
},
{
KERN_CAP_BSET
,
"cap-bound"
,
&
cap_bset
,
sizeof
(
kernel_cap_t
),
0600
,
NULL
,
&
proc_dointvec_bset
},
{
.
ctl_name
=
KERN_OSTYPE
,
.
procname
=
"ostype"
,
.
data
=
system_utsname
.
sysname
,
.
maxlen
=
64
,
.
mode
=
0444
,
.
proc_handler
=
&
proc_doutsstring
,
.
strategy
=
&
sysctl_string
,
},
{
.
ctl_name
=
KERN_OSRELEASE
,
.
procname
=
"osrelease"
,
.
data
=
system_utsname
.
release
,
.
maxlen
=
64
,
.
mode
=
0444
,
.
proc_handler
=
&
proc_doutsstring
,
.
strategy
=
&
sysctl_string
,
},
{
.
ctl_name
=
KERN_VERSION
,
.
procname
=
"version"
,
.
data
=
system_utsname
.
version
,
.
maxlen
=
64
,
.
mode
=
0444
,
.
proc_handler
=
&
proc_doutsstring
,
.
strategy
=
&
sysctl_string
,
},
{
.
ctl_name
=
KERN_NODENAME
,
.
procname
=
"hostname"
,
.
data
=
system_utsname
.
nodename
,
.
maxlen
=
64
,
.
mode
=
0644
,
.
proc_handler
=
&
proc_doutsstring
,
.
strategy
=
&
sysctl_string
,
},
{
.
ctl_name
=
KERN_DOMAINNAME
,
.
procname
=
"domainname"
,
.
data
=
system_utsname
.
domainname
,
.
maxlen
=
64
,
.
mode
=
0644
,
.
proc_handler
=
&
proc_doutsstring
,
.
strategy
=
&
sysctl_string
,
},
{
.
ctl_name
=
KERN_PANIC
,
.
procname
=
"panic"
,
.
data
=
&
panic_timeout
,
.
maxlen
=
sizeof
(
int
),
.
mode
=
0644
,
.
proc_handler
=
&
proc_dointvec
,
},
{
.
ctl_name
=
KERN_CORE_USES_PID
,
.
procname
=
"core_uses_pid"
,
.
data
=
&
core_uses_pid
,
.
maxlen
=
sizeof
(
int
),
.
mode
=
0644
,
.
proc_handler
=
&
proc_dointvec
,
},
{
.
ctl_name
=
KERN_CORE_PATTERN
,
.
procname
=
"core_pattern"
,
.
data
=
core_pattern
,
.
maxlen
=
64
,
.
mode
=
0644
,
.
proc_handler
=
&
proc_dostring
,
.
strategy
=
&
sysctl_string
,
},
{
.
ctl_name
=
KERN_TAINTED
,
.
procname
=
"tainted"
,
.
data
=
&
tainted
,
.
maxlen
=
sizeof
(
int
),
.
mode
=
0644
,
.
proc_handler
=
&
proc_dointvec
,
},
{
.
ctl_name
=
KERN_CAP_BSET
,
.
procname
=
"cap-bound"
,
.
data
=
&
cap_bset
,
.
maxlen
=
sizeof
(
kernel_cap_t
),
.
mode
=
0600
,
.
proc_handler
=
&
proc_dointvec_bset
,
},
#ifdef CONFIG_BLK_DEV_INITRD
{
KERN_REALROOTDEV
,
"real-root-dev"
,
&
real_root_dev
,
sizeof
(
int
),
0644
,
NULL
,
&
proc_dointvec
},
{
.
ctl_name
=
KERN_REALROOTDEV
,
.
procname
=
"real-root-dev"
,
.
data
=
&
real_root_dev
,
.
maxlen
=
sizeof
(
int
),
.
mode
=
0644
,
.
proc_handler
=
&
proc_dointvec
,
},
#endif
#ifdef __sparc__
{
KERN_SPARC_REBOOT
,
"reboot-cmd"
,
reboot_command
,
256
,
0644
,
NULL
,
&
proc_dostring
,
&
sysctl_string
},
{
KERN_SPARC_STOP_A
,
"stop-a"
,
&
stop_a_enabled
,
sizeof
(
int
),
0644
,
NULL
,
&
proc_dointvec
},
{
.
ctl_name
=
KERN_SPARC_REBOOT
,
.
procname
=
"reboot-cmd"
,
.
data
=
reboot_command
,
.
maxlen
=
256
,
.
mode
=
0644
,
.
proc_handler
=
&
proc_dostring
,
.
strategy
=
&
sysctl_string
,
},
{
.
ctl_name
=
KERN_SPARC_STOP_A
,
.
procname
=
"stop-a"
,
.
data
=
&
stop_a_enabled
,
.
maxlen
=
sizeof
(
int
),
.
mode
=
0644
,
.
proc_handler
=
&
proc_dointvec
,
},
#endif
#if defined(CONFIG_PPC32) && defined(CONFIG_6xx)
{
KERN_PPC_POWERSAVE_NAP
,
"powersave-nap"
,
&
powersave_nap
,
sizeof
(
int
),
0644
,
NULL
,
&
proc_dointvec
},
{
KERN_PPC_L2CR
,
"l2cr"
,
NULL
,
0
,
0644
,
NULL
,
&
proc_dol2crvec
},
{
.
ctl_name
=
KERN_PPC_POWERSAVE_NAP
,
.
procname
=
"powersave-nap"
,
.
data
=
&
powersave_nap
,
.
maxlen
=
sizeof
(
int
),
.
mode
=
0644
,
.
proc_handler
=
&
proc_dointvec
,
},
{
.
ctl_name
=
KERN_PPC_L2CR
,
.
procname
=
"l2cr"
,
.
mode
=
0644
,
.
proc_handler
=
&
proc_dol2crvec
,
},
#endif
{
KERN_CTLALTDEL
,
"ctrl-alt-del"
,
&
C_A_D
,
sizeof
(
int
),
0644
,
NULL
,
&
proc_dointvec
},
{
KERN_PRINTK
,
"printk"
,
&
console_loglevel
,
4
*
sizeof
(
int
),
0644
,
NULL
,
&
proc_dointvec
},
{
.
ctl_name
=
KERN_CTLALTDEL
,
.
procname
=
"ctrl-alt-del"
,
.
data
=
&
C_A_D
,
.
maxlen
=
sizeof
(
int
),
.
mode
=
0644
,
.
proc_handler
=
&
proc_dointvec
,
},
{
.
ctl_name
=
KERN_PRINTK
,
.
procname
=
"printk"
,
.
data
=
&
console_loglevel
,
.
maxlen
=
4
*
sizeof
(
int
),
.
mode
=
0644
,
.
proc_handler
=
&
proc_dointvec
,
},
#ifdef CONFIG_KMOD
{
KERN_MODPROBE
,
"modprobe"
,
&
modprobe_path
,
256
,
0644
,
NULL
,
&
proc_dostring
,
&
sysctl_string
},
{
.
ctl_name
=
KERN_MODPROBE
,
.
procname
=
"modprobe"
,
.
data
=
&
modprobe_path
,
.
maxlen
=
256
,
.
mode
=
0644
,
.
proc_handler
=
&
proc_dostring
,
.
strategy
=
&
sysctl_string
,
},
#endif
#ifdef CONFIG_HOTPLUG
{
KERN_HOTPLUG
,
"hotplug"
,
&
hotplug_path
,
256
,
0644
,
NULL
,
&
proc_dostring
,
&
sysctl_string
},
{
.
ctl_name
=
KERN_HOTPLUG
,
.
procname
=
"hotplug"
,
.
data
=
&
hotplug_path
,
.
maxlen
=
256
,
.
mode
=
0644
,
.
proc_handler
=
&
proc_dostring
,
.
strategy
=
&
sysctl_string
,
},
#endif
#ifdef CONFIG_CHR_DEV_SG
{
KERN_SG_BIG_BUFF
,
"sg-big-buff"
,
&
sg_big_buff
,
sizeof
(
int
),
0444
,
NULL
,
&
proc_dointvec
},
{
.
ctl_name
=
KERN_SG_BIG_BUFF
,
.
procname
=
"sg-big-buff"
,
.
data
=
&
sg_big_buff
,
.
maxlen
=
sizeof
(
int
),
.
mode
=
0444
,
.
proc_handler
=
&
proc_dointvec
,
},
#endif
#ifdef CONFIG_BSD_PROCESS_ACCT
{
KERN_ACCT
,
"acct"
,
&
acct_parm
,
3
*
sizeof
(
int
),
0644
,
NULL
,
&
proc_dointvec
},
{
.
ctl_name
=
KERN_ACCT
,
.
procname
=
"acct"
,
.
data
=
&
acct_parm
,
.
maxlen
=
3
*
sizeof
(
int
),
.
mode
=
0644
,
.
proc_handler
=
&
proc_dointvec
,
},
#endif
{
KERN_RTSIGNR
,
"rtsig-nr"
,
&
nr_queued_signals
,
sizeof
(
int
),
0444
,
NULL
,
&
proc_dointvec
},
{
KERN_RTSIGMAX
,
"rtsig-max"
,
&
max_queued_signals
,
sizeof
(
int
),
0644
,
NULL
,
&
proc_dointvec
},
{
.
ctl_name
=
KERN_RTSIGNR
,
.
procname
=
"rtsig-nr"
,
.
data
=
&
nr_queued_signals
,
.
maxlen
=
sizeof
(
int
),
.
mode
=
0444
,
.
proc_handler
=
&
proc_dointvec
,
},
{
.
ctl_name
=
KERN_RTSIGMAX
,
.
procname
=
"rtsig-max"
,
.
data
=
&
max_queued_signals
,
.
maxlen
=
sizeof
(
int
),
.
mode
=
0644
,
.
proc_handler
=
&
proc_dointvec
,
},
#ifdef CONFIG_SYSVIPC
{
KERN_SHMMAX
,
"shmmax"
,
&
shm_ctlmax
,
sizeof
(
size_t
),
0644
,
NULL
,
&
proc_doulongvec_minmax
},
{
KERN_SHMALL
,
"shmall"
,
&
shm_ctlall
,
sizeof
(
size_t
),
0644
,
NULL
,
&
proc_doulongvec_minmax
},
{
KERN_SHMMNI
,
"shmmni"
,
&
shm_ctlmni
,
sizeof
(
int
),
0644
,
NULL
,
&
proc_dointvec
},
{
KERN_MSGMAX
,
"msgmax"
,
&
msg_ctlmax
,
sizeof
(
int
),
0644
,
NULL
,
&
proc_dointvec
},
{
KERN_MSGMNI
,
"msgmni"
,
&
msg_ctlmni
,
sizeof
(
int
),
0644
,
NULL
,
&
proc_dointvec
},
{
KERN_MSGMNB
,
"msgmnb"
,
&
msg_ctlmnb
,
sizeof
(
int
),
0644
,
NULL
,
&
proc_dointvec
},
{
KERN_SEM
,
"sem"
,
&
sem_ctls
,
4
*
sizeof
(
int
),
0644
,
NULL
,
&
proc_dointvec
},
{
.
ctl_name
=
KERN_SHMMAX
,
.
procname
=
"shmmax"
,
.
data
=
&
shm_ctlmax
,
.
maxlen
=
sizeof
(
size_t
),
.
mode
=
0644
,
.
proc_handler
=
&
proc_doulongvec_minmax
,
},
{
.
ctl_name
=
KERN_SHMALL
,
.
procname
=
"shmall"
,
.
data
=
&
shm_ctlall
,
.
maxlen
=
sizeof
(
size_t
),
.
mode
=
0644
,
.
proc_handler
=
&
proc_doulongvec_minmax
,
},
{
.
ctl_name
=
KERN_SHMMNI
,
.
procname
=
"shmmni"
,
.
data
=
&
shm_ctlmni
,
.
maxlen
=
sizeof
(
int
),
.
mode
=
0644
,
.
proc_handler
=
&
proc_dointvec
,
},
{
.
ctl_name
=
KERN_MSGMAX
,
.
procname
=
"msgmax"
,
.
data
=
&
msg_ctlmax
,
.
maxlen
=
sizeof
(
int
),
.
mode
=
0644
,
.
proc_handler
=
&
proc_dointvec
,
},
{
.
ctl_name
=
KERN_MSGMNI
,
.
procname
=
"msgmni"
,
.
data
=
&
msg_ctlmni
,
.
maxlen
=
sizeof
(
int
),
.
mode
=
0644
,
.
proc_handler
=
&
proc_dointvec
,
},
{
.
ctl_name
=
KERN_MSGMNB
,
.
procname
=
"msgmnb"
,
.
data
=
&
msg_ctlmnb
,
.
maxlen
=
sizeof
(
int
),
.
mode
=
0644
,
.
proc_handler
=
&
proc_dointvec
,
},
{
.
ctl_name
=
KERN_SEM
,
.
procname
=
"sem"
,
.
data
=
&
sem_ctls
,
.
maxlen
=
4
*
sizeof
(
int
),
.
mode
=
0644
,
.
proc_handler
=
&
proc_dointvec
,
},
#endif
#ifdef CONFIG_MAGIC_SYSRQ
{
KERN_SYSRQ
,
"sysrq"
,
&
sysrq_enabled
,
sizeof
(
int
),
0644
,
NULL
,
&
proc_dointvec
},
#endif
{
KERN_CADPID
,
"cad_pid"
,
&
cad_pid
,
sizeof
(
int
),
0600
,
NULL
,
&
proc_dointvec
},
{
KERN_MAX_THREADS
,
"threads-max"
,
&
max_threads
,
sizeof
(
int
),
0644
,
NULL
,
&
proc_dointvec
},
{
KERN_RANDOM
,
"random"
,
NULL
,
0
,
0555
,
random_table
},
{
KERN_OVERFLOWUID
,
"overflowuid"
,
&
overflowuid
,
sizeof
(
int
),
0644
,
NULL
,
&
proc_dointvec_minmax
,
&
sysctl_intvec
,
NULL
,
&
minolduid
,
&
maxolduid
},
{
KERN_OVERFLOWGID
,
"overflowgid"
,
&
overflowgid
,
sizeof
(
int
),
0644
,
NULL
,
&
proc_dointvec_minmax
,
&
sysctl_intvec
,
NULL
,
&
minolduid
,
&
maxolduid
},
{
.
ctl_name
=
KERN_SYSRQ
,
.
procname
=
"sysrq"
,
.
data
=
&
sysrq_enabled
,
.
maxlen
=
sizeof
(
int
),
.
mode
=
0644
,
.
proc_handler
=
&
proc_dointvec
,
},
#endif
{
.
ctl_name
=
KERN_CADPID
,
.
procname
=
"cad_pid"
,
.
data
=
&
cad_pid
,
.
maxlen
=
sizeof
(
int
),
.
mode
=
0600
,
.
proc_handler
=
&
proc_dointvec
,
},
{
.
ctl_name
=
KERN_MAX_THREADS
,
.
procname
=
"threads-max"
,
.
data
=
&
max_threads
,
.
maxlen
=
sizeof
(
int
),
.
mode
=
0644
,
.
proc_handler
=
&
proc_dointvec
,
},
{
.
ctl_name
=
KERN_RANDOM
,
.
procname
=
"random"
,
.
mode
=
0555
,
.
child
=
random_table
,
},
{
.
ctl_name
=
KERN_OVERFLOWUID
,
.
procname
=
"overflowuid"
,
.
data
=
&
overflowuid
,
.
maxlen
=
sizeof
(
int
),
.
mode
=
0644
,
.
proc_handler
=
&
proc_dointvec_minmax
,
.
strategy
=
&
sysctl_intvec
,
.
extra1
=
&
minolduid
,
.
extra2
=
&
maxolduid
,
},
{
.
ctl_name
=
KERN_OVERFLOWGID
,
.
procname
=
"overflowgid"
,
.
data
=
&
overflowgid
,
.
maxlen
=
sizeof
(
int
),
.
mode
=
0644
,
.
proc_handler
=
&
proc_dointvec_minmax
,
.
strategy
=
&
sysctl_intvec
,
.
extra1
=
&
minolduid
,
.
extra2
=
&
maxolduid
,
},
#ifdef CONFIG_ARCH_S390
#ifdef CONFIG_MATHEMU
{
KERN_IEEE_EMULATION_WARNINGS
,
"ieee_emulation_warnings"
,
&
sysctl_ieee_emulation_warnings
,
sizeof
(
int
),
0644
,
NULL
,
&
proc_dointvec
},
{
.
ctl_name
=
KERN_IEEE_EMULATION_WARNINGS
,
.
procname
=
"ieee_emulation_warnings"
,
.
data
=
&
sysctl_ieee_emulation_warnings
,
.
maxlen
=
sizeof
(
int
),
.
mode
=
0644
,
.
proc_handler
=
&
proc_dointvec
,
},
#endif
{
KERN_S390_USER_DEBUG_LOGGING
,
"userprocess_debug"
,
&
sysctl_userprocess_debug
,
sizeof
(
int
),
0644
,
NULL
,
&
proc_dointvec
},
{
.
ctl_name
=
KERN_S390_USER_DEBUG_LOGGING
,
.
procname
=
"userprocess_debug"
,
.
data
=
&
sysctl_userprocess_debug
,
.
maxlen
=
sizeof
(
int
),
.
mode
=
0644
,
.
proc_handler
=
&
proc_dointvec
,
},
#endif
{
KERN_PIDMAX
,
"pid_max"
,
&
pid_max
,
sizeof
(
int
),
0600
,
NULL
,
&
proc_dointvec
},
{
KERN_PANIC_ON_OOPS
,
"panic_on_oops"
,
&
panic_on_oops
,
sizeof
(
int
),
0644
,
NULL
,
&
proc_dointvec
},
{
0
}
{
.
ctl_name
=
KERN_PIDMAX
,
.
procname
=
"pid_max"
,
.
data
=
&
pid_max
,
.
maxlen
=
sizeof
(
int
),
.
mode
=
0600
,
.
proc_handler
=
&
proc_dointvec
,
},
{
.
ctl_name
=
KERN_PANIC_ON_OOPS
,
.
procname
=
"panic_on_oops"
,
.
data
=
&
panic_on_oops
,
.
maxlen
=
sizeof
(
int
),
.
mode
=
0644
,
.
proc_handler
=
&
proc_dointvec
,
},
{
.
ctl_name
=
0
}
};
/* Constants for minimum and maximum testing in vm_table.
...
...
@@ -275,79 +560,210 @@ static int one_hundred = 100;
static
ctl_table
vm_table
[]
=
{
{
VM_OVERCOMMIT_MEMORY
,
"overcommit_memory"
,
&
sysctl_overcommit_memory
,
sizeof
(
sysctl_overcommit_memory
),
0644
,
NULL
,
&
proc_dointvec
},
{
VM_OVERCOMMIT_RATIO
,
"overcommit_ratio"
,
&
sysctl_overcommit_ratio
,
sizeof
(
sysctl_overcommit_ratio
),
0644
,
NULL
,
&
proc_dointvec
},
{
VM_PAGE_CLUSTER
,
"page-cluster"
,
&
page_cluster
,
sizeof
(
int
),
0644
,
NULL
,
&
proc_dointvec
},
{
VM_DIRTY_BACKGROUND
,
"dirty_background_ratio"
,
&
dirty_background_ratio
,
sizeof
(
dirty_background_ratio
),
0644
,
NULL
,
&
proc_dointvec_minmax
,
&
sysctl_intvec
,
NULL
,
&
zero
,
&
one_hundred
},
{
VM_DIRTY_RATIO
,
"dirty_ratio"
,
&
vm_dirty_ratio
,
sizeof
(
vm_dirty_ratio
),
0644
,
NULL
,
&
proc_dointvec_minmax
,
&
sysctl_intvec
,
NULL
,
&
zero
,
&
one_hundred
},
{
VM_DIRTY_WB_CS
,
"dirty_writeback_centisecs"
,
&
dirty_writeback_centisecs
,
sizeof
(
dirty_writeback_centisecs
),
0644
,
NULL
,
dirty_writeback_centisecs_handler
},
{
VM_DIRTY_EXPIRE_CS
,
"dirty_expire_centisecs"
,
&
dirty_expire_centisecs
,
sizeof
(
dirty_expire_centisecs
),
0644
,
NULL
,
&
proc_dointvec
},
{
VM_NR_PDFLUSH_THREADS
,
"nr_pdflush_threads"
,
&
nr_pdflush_threads
,
sizeof
nr_pdflush_threads
,
0444
/* read-only*/
,
NULL
,
&
proc_dointvec
},
{
VM_SWAPPINESS
,
"swappiness"
,
&
vm_swappiness
,
sizeof
(
vm_swappiness
),
0644
,
NULL
,
&
proc_dointvec_minmax
,
&
sysctl_intvec
,
NULL
,
&
zero
,
&
one_hundred
},
{
.
ctl_name
=
VM_OVERCOMMIT_MEMORY
,
.
procname
=
"overcommit_memory"
,
.
data
=
&
sysctl_overcommit_memory
,
.
maxlen
=
sizeof
(
sysctl_overcommit_memory
),
.
mode
=
0644
,
.
proc_handler
=
&
proc_dointvec
,
},
{
.
ctl_name
=
VM_OVERCOMMIT_RATIO
,
.
procname
=
"overcommit_ratio"
,
.
data
=
&
sysctl_overcommit_ratio
,
.
maxlen
=
sizeof
(
sysctl_overcommit_ratio
),
.
mode
=
0644
,
.
proc_handler
=
&
proc_dointvec
,
},
{
.
ctl_name
=
VM_PAGE_CLUSTER
,
.
procname
=
"page-cluster"
,
.
data
=
&
page_cluster
,
.
maxlen
=
sizeof
(
int
),
.
mode
=
0644
,
.
proc_handler
=
&
proc_dointvec
,
},
{
.
ctl_name
=
VM_DIRTY_BACKGROUND
,
.
procname
=
"dirty_background_ratio"
,
.
data
=
&
dirty_background_ratio
,
.
maxlen
=
sizeof
(
dirty_background_ratio
),
.
mode
=
0644
,
.
proc_handler
=
&
proc_dointvec_minmax
,
.
strategy
=
&
sysctl_intvec
,
.
extra1
=
&
zero
,
.
extra2
=
&
one_hundred
,
},
{
.
ctl_name
=
VM_DIRTY_RATIO
,
.
procname
=
"dirty_ratio"
,
.
data
=
&
vm_dirty_ratio
,
.
maxlen
=
sizeof
(
vm_dirty_ratio
),
.
mode
=
0644
,
.
proc_handler
=
&
proc_dointvec_minmax
,
.
strategy
=
&
sysctl_intvec
,
.
extra1
=
&
zero
,
.
extra2
=
&
one_hundred
,
},
{
.
ctl_name
=
VM_DIRTY_WB_CS
,
.
procname
=
"dirty_writeback_centisecs"
,
.
data
=
&
dirty_writeback_centisecs
,
.
maxlen
=
sizeof
(
dirty_writeback_centisecs
),
.
mode
=
0644
,
.
proc_handler
=
dirty_writeback_centisecs_handler
,
},
{
.
ctl_name
=
VM_DIRTY_EXPIRE_CS
,
.
procname
=
"dirty_expire_centisecs"
,
.
data
=
&
dirty_expire_centisecs
,
.
maxlen
=
sizeof
(
dirty_expire_centisecs
),
.
mode
=
0644
,
.
proc_handler
=
&
proc_dointvec
,
},
{
.
ctl_name
=
VM_NR_PDFLUSH_THREADS
,
.
procname
=
"nr_pdflush_threads"
,
.
data
=
&
nr_pdflush_threads
,
.
maxlen
=
sizeof
nr_pdflush_threads
,
.
mode
=
0444
/* read-only*/
,
.
proc_handler
=
&
proc_dointvec
,
},
{
.
ctl_name
=
VM_SWAPPINESS
,
.
procname
=
"swappiness"
,
.
data
=
&
vm_swappiness
,
.
maxlen
=
sizeof
(
vm_swappiness
),
.
mode
=
0644
,
.
proc_handler
=
&
proc_dointvec_minmax
,
.
strategy
=
&
sysctl_intvec
,
.
extra1
=
&
zero
,
.
extra2
=
&
one_hundred
,
},
#ifdef CONFIG_HUGETLB_PAGE
{
VM_HUGETLB_PAGES
,
"nr_hugepages"
,
&
htlbpage_max
,
sizeof
(
int
),
0644
,
NULL
,
&
hugetlb_sysctl_handler
},
{
.
ctl_name
=
VM_HUGETLB_PAGES
,
.
procname
=
"nr_hugepages"
,
.
data
=
&
htlbpage_max
,
.
maxlen
=
sizeof
(
int
),
.
mode
=
0644
,
.
proc_handler
=
&
hugetlb_sysctl_handler
,
},
#endif
{
VM_LOWER_ZONE_PROTECTION
,
"lower_zone_protection"
,
&
sysctl_lower_zone_protection
,
sizeof
(
sysctl_lower_zone_protection
),
0644
,
NULL
,
&
proc_dointvec_minmax
,
&
sysctl_intvec
,
NULL
,
&
zero
,
NULL
,
},
{
0
}
{
.
ctl_name
=
VM_LOWER_ZONE_PROTECTION
,
.
procname
=
"lower_zone_protection"
,
.
data
=
&
sysctl_lower_zone_protection
,
.
maxlen
=
sizeof
(
sysctl_lower_zone_protection
),
.
mode
=
0644
,
.
proc_handler
=
&
proc_dointvec_minmax
,
.
strategy
=
&
sysctl_intvec
,
.
extra1
=
&
zero
,
},
{
.
ctl_name
=
0
}
};
static
ctl_table
proc_table
[]
=
{
{
0
}
{
.
ctl_name
=
0
}
};
static
ctl_table
fs_table
[]
=
{
{
FS_NRINODE
,
"inode-nr"
,
&
inodes_stat
,
2
*
sizeof
(
int
),
0444
,
NULL
,
&
proc_dointvec
},
{
FS_STATINODE
,
"inode-state"
,
&
inodes_stat
,
7
*
sizeof
(
int
),
0444
,
NULL
,
&
proc_dointvec
},
{
FS_NRFILE
,
"file-nr"
,
&
files_stat
,
3
*
sizeof
(
int
),
0444
,
NULL
,
&
proc_dointvec
},
{
FS_MAXFILE
,
"file-max"
,
&
files_stat
.
max_files
,
sizeof
(
int
),
0644
,
NULL
,
&
proc_dointvec
},
{
FS_DENTRY
,
"dentry-state"
,
&
dentry_stat
,
6
*
sizeof
(
int
),
0444
,
NULL
,
&
proc_dointvec
},
{
FS_OVERFLOWUID
,
"overflowuid"
,
&
fs_overflowuid
,
sizeof
(
int
),
0644
,
NULL
,
&
proc_dointvec_minmax
,
&
sysctl_intvec
,
NULL
,
&
minolduid
,
&
maxolduid
},
{
FS_OVERFLOWGID
,
"overflowgid"
,
&
fs_overflowgid
,
sizeof
(
int
),
0644
,
NULL
,
&
proc_dointvec_minmax
,
&
sysctl_intvec
,
NULL
,
&
minolduid
,
&
maxolduid
},
{
FS_LEASES
,
"leases-enable"
,
&
leases_enable
,
sizeof
(
int
),
0644
,
NULL
,
&
proc_dointvec
},
{
FS_DIR_NOTIFY
,
"dir-notify-enable"
,
&
dir_notify_enable
,
sizeof
(
int
),
0644
,
NULL
,
&
proc_dointvec
},
{
FS_LEASE_TIME
,
"lease-break-time"
,
&
lease_break_time
,
sizeof
(
int
),
0644
,
NULL
,
&
proc_dointvec
},
{
0
}
{
.
ctl_name
=
FS_NRINODE
,
.
procname
=
"inode-nr"
,
.
data
=
&
inodes_stat
,
.
maxlen
=
2
*
sizeof
(
int
),
.
mode
=
0444
,
.
proc_handler
=
&
proc_dointvec
,
},
{
.
ctl_name
=
FS_STATINODE
,
.
procname
=
"inode-state"
,
.
data
=
&
inodes_stat
,
.
maxlen
=
7
*
sizeof
(
int
),
.
mode
=
0444
,
.
proc_handler
=
&
proc_dointvec
,
},
{
.
ctl_name
=
FS_NRFILE
,
.
procname
=
"file-nr"
,
.
data
=
&
files_stat
,
.
maxlen
=
3
*
sizeof
(
int
),
.
mode
=
0444
,
.
proc_handler
=
&
proc_dointvec
,
},
{
.
ctl_name
=
FS_MAXFILE
,
.
procname
=
"file-max"
,
.
data
=
&
files_stat
.
max_files
,
.
maxlen
=
sizeof
(
int
),
.
mode
=
0644
,
.
proc_handler
=
&
proc_dointvec
,
},
{
.
ctl_name
=
FS_DENTRY
,
.
procname
=
"dentry-state"
,
.
data
=
&
dentry_stat
,
.
maxlen
=
6
*
sizeof
(
int
),
.
mode
=
0444
,
.
proc_handler
=
&
proc_dointvec
,
},
{
.
ctl_name
=
FS_OVERFLOWUID
,
.
procname
=
"overflowuid"
,
.
data
=
&
fs_overflowuid
,
.
maxlen
=
sizeof
(
int
),
.
mode
=
0644
,
.
proc_handler
=
&
proc_dointvec_minmax
,
.
strategy
=
&
sysctl_intvec
,
.
extra1
=
&
minolduid
,
.
extra2
=
&
maxolduid
,
},
{
.
ctl_name
=
FS_OVERFLOWGID
,
.
procname
=
"overflowgid"
,
.
data
=
&
fs_overflowgid
,
.
maxlen
=
sizeof
(
int
),
.
mode
=
0644
,
.
proc_handler
=
&
proc_dointvec_minmax
,
.
strategy
=
&
sysctl_intvec
,
.
extra1
=
&
minolduid
,
.
extra2
=
&
maxolduid
,
},
{
.
ctl_name
=
FS_LEASES
,
.
procname
=
"leases-enable"
,
.
data
=
&
leases_enable
,
.
maxlen
=
sizeof
(
int
),
.
mode
=
0644
,
.
proc_handler
=
&
proc_dointvec
,
},
{
.
ctl_name
=
FS_DIR_NOTIFY
,
.
procname
=
"dir-notify-enable"
,
.
data
=
&
dir_notify_enable
,
.
maxlen
=
sizeof
(
int
),
.
mode
=
0644
,
.
proc_handler
=
&
proc_dointvec
,
},
{
.
ctl_name
=
FS_LEASE_TIME
,
.
procname
=
"lease-break-time"
,
.
data
=
&
lease_break_time
,
.
maxlen
=
sizeof
(
int
),
.
mode
=
0644
,
.
proc_handler
=
&
proc_dointvec
,
},
{
.
ctl_name
=
0
}
};
static
ctl_table
debug_table
[]
=
{
{
0
}
{
.
ctl_name
=
0
}
};
static
ctl_table
dev_table
[]
=
{
{
0
}
{
.
ctl_name
=
0
}
};
extern
void
init_irq_proc
(
void
);
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment