Parent Directory | Revision Log
++ trunk/HISTORY (local) $Id: HISTORY,v 1.772 2005/06/04 12:02:16 debug Exp $ 20050428 Disabling the "-fmove-all-movables" option in the configure script, because it causes the compile to fail on OpenBSD/sgi. 20050502 Minor updates. 20050503 Removing the WRT54G mode (it was bogus anyway), and adding a comment about Windows NT for MIPS in doc/experiments.html. Minor updates to the x86 instruction decoding. 20050504 Adding some more x86 instructions. Adding support for reading files from ISO9660 CDROMs (including gzipped files). It's an ugly hack, but it seems to work. Various other minor updates (dev_vga.c, pc_bios.c etc). 20050505 Some more x86-related updates. Beginning (what I hope will be) a major code cleanup phase. "bootris" (an x86 bootsector) runs :-) 20050506 Adding some more x86 instructions. 20050507 tmpnam => mkstemp. Working on a hack to allow VGA charcells to be shown even when not running with X11. Adding more x86 instructions. 20050508 x86 32-bit SIB addressing fix, and more instructions. 20050509 Adding more x86 instructions. 20050510 Minor documentation updates, and other updates (x86 stuff etc.) 20050511 More x86-related updates. 20050513 Various updates, mostly x86-related. (Trying to fix flag calculation, factoring out the ugly shift/rotate code, and some other things.) 20050514 Adding support for loading some old i386 a.out executables. Finally beginning the cleanup of machine/PROM/bios dependant info. Some minor documentation updates. Trying to clean up ARCBIOS stuff a little. 20050515 Trying to make it possible to actually use more than one disk type per machine (floppy, ide, scsi). Trying to clean up the kbd vs PROM console stuff. (For PC and ARC emulation modes, mostly.) Beginning to add an 8259 interrupt controller, and connecting it to the x86 emulation. 20050516 The first x86 interrupts seem to work (keyboard stuff). Adding a 8253/8254 programmable interval timer skeleton. FreeDOS now reaches a command prompt and can be interacted with. 20050517 After some bugfixes, MS-DOS also (sometimes) reaches a command prompt now. Trying to fix the pckbc to work with MS-DOS' keyb.com, but no success yet. 20050518 Adding a simple 32-bit x86 MMU skeleton. 20050519 Some more work on the x86 stuff. (Beginning the work on paging, and various other fixes). 20050520 More updates. Working on dev_vga (4-bit graphics modes), adding 40 columns support to the PC bios emulation. Trying to add support for resizing windows when switching between graphics modes. 20050521 Many more x86-related updates. 20050522 Correcting the initial stack pointer's sign-extension for ARCBIOS emulation (thanks to Alec Voropay for noticing the error). Continuing on the cleanup (ARCBIOS etc). dev_vga updates. 20050523 More x86 updates: trying to add some support for protected mode interrupts (via gate descriptors) and many other fixes. More ARCBIOS cleanup. Adding a device flag which indicates that reads cause no side-effects. (Useful for the "dump" command in the debugger, and other things.) Adding support for directly starting up x86 ELFs, skipping the bootloader stage. (Most ELFs, however, are not suitable for this.) 20050524 Adding simple 32-bit x86 TSS task switching, but no privilege level support yet. More work on dev_vga. A small "Copper bars" demo works. :-) Adding support for Trap Flag (single-step exceptions), at least in real mode, and various other x86-related fixes. 20050525 Adding a new disk image prefix (gH;S;) which can be used to override the default nr of heads and sectors per track. 20050527 Various bug fixes, more work on the x86 mode (stack change on interrupts between different priv.levels), and some minor documentation updates. 20050528 Various fixes (x86 stuff). 20050529 More x86 fixes. An OpenBSD/i386 bootfloppy reaches userland and can be interacted with (although there are problems with key repetition). NetBSD/i386 triggers a serious CISC-related problem: instruction fetches across page boundaries, where the later part isn't actually part of the instruction. 20050530 Various minor updates. (Documentation updates, etc.) 20050531 Adding some experimental code (experiments/new_test_*) which could be useful for dynamic (but not binary) translation in the future. 20050602 Adding a dummy ARM skeleton. Fixing the pckbc key repetition problem (by adding release scancodes for all keypresses). 20050603 Minor updates for the next release. 20050604 Release testing. Minor updates. ============== RELEASE 0.3.3 ============== 20050604 There'll probably be a 0.3.3.1 release soon, with some very very tiny updates.
1 | dpavlin | 4 | #ifndef ARCBIOS_H |
2 | #define ARCBIOS_H | ||
3 | |||
4 | /* | ||
5 | * Copyright (C) 2004-2005 Anders Gavare. All rights reserved. | ||
6 | * | ||
7 | * Redistribution and use in source and binary forms, with or without | ||
8 | * modification, are permitted provided that the following conditions are met: | ||
9 | * | ||
10 | * 1. Redistributions of source code must retain the above copyright | ||
11 | * notice, this list of conditions and the following disclaimer. | ||
12 | * 2. Redistributions in binary form must reproduce the above copyright | ||
13 | * notice, this list of conditions and the following disclaimer in the | ||
14 | * documentation and/or other materials provided with the distribution. | ||
15 | * 3. The name of the author may not be used to endorse or promote products | ||
16 | * derived from this software without specific prior written permission. | ||
17 | * | ||
18 | * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND | ||
19 | * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE | ||
20 | * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE | ||
21 | * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE | ||
22 | * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL | ||
23 | * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS | ||
24 | * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) | ||
25 | * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT | ||
26 | * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY | ||
27 | * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF | ||
28 | * SUCH DAMAGE. | ||
29 | * | ||
30 | * | ||
31 | dpavlin | 6 | * $Id: arcbios.h,v 1.9 2005/05/23 12:21:46 debug Exp $ |
32 | dpavlin | 4 | * |
33 | * Headerfile for src/arcbios.c. | ||
34 | * | ||
35 | * (Note: There are also files called arcbios_other.h and sgi_arcbios.h, | ||
36 | * which are copied from NetBSD.) | ||
37 | */ | ||
38 | |||
39 | #include "misc.h" | ||
40 | #include "sgi_arcbios.h" | ||
41 | |||
42 | struct cpu; | ||
43 | |||
44 | /* arcbios.c: */ | ||
45 | dpavlin | 6 | void arcbios_add_string_to_component(struct machine *machine, |
46 | char *string, uint64_t component); | ||
47 | void arcbios_register_scsicontroller(struct machine *machine, | ||
48 | uint64_t scsicontroller_component); | ||
49 | uint64_t arcbios_get_scsicontroller(struct machine *machine); | ||
50 | dpavlin | 4 | void arcbios_add_memory_descriptor(struct cpu *cpu, |
51 | uint64_t base, uint64_t len, int arctype); | ||
52 | uint64_t arcbios_addchild_manual(struct cpu *cpu, | ||
53 | uint64_t class, uint64_t type, uint64_t flags, uint64_t version, | ||
54 | uint64_t revision, uint64_t key, uint64_t affinitymask, | ||
55 | char *identifier, uint64_t parent, void *config_data, | ||
56 | size_t config_len); | ||
57 | int arcbios_emul(struct cpu *cpu); | ||
58 | void arcbios_set_default_exception_handler(struct cpu *cpu); | ||
59 | |||
60 | dpavlin | 6 | void arcbios_console_init(struct machine *machine, |
61 | uint64_t vram, uint64_t ctrlregs); | ||
62 | void arcbios_init(struct machine *machine, int is64bit, | ||
63 | uint64_t sgi_ram_offset); | ||
64 | dpavlin | 4 | |
65 | dpavlin | 6 | |
66 | #define ARC_CONSOLE_MAX_X 80 | ||
67 | #define ARC_CONSOLE_MAX_Y 25 | ||
68 | |||
69 | #define ARC_MAX_ESC 16 | ||
70 | |||
71 | #define MAX_OPEN_STRINGLEN 200 | ||
72 | #define ARC_MAX_HANDLES 10 | ||
73 | |||
74 | #define MAX_STRING_TO_COMPONENT 20 | ||
75 | #define MAX_CONFIG_DATA 50 | ||
76 | |||
77 | struct machine_arcbios { | ||
78 | /* General stuff: */ | ||
79 | int arc_64bit; | ||
80 | int wordlen; /* cached */ | ||
81 | |||
82 | /* VGA Console I/O: */ | ||
83 | int vgaconsole; /* 1 or 0 */ | ||
84 | uint64_t console_vram; | ||
85 | uint64_t console_ctrlregs; | ||
86 | char escape_sequence[ARC_MAX_ESC+1]; | ||
87 | int in_escape_sequence; | ||
88 | int console_maxx; | ||
89 | int console_maxy; | ||
90 | int console_curx; | ||
91 | int console_cury; | ||
92 | int console_reverse; | ||
93 | int console_curcolor; | ||
94 | |||
95 | /* File handles: */ | ||
96 | int file_handle_in_use[ARC_MAX_HANDLES]; | ||
97 | char *file_handle_string[ARC_MAX_HANDLES]; | ||
98 | uint64_t current_seek_offset[ARC_MAX_HANDLES]; | ||
99 | |||
100 | /* Memory: */ | ||
101 | int n_memdescriptors; | ||
102 | uint64_t memdescriptor_base; | ||
103 | |||
104 | /* Component tree: */ | ||
105 | uint64_t next_component_address; | ||
106 | int n_components; | ||
107 | |||
108 | char *string_to_component[MAX_STRING_TO_COMPONENT]; | ||
109 | uint64_t string_to_component_value[MAX_STRING_TO_COMPONENT]; | ||
110 | int n_string_to_components; | ||
111 | |||
112 | /* Configuration data: */ | ||
113 | int n_configuration_data; | ||
114 | uint64_t configuration_data_next_addr; | ||
115 | uint64_t configuration_data_component[MAX_CONFIG_DATA]; | ||
116 | int configuration_data_len[MAX_CONFIG_DATA]; | ||
117 | uint64_t configuration_data_configdata[MAX_CONFIG_DATA]; | ||
118 | |||
119 | /* SCSI: */ | ||
120 | uint64_t scsicontroller; /* component addr */ | ||
121 | }; | ||
122 | |||
123 | |||
124 | dpavlin | 4 | /* For internal use in arcbios.c: */ |
125 | |||
126 | struct emul_arc_child { | ||
127 | uint32_t ptr_peer; | ||
128 | uint32_t ptr_child; | ||
129 | uint32_t ptr_parent; | ||
130 | struct arcbios_component component; | ||
131 | }; | ||
132 | |||
133 | struct emul_arc_child64 { | ||
134 | uint64_t ptr_peer; | ||
135 | uint64_t ptr_child; | ||
136 | uint64_t ptr_parent; | ||
137 | struct arcbios_component64 component; | ||
138 | }; | ||
139 | |||
140 | |||
141 | #endif /* ARCBIOS_H */ |
ViewVC Help | |
Powered by ViewVC 1.1.26 |