Execute BIOS function
dwhite at gumbysoft.com
Mon Jun 7 05:05:03 GMT 2004
On Mon, 7 Jun 2004, Phil Schulz wrote:
> Hello List!
> The radio transmitter of my new centrino laptop is turned on by a BIOS
> function which resides at a certain location in memory. I know how to
> find the adress of the function's start but I don't yet know how to tell
> the OS that I do want to execute that memory region and make it let me
> do so. When running the program I get "Bus error (core dumped)". So the
> question is: Can I actually execute the BIOS code from userland or do I
> have to do it from kernelspace? How do I tell the kernel that I want the
> memory region to be executed and make it let me do so?
You'll have to do it from the kernel. The BIOS call will probably want to
poke memory and I/O ports you won't have access to.
You'll also need to know if its 32-bit protected mode safe or not; if not
you'll have to set up VM86() to make the call.
Have you checked for an ACPI method that implements the same thing?
> Any help is appreciated.
> This is a part of the code (I hope it's not going to be wrapped).
> bios_code_addr holds the BIOS function's start address and dev_mem is a
> file-descriptor to /dev/mem.
> ptr = mmap( 0, BIOS_CODE_SIZE, PROT_EXEC,
> 0, dev_mem, bios_code_addr );
> __asm__ __volatile__ (
> "call *%3 \t\n"
> : "=a"(eax)
> : "a"(eax), "b"(ebx), "c"(ptr)
> freebsd-current at freebsd.org mailing list
> To unsubscribe, send any mail to "freebsd-current-unsubscribe at freebsd.org"
Doug White | FreeBSD: The Power to Serve
dwhite at gumbysoft.com | www.FreeBSD.org
More information about the freebsd-current