pbrook | 87ecb68 | 2007-11-17 17:14:51 +0000 | [diff] [blame] | 1 | #ifndef SYSEMU_H |
| 2 | #define SYSEMU_H |
| 3 | /* Misc. things related to the system emulator. */ |
| 4 | |
aliguori | 376253e | 2009-03-05 23:01:23 +0000 | [diff] [blame] | 5 | #include "qemu-common.h" |
Gerd Hoffmann | 62c5802 | 2009-07-22 16:43:00 +0200 | [diff] [blame] | 6 | #include "qemu-option.h" |
Blue Swirl | 72cf2d4 | 2009-09-12 07:36:22 +0000 | [diff] [blame] | 7 | #include "qemu-queue.h" |
Jan Kiszka | 6875204 | 2009-09-15 13:36:04 +0200 | [diff] [blame] | 8 | #include "qemu-timer.h" |
Luiz Capitulino | d54908a | 2009-08-28 15:27:13 -0300 | [diff] [blame] | 9 | #include "qdict.h" |
Luiz Capitulino | 8204a91 | 2009-11-18 23:05:31 -0200 | [diff] [blame] | 10 | #include "qerror.h" |
aliguori | 376253e | 2009-03-05 23:01:23 +0000 | [diff] [blame] | 11 | |
aliguori | 49dc768 | 2009-03-08 16:26:59 +0000 | [diff] [blame] | 12 | #ifdef _WIN32 |
| 13 | #include <windows.h> |
| 14 | #endif |
| 15 | |
pbrook | 87ecb68 | 2007-11-17 17:14:51 +0000 | [diff] [blame] | 16 | /* vl.c */ |
| 17 | extern const char *bios_name; |
Paul Brook | 5cea859 | 2009-05-30 00:52:44 +0100 | [diff] [blame] | 18 | |
| 19 | #define QEMU_FILE_TYPE_BIOS 0 |
| 20 | #define QEMU_FILE_TYPE_KEYMAP 1 |
| 21 | char *qemu_find_file(int type, const char *name); |
pbrook | 87ecb68 | 2007-11-17 17:14:51 +0000 | [diff] [blame] | 22 | |
| 23 | extern int vm_running; |
| 24 | extern const char *qemu_name; |
blueswir1 | 8fcb1b9 | 2008-09-18 18:29:08 +0000 | [diff] [blame] | 25 | extern uint8_t qemu_uuid[]; |
aliguori | c4be29f | 2009-04-17 18:58:14 +0000 | [diff] [blame] | 26 | int qemu_uuid_parse(const char *str, uint8_t *uuid); |
blueswir1 | 8fcb1b9 | 2008-09-18 18:29:08 +0000 | [diff] [blame] | 27 | #define UUID_FMT "%02hhx%02hhx%02hhx%02hhx-%02hhx%02hhx-%02hhx%02hhx-%02hhx%02hhx-%02hhx%02hhx%02hhx%02hhx%02hhx%02hhx" |
pbrook | 87ecb68 | 2007-11-17 17:14:51 +0000 | [diff] [blame] | 28 | |
| 29 | typedef struct vm_change_state_entry VMChangeStateEntry; |
aliguori | 9781e04 | 2009-01-22 17:15:29 +0000 | [diff] [blame] | 30 | typedef void VMChangeStateHandler(void *opaque, int running, int reason); |
pbrook | 87ecb68 | 2007-11-17 17:14:51 +0000 | [diff] [blame] | 31 | |
| 32 | VMChangeStateEntry *qemu_add_vm_change_state_handler(VMChangeStateHandler *cb, |
| 33 | void *opaque); |
| 34 | void qemu_del_vm_change_state_handler(VMChangeStateEntry *e); |
| 35 | |
pbrook | 87ecb68 | 2007-11-17 17:14:51 +0000 | [diff] [blame] | 36 | void vm_start(void); |
| 37 | void vm_stop(int reason); |
| 38 | |
Glauber Costa | 9f9e28c | 2009-05-21 17:38:01 -0400 | [diff] [blame] | 39 | uint64_t ram_bytes_remaining(void); |
| 40 | uint64_t ram_bytes_transferred(void); |
| 41 | uint64_t ram_bytes_total(void); |
| 42 | |
pbrook | 87ecb68 | 2007-11-17 17:14:51 +0000 | [diff] [blame] | 43 | int64_t cpu_get_ticks(void); |
| 44 | void cpu_enable_ticks(void); |
| 45 | void cpu_disable_ticks(void); |
| 46 | |
| 47 | void qemu_system_reset_request(void); |
| 48 | void qemu_system_shutdown_request(void); |
| 49 | void qemu_system_powerdown_request(void); |
aurel32 | cf7a2fe | 2008-03-18 06:53:05 +0000 | [diff] [blame] | 50 | int qemu_shutdown_requested(void); |
| 51 | int qemu_reset_requested(void); |
| 52 | int qemu_powerdown_requested(void); |
Blue Swirl | d9c3231 | 2009-08-09 08:42:19 +0000 | [diff] [blame] | 53 | extern qemu_irq qemu_system_powerdown; |
aurel32 | cf7a2fe | 2008-03-18 06:53:05 +0000 | [diff] [blame] | 54 | void qemu_system_reset(void); |
pbrook | 87ecb68 | 2007-11-17 17:14:51 +0000 | [diff] [blame] | 55 | |
Luiz Capitulino | d54908a | 2009-08-28 15:27:13 -0300 | [diff] [blame] | 56 | void do_savevm(Monitor *mon, const QDict *qdict); |
Juan Quintela | 05f2401 | 2009-08-20 19:42:22 +0200 | [diff] [blame] | 57 | int load_vmstate(Monitor *mon, const char *name); |
Luiz Capitulino | d54908a | 2009-08-28 15:27:13 -0300 | [diff] [blame] | 58 | void do_delvm(Monitor *mon, const QDict *qdict); |
aliguori | 376253e | 2009-03-05 23:01:23 +0000 | [diff] [blame] | 59 | void do_info_snapshots(Monitor *mon); |
pbrook | 87ecb68 | 2007-11-17 17:14:51 +0000 | [diff] [blame] | 60 | |
aliguori | 210f41b | 2008-10-13 03:13:12 +0000 | [diff] [blame] | 61 | void qemu_announce_self(void); |
| 62 | |
pbrook | 87ecb68 | 2007-11-17 17:14:51 +0000 | [diff] [blame] | 63 | void main_loop_wait(int timeout); |
| 64 | |
Jan Kiszka | f327aa0 | 2009-11-30 18:21:21 +0100 | [diff] [blame] | 65 | int qemu_savevm_state_begin(Monitor *mon, QEMUFile *f, int blk_enable, |
| 66 | int shared); |
| 67 | int qemu_savevm_state_iterate(Monitor *mon, QEMUFile *f); |
| 68 | int qemu_savevm_state_complete(Monitor *mon, QEMUFile *f); |
| 69 | void qemu_savevm_state_cancel(Monitor *mon, QEMUFile *f); |
aliguori | 9366f41 | 2008-10-06 14:53:52 +0000 | [diff] [blame] | 70 | int qemu_loadvm_state(QEMUFile *f); |
| 71 | |
Gerd Hoffmann | ac7531e | 2009-08-14 10:36:06 +0200 | [diff] [blame] | 72 | void qemu_errors_to_file(FILE *fp); |
| 73 | void qemu_errors_to_mon(Monitor *mon); |
| 74 | void qemu_errors_to_previous(void); |
| 75 | void qemu_error(const char *fmt, ...) __attribute__ ((format(printf, 1, 2))); |
Luiz Capitulino | 8204a91 | 2009-11-18 23:05:31 -0200 | [diff] [blame] | 76 | void qemu_error_internal(const char *file, int linenr, const char *func, |
| 77 | const char *fmt, ...) |
| 78 | __attribute__ ((format(printf, 4, 5))); |
| 79 | |
| 80 | #define qemu_error_new(fmt, ...) \ |
| 81 | qemu_error_internal(__FILE__, __LINE__, __func__, fmt, ## __VA_ARGS__) |
Gerd Hoffmann | ac7531e | 2009-08-14 10:36:06 +0200 | [diff] [blame] | 82 | |
aliguori | 56f3a5d | 2008-10-31 18:07:17 +0000 | [diff] [blame] | 83 | #ifdef _WIN32 |
pbrook | 87ecb68 | 2007-11-17 17:14:51 +0000 | [diff] [blame] | 84 | /* Polling handling */ |
| 85 | |
| 86 | /* return TRUE if no sleep should be done afterwards */ |
| 87 | typedef int PollingFunc(void *opaque); |
| 88 | |
| 89 | int qemu_add_polling_cb(PollingFunc *func, void *opaque); |
| 90 | void qemu_del_polling_cb(PollingFunc *func, void *opaque); |
| 91 | |
pbrook | 87ecb68 | 2007-11-17 17:14:51 +0000 | [diff] [blame] | 92 | /* Wait objects handling */ |
| 93 | typedef void WaitObjectFunc(void *opaque); |
| 94 | |
| 95 | int qemu_add_wait_object(HANDLE handle, WaitObjectFunc *func, void *opaque); |
| 96 | void qemu_del_wait_object(HANDLE handle, WaitObjectFunc *func, void *opaque); |
| 97 | #endif |
| 98 | |
pbrook | 87ecb68 | 2007-11-17 17:14:51 +0000 | [diff] [blame] | 99 | /* SLIRP */ |
aliguori | 376253e | 2009-03-05 23:01:23 +0000 | [diff] [blame] | 100 | void do_info_slirp(Monitor *mon); |
pbrook | 87ecb68 | 2007-11-17 17:14:51 +0000 | [diff] [blame] | 101 | |
Anthony Liguori | 993fbfd | 2009-05-21 16:54:00 -0500 | [diff] [blame] | 102 | typedef enum DisplayType |
| 103 | { |
| 104 | DT_DEFAULT, |
| 105 | DT_CURSES, |
| 106 | DT_SDL, |
| 107 | DT_VNC, |
| 108 | DT_NOGRAPHIC, |
| 109 | } DisplayType; |
| 110 | |
Paolo Bonzini | d399f67 | 2009-07-27 23:17:51 +0200 | [diff] [blame] | 111 | extern int autostart; |
pbrook | 87ecb68 | 2007-11-17 17:14:51 +0000 | [diff] [blame] | 112 | extern int bios_size; |
Zachary Amsden | 8617675 | 2009-07-30 00:15:02 -1000 | [diff] [blame] | 113 | |
| 114 | typedef enum { |
| 115 | VGA_NONE, VGA_STD, VGA_CIRRUS, VGA_VMWARE, VGA_XENFB |
| 116 | } VGAInterfaceType; |
| 117 | |
| 118 | extern int vga_interface_type; |
| 119 | #define cirrus_vga_enabled (vga_interface_type == VGA_CIRRUS) |
| 120 | #define std_vga_enabled (vga_interface_type == VGA_STD) |
| 121 | #define xenfb_enabled (vga_interface_type == VGA_XENFB) |
| 122 | #define vmsvga_enabled (vga_interface_type == VGA_VMWARE) |
| 123 | |
pbrook | 87ecb68 | 2007-11-17 17:14:51 +0000 | [diff] [blame] | 124 | extern int graphic_width; |
| 125 | extern int graphic_height; |
| 126 | extern int graphic_depth; |
Jes Sorensen | 6b35e7b | 2009-08-06 16:25:50 +0200 | [diff] [blame] | 127 | extern uint8_t irq0override; |
Anthony Liguori | 993fbfd | 2009-05-21 16:54:00 -0500 | [diff] [blame] | 128 | extern DisplayType display_type; |
pbrook | 87ecb68 | 2007-11-17 17:14:51 +0000 | [diff] [blame] | 129 | extern const char *keyboard_layout; |
| 130 | extern int win2k_install_hack; |
aliguori | 73822ec | 2009-01-15 20:11:34 +0000 | [diff] [blame] | 131 | extern int rtc_td_hack; |
pbrook | 87ecb68 | 2007-11-17 17:14:51 +0000 | [diff] [blame] | 132 | extern int alt_grab; |
Dustin Kirkland | 0ca9f8a | 2009-09-17 15:48:04 -0500 | [diff] [blame] | 133 | extern int ctrl_grab; |
pbrook | 87ecb68 | 2007-11-17 17:14:51 +0000 | [diff] [blame] | 134 | extern int usb_enabled; |
| 135 | extern int smp_cpus; |
Jes Sorensen | 6be68d7 | 2009-07-23 17:03:42 +0200 | [diff] [blame] | 136 | extern int max_cpus; |
pbrook | 87ecb68 | 2007-11-17 17:14:51 +0000 | [diff] [blame] | 137 | extern int cursor_hide; |
| 138 | extern int graphic_rotate; |
| 139 | extern int no_quit; |
| 140 | extern int semihosting_enabled; |
pbrook | 87ecb68 | 2007-11-17 17:14:51 +0000 | [diff] [blame] | 141 | extern int old_param; |
Jan Kiszka | 9538749 | 2009-07-02 00:19:02 +0200 | [diff] [blame] | 142 | extern int boot_menu; |
Jan Kiszka | 6875204 | 2009-09-15 13:36:04 +0200 | [diff] [blame] | 143 | extern QEMUClock *rtc_clock; |
pbrook | 87ecb68 | 2007-11-17 17:14:51 +0000 | [diff] [blame] | 144 | |
aliguori | 268a362 | 2009-04-21 22:30:27 +0000 | [diff] [blame] | 145 | #define MAX_NODES 64 |
| 146 | extern int nb_numa_nodes; |
| 147 | extern uint64_t node_mem[MAX_NODES]; |
Blue Swirl | 075cd32 | 2009-09-13 08:32:39 +0000 | [diff] [blame] | 148 | extern uint64_t node_cpumask[MAX_NODES]; |
aliguori | 268a362 | 2009-04-21 22:30:27 +0000 | [diff] [blame] | 149 | |
pbrook | 87ecb68 | 2007-11-17 17:14:51 +0000 | [diff] [blame] | 150 | #define MAX_OPTION_ROMS 16 |
| 151 | extern const char *option_rom[MAX_OPTION_ROMS]; |
| 152 | extern int nb_option_roms; |
| 153 | |
Paul Brook | 1ad2134 | 2009-05-19 16:17:58 +0100 | [diff] [blame] | 154 | #ifdef NEED_CPU_H |
blueswir1 | 95efd11 | 2008-12-24 20:26:14 +0000 | [diff] [blame] | 155 | #if defined(TARGET_SPARC) || defined(TARGET_PPC) |
pbrook | 87ecb68 | 2007-11-17 17:14:51 +0000 | [diff] [blame] | 156 | #define MAX_PROM_ENVS 128 |
| 157 | extern const char *prom_envs[MAX_PROM_ENVS]; |
| 158 | extern unsigned int nb_prom_envs; |
| 159 | #endif |
Paul Brook | 1ad2134 | 2009-05-19 16:17:58 +0100 | [diff] [blame] | 160 | #endif |
pbrook | 87ecb68 | 2007-11-17 17:14:51 +0000 | [diff] [blame] | 161 | |
ths | e4bcb14 | 2007-12-02 04:51:10 +0000 | [diff] [blame] | 162 | typedef enum { |
Gerd Hoffmann | a8659e9 | 2009-07-31 12:25:39 +0200 | [diff] [blame] | 163 | IF_NONE, |
Paul Brook | aae9460 | 2009-05-14 22:35:06 +0100 | [diff] [blame] | 164 | IF_IDE, IF_SCSI, IF_FLOPPY, IF_PFLASH, IF_MTD, IF_SD, IF_VIRTIO, IF_XEN, |
| 165 | IF_COUNT |
ths | e4bcb14 | 2007-12-02 04:51:10 +0000 | [diff] [blame] | 166 | } BlockInterfaceType; |
pbrook | 87ecb68 | 2007-11-17 17:14:51 +0000 | [diff] [blame] | 167 | |
aliguori | 428c570 | 2009-01-21 18:59:04 +0000 | [diff] [blame] | 168 | typedef enum { |
| 169 | BLOCK_ERR_REPORT, BLOCK_ERR_IGNORE, BLOCK_ERR_STOP_ENOSPC, |
| 170 | BLOCK_ERR_STOP_ANY |
| 171 | } BlockInterfaceErrorAction; |
| 172 | |
john cooper | bf01129 | 2009-06-22 14:26:51 -0400 | [diff] [blame] | 173 | #define BLOCK_SERIAL_STRLEN 20 |
| 174 | |
ths | e4bcb14 | 2007-12-02 04:51:10 +0000 | [diff] [blame] | 175 | typedef struct DriveInfo { |
| 176 | BlockDriverState *bdrv; |
Gerd Hoffmann | 1dae12e | 2009-07-22 16:42:58 +0200 | [diff] [blame] | 177 | char *id; |
Markus Armbruster | c2cc47a | 2009-06-18 15:14:10 +0200 | [diff] [blame] | 178 | const char *devaddr; |
ths | f60d39b | 2007-12-17 03:55:57 +0000 | [diff] [blame] | 179 | BlockInterfaceType type; |
ths | e4bcb14 | 2007-12-02 04:51:10 +0000 | [diff] [blame] | 180 | int bus; |
| 181 | int unit; |
Gerd Hoffmann | 9dfd7c7 | 2009-07-22 16:43:04 +0200 | [diff] [blame] | 182 | QemuOpts *opts; |
Kevin Wolf | e9b2e81 | 2009-11-27 13:25:37 +0100 | [diff] [blame] | 183 | BlockInterfaceErrorAction on_read_error; |
Kevin Wolf | f785009 | 2009-11-27 13:25:36 +0100 | [diff] [blame] | 184 | BlockInterfaceErrorAction on_write_error; |
john cooper | bf01129 | 2009-06-22 14:26:51 -0400 | [diff] [blame] | 185 | char serial[BLOCK_SERIAL_STRLEN + 1]; |
Blue Swirl | 72cf2d4 | 2009-09-12 07:36:22 +0000 | [diff] [blame] | 186 | QTAILQ_ENTRY(DriveInfo) next; |
ths | e4bcb14 | 2007-12-02 04:51:10 +0000 | [diff] [blame] | 187 | } DriveInfo; |
pbrook | 87ecb68 | 2007-11-17 17:14:51 +0000 | [diff] [blame] | 188 | |
ths | e4bcb14 | 2007-12-02 04:51:10 +0000 | [diff] [blame] | 189 | #define MAX_IDE_DEVS 2 |
| 190 | #define MAX_SCSI_DEVS 7 |
| 191 | #define MAX_DRIVES 32 |
| 192 | |
Blue Swirl | 72cf2d4 | 2009-09-12 07:36:22 +0000 | [diff] [blame] | 193 | extern QTAILQ_HEAD(drivelist, DriveInfo) drives; |
| 194 | extern QTAILQ_HEAD(driveoptlist, DriveOpt) driveopts; |
ths | e4bcb14 | 2007-12-02 04:51:10 +0000 | [diff] [blame] | 195 | |
Gerd Hoffmann | 751c6a1 | 2009-07-22 16:42:57 +0200 | [diff] [blame] | 196 | extern DriveInfo *drive_get(BlockInterfaceType type, int bus, int unit); |
Gerd Hoffmann | 2e810b3 | 2009-07-31 12:25:38 +0200 | [diff] [blame] | 197 | extern DriveInfo *drive_get_by_id(const char *id); |
ths | f60d39b | 2007-12-17 03:55:57 +0000 | [diff] [blame] | 198 | extern int drive_get_max_bus(BlockInterfaceType type); |
Gerd Hoffmann | 56a1493 | 2009-09-25 21:42:46 +0200 | [diff] [blame] | 199 | extern void drive_uninit(DriveInfo *dinfo); |
aliguori | fa879c6 | 2009-01-07 17:32:33 +0000 | [diff] [blame] | 200 | extern const char *drive_get_serial(BlockDriverState *bdrv); |
Kevin Wolf | f785009 | 2009-11-27 13:25:36 +0100 | [diff] [blame] | 201 | |
| 202 | extern BlockInterfaceErrorAction drive_get_on_error( |
| 203 | BlockDriverState *bdrv, int is_read); |
pbrook | 87ecb68 | 2007-11-17 17:14:51 +0000 | [diff] [blame] | 204 | |
Paul Brook | aae9460 | 2009-05-14 22:35:06 +0100 | [diff] [blame] | 205 | BlockDriverState *qdev_init_bdrv(DeviceState *dev, BlockInterfaceType type); |
| 206 | |
Gerd Hoffmann | 9dfd7c7 | 2009-07-22 16:43:04 +0200 | [diff] [blame] | 207 | extern QemuOpts *drive_add(const char *file, const char *fmt, ...); |
| 208 | extern DriveInfo *drive_init(QemuOpts *arg, void *machine, int *fatal_error); |
aliguori | 4d73cd3 | 2009-02-11 15:20:46 +0000 | [diff] [blame] | 209 | |
aliguori | 6f338c3 | 2009-02-11 15:21:54 +0000 | [diff] [blame] | 210 | /* device-hotplug */ |
| 211 | |
Gerd Hoffmann | 751c6a1 | 2009-07-22 16:42:57 +0200 | [diff] [blame] | 212 | DriveInfo *add_init_drive(const char *opts); |
aliguori | 6f338c3 | 2009-02-11 15:21:54 +0000 | [diff] [blame] | 213 | |
| 214 | /* pci-hotplug */ |
Luiz Capitulino | 7a344f7 | 2009-12-10 17:16:09 -0200 | [diff] [blame] | 215 | void pci_device_hot_add_print(Monitor *mon, const QObject *data); |
| 216 | void pci_device_hot_add(Monitor *mon, const QDict *qdict, QObject **ret_data); |
Luiz Capitulino | f18c16d | 2009-08-28 15:27:14 -0300 | [diff] [blame] | 217 | void drive_hot_add(Monitor *mon, const QDict *qdict); |
aliguori | 376253e | 2009-03-05 23:01:23 +0000 | [diff] [blame] | 218 | void pci_device_hot_remove(Monitor *mon, const char *pci_addr); |
Luiz Capitulino | 6848d82 | 2009-10-16 12:23:48 -0300 | [diff] [blame] | 219 | void do_pci_device_hot_remove(Monitor *mon, const QDict *qdict, |
| 220 | QObject **ret_data); |
aliguori | 6f338c3 | 2009-02-11 15:21:54 +0000 | [diff] [blame] | 221 | |
pbrook | 87ecb68 | 2007-11-17 17:14:51 +0000 | [diff] [blame] | 222 | /* serial ports */ |
| 223 | |
| 224 | #define MAX_SERIAL_PORTS 4 |
| 225 | |
| 226 | extern CharDriverState *serial_hds[MAX_SERIAL_PORTS]; |
| 227 | |
| 228 | /* parallel ports */ |
| 229 | |
| 230 | #define MAX_PARALLEL_PORTS 3 |
| 231 | |
| 232 | extern CharDriverState *parallel_hds[MAX_PARALLEL_PORTS]; |
| 233 | |
aliguori | 9ede2fd | 2009-01-15 20:05:25 +0000 | [diff] [blame] | 234 | /* virtio consoles */ |
| 235 | |
| 236 | #define MAX_VIRTIO_CONSOLES 1 |
| 237 | |
| 238 | extern CharDriverState *virtcon_hds[MAX_VIRTIO_CONSOLES]; |
| 239 | |
aliguori | 0e82f34 | 2008-10-31 18:44:40 +0000 | [diff] [blame] | 240 | #define TFR(expr) do { if ((expr) != -1) break; } while (errno == EINTR) |
| 241 | |
pbrook | 87ecb68 | 2007-11-17 17:14:51 +0000 | [diff] [blame] | 242 | #ifdef HAS_AUDIO |
| 243 | struct soundhw { |
| 244 | const char *name; |
| 245 | const char *descr; |
| 246 | int enabled; |
| 247 | int isa; |
| 248 | union { |
Paul Brook | 22d83b1 | 2009-05-12 12:33:04 +0100 | [diff] [blame] | 249 | int (*init_isa) (qemu_irq *pic); |
| 250 | int (*init_pci) (PCIBus *bus); |
pbrook | 87ecb68 | 2007-11-17 17:14:51 +0000 | [diff] [blame] | 251 | } init; |
| 252 | }; |
| 253 | |
| 254 | extern struct soundhw soundhw[]; |
| 255 | #endif |
| 256 | |
Luiz Capitulino | d54908a | 2009-08-28 15:27:13 -0300 | [diff] [blame] | 257 | void do_usb_add(Monitor *mon, const QDict *qdict); |
| 258 | void do_usb_del(Monitor *mon, const QDict *qdict); |
aliguori | 376253e | 2009-03-05 23:01:23 +0000 | [diff] [blame] | 259 | void usb_info(Monitor *mon); |
pbrook | 87ecb68 | 2007-11-17 17:14:51 +0000 | [diff] [blame] | 260 | |
Paul Brook | aae9460 | 2009-05-14 22:35:06 +0100 | [diff] [blame] | 261 | void register_devices(void); |
| 262 | |
pbrook | 87ecb68 | 2007-11-17 17:14:51 +0000 | [diff] [blame] | 263 | #endif |