Move the sysctls of the misalignment handler to where they belong

and use OID_AUTO instead of fixed IDs.

Approved by: re@ (blanket)
This commit is contained in:
marcel 2003-05-29 06:30:36 +00:00
parent c050190f48
commit 355d7ef9c5
3 changed files with 18 additions and 26 deletions

View File

@ -124,19 +124,6 @@ SYSCTL_STRING(_hw, HW_MODEL, model, CTLFLAG_RD, cpu_model, 0, "");
void *ksym_start, *ksym_end; void *ksym_start, *ksym_end;
#endif #endif
int ia64_unaligned_print = 1; /* warn about unaligned accesses */
int ia64_unaligned_fix = 1; /* fix up unaligned accesses */
int ia64_unaligned_sigbus = 0; /* don't SIGBUS on fixed-up accesses */
SYSCTL_INT(_machdep, CPU_UNALIGNED_PRINT, unaligned_print,
CTLFLAG_RW, &ia64_unaligned_print, 0, "");
SYSCTL_INT(_machdep, CPU_UNALIGNED_FIX, unaligned_fix,
CTLFLAG_RW, &ia64_unaligned_fix, 0, "");
SYSCTL_INT(_machdep, CPU_UNALIGNED_SIGBUS, unaligned_sigbus,
CTLFLAG_RW, &ia64_unaligned_sigbus, 0, "");
static void cpu_startup(void *); static void cpu_startup(void *);
SYSINIT(cpu, SI_SUB_CPU, SI_ORDER_FIRST, cpu_startup, NULL) SYSINIT(cpu, SI_SUB_CPU, SI_ORDER_FIRST, cpu_startup, NULL)

View File

@ -30,6 +30,7 @@
#include <sys/systm.h> #include <sys/systm.h>
#include <sys/kernel.h> #include <sys/kernel.h>
#include <sys/proc.h> #include <sys/proc.h>
#include <sys/sysctl.h>
#include <vm/vm.h> #include <vm/vm.h>
#include <vm/vm_extern.h> #include <vm/vm_extern.h>
#include <machine/frame.h> #include <machine/frame.h>
@ -37,8 +38,18 @@
#define sign_extend(imm, w) (((int64_t)(imm) << (64 - (w))) >> (64 - (w))) #define sign_extend(imm, w) (((int64_t)(imm) << (64 - (w))) >> (64 - (w)))
extern int ia64_unaligned_print, ia64_unaligned_fix; static int ia64_unaligned_print = 1; /* warn about unaligned accesses */
extern int ia64_unaligned_sigbus; static int ia64_unaligned_fix = 1; /* fix up unaligned accesses */
static int ia64_unaligned_sigbus = 0; /* don't SIGBUS on fixed-up accesses */
SYSCTL_INT(_machdep, OID_AUTO, unaligned_print, CTLFLAG_RW,
&ia64_unaligned_print, 0, "warn about unaligned accesses");
SYSCTL_INT(_machdep, OID_AUTO, unaligned_fix, CTLFLAG_RW,
&ia64_unaligned_fix, 0, "fix up unaligned accesses (if possible)");
SYSCTL_INT(_machdep, OID_AUTO, unaligned_sigbus, CTLFLAG_RW,
&ia64_unaligned_sigbus, 0, "do not SIGBUS on fixed-up accesses");
int unaligned_fixup(struct trapframe *framep, struct thread *td); int unaligned_fixup(struct trapframe *framep, struct thread *td);

View File

@ -70,22 +70,16 @@ struct clockframe {
*/ */
#define CPU_CONSDEV 1 /* dev_t: console terminal device */ #define CPU_CONSDEV 1 /* dev_t: console terminal device */
#define CPU_ROOT_DEVICE 2 /* string: root device name */ #define CPU_ROOT_DEVICE 2 /* string: root device name */
#define CPU_UNALIGNED_PRINT 3 /* int: print unaligned accesses */ #define CPU_BOOTED_KERNEL 3 /* string: booted kernel name */
#define CPU_UNALIGNED_FIX 4 /* int: fix unaligned accesses */ #define CPU_ADJKERNTZ 4 /* int: timezone offset (seconds) */
#define CPU_UNALIGNED_SIGBUS 5 /* int: SIGBUS unaligned accesses */ #define CPU_DISRTCSET 5 /* int: disable resettodr() call */
#define CPU_BOOTED_KERNEL 6 /* string: booted kernel name */ #define CPU_WALLCLOCK 6 /* int: indicates wall CMOS clock */
#define CPU_ADJKERNTZ 7 /* int: timezone offset (seconds) */ #define CPU_MAXID 7 /* valid machdep IDs */
#define CPU_DISRTCSET 8 /* int: disable resettodr() call */
#define CPU_WALLCLOCK 9 /* int: indicates wall CMOS clock */
#define CPU_MAXID 10 /* valid machdep IDs */
#define CTL_MACHDEP_NAMES { \ #define CTL_MACHDEP_NAMES { \
{ 0, 0 }, \ { 0, 0 }, \
{ "console_device", CTLTYPE_STRUCT }, \ { "console_device", CTLTYPE_STRUCT }, \
{ "root_device", CTLTYPE_STRING }, \ { "root_device", CTLTYPE_STRING }, \
{ "unaligned_print", CTLTYPE_INT }, \
{ "unaligned_fix", CTLTYPE_INT }, \
{ "unaligned_sigbus", CTLTYPE_INT }, \
{ "booted_kernel", CTLTYPE_STRING }, \ { "booted_kernel", CTLTYPE_STRING }, \
{ "adjkerntz", CTLTYPE_INT }, \ { "adjkerntz", CTLTYPE_INT }, \
{ "disable_rtc_set", CTLTYPE_INT }, \ { "disable_rtc_set", CTLTYPE_INT }, \