haiku/headers/os/drivers/KernelExport.h

261 lines
6.6 KiB
C

/* ++++++++++
KernelExport.h
Functions exported from the kernel for driver use that are not already
prototyped elsewhere.
Copyright 1996-98, Be Incorporated.
+++++ */
#ifndef _KERNEL_EXPORT_H
#define _KERNEL_EXPORT_H
#include <BeBuild.h>
#include <SupportDefs.h>
#include <OS.h>
#ifdef __cplusplus
extern "C" {
#endif
/* ---
kernel threads
--- */
extern _IMPEXP_KERNEL thread_id spawn_kernel_thread (
thread_func function,
const char *thread_name,
long priority,
void *arg
);
/* ---
disable/restore interrupt enable flag on current cpu
--- */
typedef ulong cpu_status;
extern _IMPEXP_KERNEL cpu_status disable_interrupts(void);
extern _IMPEXP_KERNEL void restore_interrupts(cpu_status status);
/* ---
spinlocks. Note that acquire/release should be called with
interrupts disabled.
--- */
typedef vint32 spinlock;
extern _IMPEXP_KERNEL void acquire_spinlock (spinlock *lock);
extern _IMPEXP_KERNEL void release_spinlock (spinlock *lock);
/* ---
An interrupt handler returns one of the following values:
--- */
#define B_UNHANDLED_INTERRUPT 0 /* pass to next handler */
#define B_HANDLED_INTERRUPT 1 /* don't pass on */
#define B_INVOKE_SCHEDULER 2 /* don't pass on; invoke the scheduler */
typedef int32 (*interrupt_handler) (void *data);
/* interrupt handling support for device drivers */
extern _IMPEXP_KERNEL long install_io_interrupt_handler (
long interrupt_number,
interrupt_handler handler,
void *data,
ulong flags
);
extern _IMPEXP_KERNEL long remove_io_interrupt_handler (
long interrupt_number,
interrupt_handler handler,
void *data
);
/* ---
timer interrupts services
--- */
typedef struct timer timer;
typedef struct qent qent;
typedef int32 (*timer_hook)(timer *);
/**
* The BeOS qent structure is probably part of a general double linked list
* interface used all over the kernel; a struct is required to have a qent
* entry struct as first element, so it can be linked to other elements
* easily. The key field is probably just an id, eventually used to order
* the list.
* Since we don't use this kind of interface, but we have to provide it
* to keep compatibility, we can use the qent struct for other purposes...
*/
struct qent {
int64 key; /* We use this as the sched time */
qent *next; /* This is used as a pointer to next timer */
qent *prev; /* This can be used for callback args */
};
struct timer {
qent entry;
uint16 flags;
uint16 cpu;
timer_hook hook;
bigtime_t period;
};
status_t add_timer(timer *t, timer_hook h, bigtime_t, int32 f);
bool cancel_timer(timer *t);
#define B_ONE_SHOT_ABSOLUTE_TIMER 1
#define B_ONE_SHOT_RELATIVE_TIMER 2
#define B_PERIODIC_TIMER 3
/* ---
signal functions
--- */
extern _IMPEXP_KERNEL int send_signal_etc(pid_t thid, uint sig, uint32 flags);
extern _IMPEXP_KERNEL int has_signals_pending(void *thr);
/* ---
snooze functions
--- */
extern _IMPEXP_KERNEL status_t snooze_etc(bigtime_t usecs, int timebase, uint32 flags);
/* ---
virtual memory buffer functions
--- */
#define B_DMA_IO 0x00000001
#define B_READ_DEVICE 0x00000002
typedef struct {
void *address; /* address in physical memory */
ulong size; /* size of block */
} physical_entry;
extern _IMPEXP_KERNEL long lock_memory (
void *buf, /* -> virtual buffer to lock (make resident) */
ulong num_bytes, /* size of virtual buffer */
ulong flags
);
extern _IMPEXP_KERNEL long unlock_memory (
void *buf, /* -> virtual buffer to unlock */
ulong num_bytes, /* size of virtual buffer */
ulong flags
);
extern _IMPEXP_KERNEL long get_memory_map (
const void *address, /* -> virtual buffer to translate */
ulong size, /* size of virtual buffer */
physical_entry *table, /* -> caller supplied table */
long num_entries /* # entries in table */
);
/* -----
address specifications for mapping physical memory
----- */
#define B_ANY_KERNEL_BLOCK_ADDRESS ((B_ANY_KERNEL_ADDRESS)+1)
/* -----
MTR attributes for mapping physical memory (Intel Architecture only)
----- */
#define B_MTR_UC 0x10000000
#define B_MTR_WC 0x20000000
#define B_MTR_WT 0x30000000
#define B_MTR_WP 0x40000000
#define B_MTR_WB 0x50000000
#define B_MTR_MASK 0xf0000000
/* -----
call to map physical memory - typically used for memory-mapped i/o
----- */
extern _IMPEXP_KERNEL area_id map_physical_memory (
const char *area_name,
void *physical_address,
size_t size,
uint32 flags,
uint32 protection,
void **mapped_address
);
/* -----
hardware inquiry
----- */
/* platform_type return value is defined in OS.h */
extern _IMPEXP_KERNEL platform_type platform();
#if __POWERPC__
extern _IMPEXP_KERNEL long motherboard_version (void);
extern _IMPEXP_KERNEL long io_card_version (void);
#endif
/* ---
primitive kernel debugging facilities. Debug output is on...
bebox: serial port 4
mac: modem port
pc: com1
...at 19.2 kbaud, no parity, 8 bit, 1 stop bit.
--- */
#if __GNUC__
extern _IMPEXP_KERNEL void dprintf (const char *format, ...) /* just like printf */
__attribute__ ((format (__printf__, 1, 2)));
extern _IMPEXP_KERNEL void kprintf (const char *fmt, ...) /* only for debugger cmds */
__attribute__ ((format (__printf__, 1, 2)));
#else
extern _IMPEXP_KERNEL void dprintf (const char *format, ...); /* just like printf */
extern _IMPEXP_KERNEL void kprintf (const char *fmt, ...); /* only for debugger cmds */
#endif
extern _IMPEXP_KERNEL bool set_dprintf_enabled (bool new_state); /* returns old state */
extern _IMPEXP_KERNEL void panic(const char *format, ...);
extern _IMPEXP_KERNEL void kernel_debugger (const char *message); /* enter kernel debugger */
extern _IMPEXP_KERNEL ulong parse_expression (char *str); /* util for debugger cmds */
/* special return codes for kernel debugger */
#define B_KDEBUG_CONT 2
#define B_KDEBUG_QUIT 3
extern _IMPEXP_KERNEL int add_debugger_command (char *name, /* add a cmd to debugger */
int (*func)(int argc, char **argv),
char *help);
extern _IMPEXP_KERNEL int remove_debugger_command (char *name, /* remove a cmd from debugger */
int (*func)(int argc, char **argv));
/* -----
misc
----- */
extern _IMPEXP_KERNEL void spin (bigtime_t num_microseconds);
extern _IMPEXP_KERNEL int register_kernel_daemon(void (*func)(void *, int), void *arg, int freq);
extern _IMPEXP_KERNEL int unregister_kernel_daemon(void (*func)(void *, int), void *arg);
extern _IMPEXP_KERNEL void call_all_cpus(void (*f)(void*, int), void* cookie);
extern _IMPEXP_KERNEL int load_driver_symbols(const char *driver_name);
#ifdef __cplusplus
}
#endif
#endif