diff --git a/sys/compat/x86bios/x86bios.c b/sys/compat/x86bios/x86bios.c index a8bd69a3f094..465a076e16fb 100644 --- a/sys/compat/x86bios/x86bios.c +++ b/sys/compat/x86bios/x86bios.c @@ -203,6 +203,13 @@ x86bios_get_intr(int intno) return (readl(BIOS_PADDRTOVADDR(intno * 4))); } +void +x86bios_set_intr(int intno, uint32_t saddr) +{ + + writel(BIOS_PADDRTOVADDR(intno * 4), saddr); +} + void x86bios_intr(struct x86regs *regs, int intno) { @@ -619,11 +626,15 @@ x86bios_call(struct x86regs *regs, uint16_t seg, uint16_t off) uint32_t x86bios_get_intr(int intno) { - uint32_t *iv; - iv = (uint32_t *)((vm_offset_t)x86bios_ivt + intno * 4); + return (le32toh(*((uint32_t *)x86bios_ivt + intno))); +} - return (le32toh(*iv)); +void +x86bios_set_intr(int intno, uint32_t saddr) +{ + + *((uint32_t *)x86bios_ivt + intno) = htole32(saddr); } void diff --git a/sys/compat/x86bios/x86bios.h b/sys/compat/x86bios/x86bios.h index f4749329f89e..491367de4f1e 100644 --- a/sys/compat/x86bios/x86bios.h +++ b/sys/compat/x86bios/x86bios.h @@ -151,6 +151,7 @@ void x86bios_init_regs(struct x86regs *regs); void x86bios_intr(struct x86regs *regs, int intno); int x86bios_match_device(uint32_t offset, device_t dev); void *x86bios_offset(uint32_t offset); +void x86bios_set_intr(int intno, uint32_t saddr); __END_DECLS #endif /* !_X86BIOS_H_ */