annotate vmcmd.c @ 191:dbea22936623 src

when a command has been issued to leave a menu, filter all further commands for this menu
author mroi
date Tue, 06 May 2003 14:11:44 +0000
parents f050b83857c9
children a3d7b149cc0f
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
1 /*
189
f050b83857c9 Changed the linkage for msvc
tchamp
parents: 155
diff changeset
2 * This program is free software; you can redistribute it and/or modify
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
3 * it under the terms of the GNU General Public License as published by
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
4 * the Free Software Foundation; either version 2 of the License, or
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
5 * (at your option) any later version.
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
6 *
189
f050b83857c9 Changed the linkage for msvc
tchamp
parents: 155
diff changeset
7 * This program is distributed in the hope that it will be useful,
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
8 * but WITHOUT ANY WARRANTY; without even the implied warranty of
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
9 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
10 * GNU General Public License for more details.
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
11 *
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
12 * You should have received a copy of the GNU General Public License
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
13 * along with this program; if not, write to the Free Software
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
14 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
15 *
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
16 * $Id$
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
17 *
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
18 */
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
19
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
20 #ifdef HAVE_CONFIG_H
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
21 #include "config.h"
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
22 #endif
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
23
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
24 #include <stdio.h>
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
25 #include <ctype.h>
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
26 #include <inttypes.h>
11
1f479a99339c Change the bits function so that there are no global variables left.
jcdutton
parents: 10
diff changeset
27 #include <assert.h>
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
28
189
f050b83857c9 Changed the linkage for msvc
tchamp
parents: 155
diff changeset
29 #ifdef _MSC_VER
f050b83857c9 Changed the linkage for msvc
tchamp
parents: 155
diff changeset
30 #include <timer.h> /* struct timeval */
f050b83857c9 Changed the linkage for msvc
tchamp
parents: 155
diff changeset
31 #endif
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
32
189
f050b83857c9 Changed the linkage for msvc
tchamp
parents: 155
diff changeset
33 #include "vmcmd.h"
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
34
114
b6834e6359cf big libdvdnav cleanup, quoting the ChangeLog:
mroi
parents: 76
diff changeset
35
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
36 /* freebsd compatibility */
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
37 #ifndef PRIu8
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
38 #define PRIu8 "d"
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
39 #endif
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
40
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
41 /* freebsd compatibility */
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
42 #ifndef PRIu16
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
43 #define PRIu16 "d"
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
44 #endif
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
45
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
46 static const char *cmp_op_table[] = {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
47 NULL, "&", "==", "!=", ">=", ">", "<=", "<"
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
48 };
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
49 static const char *set_op_table[] = {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
50 NULL, "=", "<->", "+=", "-=", "*=", "/=", "%=", "rnd", "&=", "|=", "^="
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
51 };
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
52
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
53 static const char *link_table[] = {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
54 "LinkNoLink", "LinkTopC", "LinkNextC", "LinkPrevC",
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
55 NULL, "LinkTopPG", "LinkNextPG", "LinkPrevPG",
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
56 NULL, "LinkTopPGC", "LinkNextPGC", "LinkPrevPGC",
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
57 "LinkGoUpPGC", "LinkTailPGC", NULL, NULL,
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
58 "RSM"
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
59 };
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
60
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
61 static const char *system_reg_table[] = {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
62 "Menu Description Language Code",
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
63 "Audio Stream Number",
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
64 "Sub-picture Stream Number",
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
65 "Angle Number",
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
66 "Title Track Number",
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
67 "VTS Title Track Number",
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
68 "VTS PGC Number",
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
69 "PTT Number for One_Sequential_PGC_Title",
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
70 "Highlighted Button Number",
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
71 "Navigation Timer",
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
72 "Title PGC Number for Navigation Timer",
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
73 "Audio Mixing Mode for Karaoke",
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
74 "Country Code for Parental Management",
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
75 "Parental Level",
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
76 "Player Configurations for Video",
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
77 "Player Configurations for Audio",
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
78 "Initial Language Code for Audio",
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
79 "Initial Language Code Extension for Audio",
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
80 "Initial Language Code for Sub-picture",
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
81 "Initial Language Code Extension for Sub-picture",
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
82 "Player Regional Code",
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
83 "Reserved 21",
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
84 "Reserved 22",
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
85 "Reserved 23"
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
86 };
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
87
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
88 static const char *system_reg_abbr_table[] = {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
89 NULL,
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
90 "ASTN",
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
91 "SPSTN",
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
92 "AGLN",
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
93 "TTN",
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
94 "VTS_TTN",
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
95 "TT_PGCN",
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
96 "PTTN",
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
97 "HL_BTNN",
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
98 "NVTMR",
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
99 "NV_PGCN",
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
100 NULL,
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
101 "CC_PLT",
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
102 "PLT",
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
103 NULL,
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
104 NULL,
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
105 NULL,
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
106 NULL,
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
107 NULL,
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
108 NULL,
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
109 NULL,
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
110 NULL,
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
111 NULL,
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
112 NULL,
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
113 };
148
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
114
189
f050b83857c9 Changed the linkage for msvc
tchamp
parents: 155
diff changeset
115 typedef struct {
f050b83857c9 Changed the linkage for msvc
tchamp
parents: 155
diff changeset
116 uint16_t SPRM[24];
f050b83857c9 Changed the linkage for msvc
tchamp
parents: 155
diff changeset
117 uint16_t GPRM[16];
f050b83857c9 Changed the linkage for msvc
tchamp
parents: 155
diff changeset
118 uint8_t GPRM_mode[16]; /* Need to have some thing to indicate normal/counter mode for every
f050b83857c9 Changed the linkage for msvc
tchamp
parents: 155
diff changeset
119 GPRM */
f050b83857c9 Changed the linkage for msvc
tchamp
parents: 155
diff changeset
120 struct timeval GPRM_time[16]; /* For counter mode */
f050b83857c9 Changed the linkage for msvc
tchamp
parents: 155
diff changeset
121 } registers_t;
f050b83857c9 Changed the linkage for msvc
tchamp
parents: 155
diff changeset
122
f050b83857c9 Changed the linkage for msvc
tchamp
parents: 155
diff changeset
123 typedef struct
f050b83857c9 Changed the linkage for msvc
tchamp
parents: 155
diff changeset
124 {
f050b83857c9 Changed the linkage for msvc
tchamp
parents: 155
diff changeset
125 uint64_t instruction;
f050b83857c9 Changed the linkage for msvc
tchamp
parents: 155
diff changeset
126 uint64_t examined;
f050b83857c9 Changed the linkage for msvc
tchamp
parents: 155
diff changeset
127 registers_t *registers;
f050b83857c9 Changed the linkage for msvc
tchamp
parents: 155
diff changeset
128 } command_t;
f050b83857c9 Changed the linkage for msvc
tchamp
parents: 155
diff changeset
129
f050b83857c9 Changed the linkage for msvc
tchamp
parents: 155
diff changeset
130 uint32_t vm_getbits(command_t *command, int start, int count) {
f050b83857c9 Changed the linkage for msvc
tchamp
parents: 155
diff changeset
131 uint64_t result = 0;
f050b83857c9 Changed the linkage for msvc
tchamp
parents: 155
diff changeset
132 uint64_t bit_mask=~0; /* I could put -1 instead */
f050b83857c9 Changed the linkage for msvc
tchamp
parents: 155
diff changeset
133 uint64_t examining = 0;
f050b83857c9 Changed the linkage for msvc
tchamp
parents: 155
diff changeset
134 int32_t bits;
f050b83857c9 Changed the linkage for msvc
tchamp
parents: 155
diff changeset
135 if (count == 0) return 0;
f050b83857c9 Changed the linkage for msvc
tchamp
parents: 155
diff changeset
136
f050b83857c9 Changed the linkage for msvc
tchamp
parents: 155
diff changeset
137 if ( ((start - count) < -1) ||
f050b83857c9 Changed the linkage for msvc
tchamp
parents: 155
diff changeset
138 (count > 32) ||
f050b83857c9 Changed the linkage for msvc
tchamp
parents: 155
diff changeset
139 (start > 63) ||
f050b83857c9 Changed the linkage for msvc
tchamp
parents: 155
diff changeset
140 (count < 0) ||
f050b83857c9 Changed the linkage for msvc
tchamp
parents: 155
diff changeset
141 (start < 0) ){
f050b83857c9 Changed the linkage for msvc
tchamp
parents: 155
diff changeset
142 fprintf(stderr, "Bad call to vm_getbits. Parameter out of range\n");
f050b83857c9 Changed the linkage for msvc
tchamp
parents: 155
diff changeset
143 assert(0);
f050b83857c9 Changed the linkage for msvc
tchamp
parents: 155
diff changeset
144 }
f050b83857c9 Changed the linkage for msvc
tchamp
parents: 155
diff changeset
145 bit_mask >>= 63 - start;
f050b83857c9 Changed the linkage for msvc
tchamp
parents: 155
diff changeset
146 bits = start + 1 - count;
f050b83857c9 Changed the linkage for msvc
tchamp
parents: 155
diff changeset
147 examining = ((bit_mask >> bits) << bits );
f050b83857c9 Changed the linkage for msvc
tchamp
parents: 155
diff changeset
148 command->examined |= examining;
f050b83857c9 Changed the linkage for msvc
tchamp
parents: 155
diff changeset
149 result = (command->instruction & bit_mask) >> bits;
f050b83857c9 Changed the linkage for msvc
tchamp
parents: 155
diff changeset
150 return (uint32_t) result;
f050b83857c9 Changed the linkage for msvc
tchamp
parents: 155
diff changeset
151 }
f050b83857c9 Changed the linkage for msvc
tchamp
parents: 155
diff changeset
152
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
153 static void print_system_reg(uint16_t reg) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
154 if(reg < sizeof(system_reg_abbr_table) / sizeof(char *))
148
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
155 fprintf(MSG_OUT, "%s (SRPM:%d)", system_reg_table[reg], reg);
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
156 else
76
0e2abe7083de more consistent console output
mroi
parents: 15
diff changeset
157 fprintf(MSG_OUT, " WARNING: Unknown system register ( reg=%d ) ", reg);
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
158 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
159
148
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
160 static void print_g_reg(uint8_t reg) {
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
161 if(reg < 16)
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
162 fprintf(MSG_OUT, "g[%" PRIu8 "]", reg);
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
163 else
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
164 fprintf(MSG_OUT, " WARNING: Unknown general register ");
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
165 }
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
166
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
167 static void print_reg(uint8_t reg) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
168 if(reg & 0x80)
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
169 print_system_reg(reg & 0x7f);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
170 else
148
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
171 print_g_reg(reg & 0x7f);
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
172 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
173
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
174 static void print_cmp_op(uint8_t op) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
175 if(op < sizeof(cmp_op_table) / sizeof(char *) && cmp_op_table[op] != NULL)
76
0e2abe7083de more consistent console output
mroi
parents: 15
diff changeset
176 fprintf(MSG_OUT, " %s ", cmp_op_table[op]);
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
177 else
76
0e2abe7083de more consistent console output
mroi
parents: 15
diff changeset
178 fprintf(MSG_OUT, " WARNING: Unknown compare op ");
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
179 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
180
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
181 static void print_set_op(uint8_t op) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
182 if(op < sizeof(set_op_table) / sizeof(char *) && set_op_table[op] != NULL)
76
0e2abe7083de more consistent console output
mroi
parents: 15
diff changeset
183 fprintf(MSG_OUT, " %s ", set_op_table[op]);
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
184 else
76
0e2abe7083de more consistent console output
mroi
parents: 15
diff changeset
185 fprintf(MSG_OUT, " WARNING: Unknown set op ");
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
186 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
187
148
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
188 static void print_reg_or_data(command_t* command, int immediate, int start) {
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
189 if(immediate) {
189
f050b83857c9 Changed the linkage for msvc
tchamp
parents: 155
diff changeset
190 uint32_t i = vm_getbits(command, start, 16);
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
191
76
0e2abe7083de more consistent console output
mroi
parents: 15
diff changeset
192 fprintf(MSG_OUT, "0x%x", i);
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
193 if(isprint(i & 0xff) && isprint((i>>8) & 0xff))
76
0e2abe7083de more consistent console output
mroi
parents: 15
diff changeset
194 fprintf(MSG_OUT, " (\"%c%c\")", (char)((i>>8) & 0xff), (char)(i & 0xff));
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
195 } else {
148
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
196 print_reg(vm_getbits(command, start - 8, 8));
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
197 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
198 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
199
148
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
200 static void print_reg_or_data_2(command_t* command, int immediate, int start) {
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
201 if(immediate)
152
3a1659f4a6c3 Remove byte references. Convert them to bit references.
jcdutton
parents: 148
diff changeset
202 fprintf(MSG_OUT, "0x%x", vm_getbits(command, start - 1, 7));
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
203 else
148
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
204 fprintf(MSG_OUT, "g[%" PRIu8 "]", vm_getbits(command, start - 4, 4));
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
205 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
206
148
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
207 static void print_reg_or_data_3(command_t* command, int immediate, int start) {
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
208 if(immediate) {
189
f050b83857c9 Changed the linkage for msvc
tchamp
parents: 155
diff changeset
209 uint32_t i = vm_getbits(command, start, 16);
148
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
210
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
211 fprintf(MSG_OUT, "0x%x", i);
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
212 if(isprint(i & 0xff) && isprint((i>>8) & 0xff))
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
213 fprintf(MSG_OUT, " (\"%c%c\")", (char)((i>>8) & 0xff), (char)(i & 0xff));
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
214 } else {
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
215 print_reg(vm_getbits(command, start, 8));
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
216 }
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
217 }
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
218
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
219
11
1f479a99339c Change the bits function so that there are no global variables left.
jcdutton
parents: 10
diff changeset
220 static void print_if_version_1(command_t* command) {
148
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
221 uint8_t op = vm_getbits(command, 54, 3);
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
222
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
223 if(op) {
76
0e2abe7083de more consistent console output
mroi
parents: 15
diff changeset
224 fprintf(MSG_OUT, "if (");
155
840e99bfb57d Some updates from ifodump at dvd.sf.net
jcdutton
parents: 154
diff changeset
225 print_g_reg(vm_getbits(command,39,8));
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
226 print_cmp_op(op);
148
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
227 print_reg_or_data(command, vm_getbits(command, 55,1), 31);
76
0e2abe7083de more consistent console output
mroi
parents: 15
diff changeset
228 fprintf(MSG_OUT, ") ");
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
229 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
230 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
231
11
1f479a99339c Change the bits function so that there are no global variables left.
jcdutton
parents: 10
diff changeset
232 static void print_if_version_2(command_t* command) {
148
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
233 uint8_t op = vm_getbits(command, 54, 3);
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
234
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
235 if(op) {
76
0e2abe7083de more consistent console output
mroi
parents: 15
diff changeset
236 fprintf(MSG_OUT, "if (");
148
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
237 print_reg(vm_getbits(command, 15, 8));
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
238 print_cmp_op(op);
148
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
239 print_reg(vm_getbits(command, 7, 8));
76
0e2abe7083de more consistent console output
mroi
parents: 15
diff changeset
240 fprintf(MSG_OUT, ") ");
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
241 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
242 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
243
11
1f479a99339c Change the bits function so that there are no global variables left.
jcdutton
parents: 10
diff changeset
244 static void print_if_version_3(command_t* command) {
148
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
245 uint8_t op = vm_getbits(command, 54, 3);
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
246
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
247 if(op) {
76
0e2abe7083de more consistent console output
mroi
parents: 15
diff changeset
248 fprintf(MSG_OUT, "if (");
155
840e99bfb57d Some updates from ifodump at dvd.sf.net
jcdutton
parents: 154
diff changeset
249 print_g_reg(vm_getbits(command, 43, 4));
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
250 print_cmp_op(op);
148
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
251 print_reg_or_data(command, vm_getbits(command, 55, 1), 15);
76
0e2abe7083de more consistent console output
mroi
parents: 15
diff changeset
252 fprintf(MSG_OUT, ") ");
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
253 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
254 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
255
11
1f479a99339c Change the bits function so that there are no global variables left.
jcdutton
parents: 10
diff changeset
256 static void print_if_version_4(command_t* command) {
148
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
257 uint8_t op = vm_getbits(command, 54, 3);
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
258
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
259 if(op) {
76
0e2abe7083de more consistent console output
mroi
parents: 15
diff changeset
260 fprintf(MSG_OUT, "if (");
148
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
261 print_g_reg(vm_getbits(command, 51, 4));
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
262 print_cmp_op(op);
148
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
263 print_reg_or_data(command, vm_getbits(command, 55, 1), 31);
76
0e2abe7083de more consistent console output
mroi
parents: 15
diff changeset
264 fprintf(MSG_OUT, ") ");
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
265 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
266 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
267
148
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
268 static void print_if_version_5(command_t* command) {
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
269 uint8_t op = vm_getbits(command, 54, 3);
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
270 int set_immediate = vm_getbits(command, 60, 1);
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
271
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
272 if(op) {
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
273 if (set_immediate) {
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
274 fprintf(MSG_OUT, "if (");
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
275 print_g_reg(vm_getbits(command, 31, 8));
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
276 print_cmp_op(op);
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
277 print_reg(vm_getbits(command, 23, 8));
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
278 fprintf(MSG_OUT, ") ");
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
279 } else {
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
280 fprintf(MSG_OUT, "if (");
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
281 print_g_reg(vm_getbits(command, 39, 8));
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
282 print_cmp_op(op);
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
283 print_reg_or_data(command, vm_getbits(command, 55, 1), 31);
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
284 fprintf(MSG_OUT, ") ");
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
285 }
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
286 }
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
287 }
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
288
11
1f479a99339c Change the bits function so that there are no global variables left.
jcdutton
parents: 10
diff changeset
289 static void print_special_instruction(command_t* command) {
148
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
290 uint8_t op = vm_getbits(command, 51, 4);
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
291
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
292 switch(op) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
293 case 0: /* NOP */
76
0e2abe7083de more consistent console output
mroi
parents: 15
diff changeset
294 fprintf(MSG_OUT, "Nop");
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
295 break;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
296 case 1: /* Goto line */
148
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
297 fprintf(MSG_OUT, "Goto %" PRIu8, vm_getbits(command, 7, 8));
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
298 break;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
299 case 2: /* Break */
76
0e2abe7083de more consistent console output
mroi
parents: 15
diff changeset
300 fprintf(MSG_OUT, "Break");
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
301 break;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
302 case 3: /* Parental level */
76
0e2abe7083de more consistent console output
mroi
parents: 15
diff changeset
303 fprintf(MSG_OUT, "SetTmpPML %" PRIu8 ", Goto %" PRIu8,
148
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
304 vm_getbits(command, 11, 4), vm_getbits(command, 7, 8));
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
305 break;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
306 default:
76
0e2abe7083de more consistent console output
mroi
parents: 15
diff changeset
307 fprintf(MSG_OUT, "WARNING: Unknown special instruction (%i)",
148
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
308 vm_getbits(command, 51, 4));
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
309 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
310 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
311
11
1f479a99339c Change the bits function so that there are no global variables left.
jcdutton
parents: 10
diff changeset
312 static void print_linksub_instruction(command_t* command) {
189
f050b83857c9 Changed the linkage for msvc
tchamp
parents: 155
diff changeset
313 uint32_t linkop = vm_getbits(command, 7, 8);
f050b83857c9 Changed the linkage for msvc
tchamp
parents: 155
diff changeset
314 uint32_t button = vm_getbits(command, 15, 6);
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
315
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
316 if(linkop < sizeof(link_table)/sizeof(char *) && link_table[linkop] != NULL)
76
0e2abe7083de more consistent console output
mroi
parents: 15
diff changeset
317 fprintf(MSG_OUT, "%s (button %" PRIu8 ")", link_table[linkop], button);
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
318 else
76
0e2abe7083de more consistent console output
mroi
parents: 15
diff changeset
319 fprintf(MSG_OUT, "WARNING: Unknown linksub instruction (%i)", linkop);
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
320 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
321
11
1f479a99339c Change the bits function so that there are no global variables left.
jcdutton
parents: 10
diff changeset
322 static void print_link_instruction(command_t* command, int optional) {
148
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
323 uint8_t op = vm_getbits(command, 51, 4);
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
324
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
325 if(optional && op)
76
0e2abe7083de more consistent console output
mroi
parents: 15
diff changeset
326 fprintf(MSG_OUT, ", ");
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
327
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
328 switch(op) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
329 case 0:
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
330 if(!optional)
76
0e2abe7083de more consistent console output
mroi
parents: 15
diff changeset
331 fprintf(MSG_OUT, "WARNING: NOP (link)!");
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
332 break;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
333 case 1:
11
1f479a99339c Change the bits function so that there are no global variables left.
jcdutton
parents: 10
diff changeset
334 print_linksub_instruction(command);
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
335 break;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
336 case 4:
148
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
337 fprintf(MSG_OUT, "LinkPGCN %" PRIu16, vm_getbits(command, 14, 15));
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
338 break;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
339 case 5:
76
0e2abe7083de more consistent console output
mroi
parents: 15
diff changeset
340 fprintf(MSG_OUT, "LinkPTT %" PRIu16 " (button %" PRIu8 ")",
148
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
341 vm_getbits(command, 9, 10), vm_getbits(command, 15, 6));
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
342 break;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
343 case 6:
76
0e2abe7083de more consistent console output
mroi
parents: 15
diff changeset
344 fprintf(MSG_OUT, "LinkPGN %" PRIu8 " (button %" PRIu8 ")",
148
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
345 vm_getbits(command, 6, 7), vm_getbits(command, 15, 6));
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
346 break;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
347 case 7:
76
0e2abe7083de more consistent console output
mroi
parents: 15
diff changeset
348 fprintf(MSG_OUT, "LinkCN %" PRIu8 " (button %" PRIu8 ")",
148
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
349 vm_getbits(command, 7, 8), vm_getbits(command, 15, 6));
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
350 break;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
351 default:
76
0e2abe7083de more consistent console output
mroi
parents: 15
diff changeset
352 fprintf(MSG_OUT, "WARNING: Unknown link instruction");
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
353 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
354 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
355
11
1f479a99339c Change the bits function so that there are no global variables left.
jcdutton
parents: 10
diff changeset
356 static void print_jump_instruction(command_t* command) {
148
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
357 switch(vm_getbits(command, 51, 4)) {
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
358 case 1:
76
0e2abe7083de more consistent console output
mroi
parents: 15
diff changeset
359 fprintf(MSG_OUT, "Exit");
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
360 break;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
361 case 2:
148
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
362 fprintf(MSG_OUT, "JumpTT %" PRIu8, vm_getbits(command, 22, 7));
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
363 break;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
364 case 3:
148
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
365 fprintf(MSG_OUT, "JumpVTS_TT %" PRIu8, vm_getbits(command, 22, 7));
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
366 break;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
367 case 5:
76
0e2abe7083de more consistent console output
mroi
parents: 15
diff changeset
368 fprintf(MSG_OUT, "JumpVTS_PTT %" PRIu8 ":%" PRIu16,
148
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
369 vm_getbits(command, 22, 7), vm_getbits(command, 41, 10));
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
370 break;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
371 case 6:
148
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
372 switch(vm_getbits(command, 23, 2)) {
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
373 case 0:
76
0e2abe7083de more consistent console output
mroi
parents: 15
diff changeset
374 fprintf(MSG_OUT, "JumpSS FP");
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
375 break;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
376 case 1:
148
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
377 fprintf(MSG_OUT, "JumpSS VMGM (menu %" PRIu8 ")", vm_getbits(command, 19, 4));
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
378 break;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
379 case 2:
76
0e2abe7083de more consistent console output
mroi
parents: 15
diff changeset
380 fprintf(MSG_OUT, "JumpSS VTSM (vts %" PRIu8 ", title %" PRIu8
155
840e99bfb57d Some updates from ifodump at dvd.sf.net
jcdutton
parents: 154
diff changeset
381 ", menu %" PRIu8 ")", vm_getbits(command, 30, 7), vm_getbits(command, 38, 7), vm_getbits(command, 19, 4));
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
382 break;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
383 case 3:
148
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
384 fprintf(MSG_OUT, "JumpSS VMGM (pgc %" PRIu8 ")", vm_getbits(command, 46, 15));
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
385 break;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
386 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
387 break;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
388 case 8:
148
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
389 switch(vm_getbits(command, 23, 2)) {
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
390 case 0:
76
0e2abe7083de more consistent console output
mroi
parents: 15
diff changeset
391 fprintf(MSG_OUT, "CallSS FP (rsm_cell %" PRIu8 ")",
148
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
392 vm_getbits(command, 31, 8));
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
393 break;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
394 case 1:
76
0e2abe7083de more consistent console output
mroi
parents: 15
diff changeset
395 fprintf(MSG_OUT, "CallSS VMGM (menu %" PRIu8
148
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
396 ", rsm_cell %" PRIu8 ")", vm_getbits(command, 19, 4), vm_getbits(command, 31, 8));
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
397 break;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
398 case 2:
76
0e2abe7083de more consistent console output
mroi
parents: 15
diff changeset
399 fprintf(MSG_OUT, "CallSS VTSM (menu %" PRIu8
148
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
400 ", rsm_cell %" PRIu8 ")", vm_getbits(command, 19, 4), vm_getbits(command, 31, 8));
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
401 break;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
402 case 3:
76
0e2abe7083de more consistent console output
mroi
parents: 15
diff changeset
403 fprintf(MSG_OUT, "CallSS VMGM (pgc %" PRIu8 ", rsm_cell %" PRIu8 ")",
148
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
404 vm_getbits(command, 46, 15), vm_getbits(command, 31, 8));
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
405 break;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
406 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
407 break;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
408 default:
76
0e2abe7083de more consistent console output
mroi
parents: 15
diff changeset
409 fprintf(MSG_OUT, "WARNING: Unknown Jump/Call instruction");
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
410 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
411 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
412
11
1f479a99339c Change the bits function so that there are no global variables left.
jcdutton
parents: 10
diff changeset
413 static void print_system_set(command_t* command) {
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
414 int i;
155
840e99bfb57d Some updates from ifodump at dvd.sf.net
jcdutton
parents: 154
diff changeset
415 /* FIXME: What about SPRM11 ? Karaoke */
840e99bfb57d Some updates from ifodump at dvd.sf.net
jcdutton
parents: 154
diff changeset
416 /* Surely there must be some system set command for that ? */
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
417
148
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
418 switch(vm_getbits(command, 59, 4)) {
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
419 case 1: /* Set system reg 1 &| 2 &| 3 (Audio, Subp. Angle) */
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
420 for(i = 1; i <= 3; i++) {
155
840e99bfb57d Some updates from ifodump at dvd.sf.net
jcdutton
parents: 154
diff changeset
421 if(vm_getbits(command, 47 - (i*8), 1)) {
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
422 print_system_reg(i);
76
0e2abe7083de more consistent console output
mroi
parents: 15
diff changeset
423 fprintf(MSG_OUT, " = ");
148
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
424 print_reg_or_data_2(command, vm_getbits(command, 60, 1), 47 - (i*8) );
76
0e2abe7083de more consistent console output
mroi
parents: 15
diff changeset
425 fprintf(MSG_OUT, " ");
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
426 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
427 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
428 break;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
429 case 2: /* Set system reg 9 & 10 (Navigation timer, Title PGC number) */
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
430 print_system_reg(9);
76
0e2abe7083de more consistent console output
mroi
parents: 15
diff changeset
431 fprintf(MSG_OUT, " = ");
148
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
432 print_reg_or_data(command, vm_getbits(command, 60, 1), 47);
76
0e2abe7083de more consistent console output
mroi
parents: 15
diff changeset
433 fprintf(MSG_OUT, " ");
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
434 print_system_reg(10);
155
840e99bfb57d Some updates from ifodump at dvd.sf.net
jcdutton
parents: 154
diff changeset
435 fprintf(MSG_OUT, " = %" PRIu16, vm_getbits(command, 30, 15)); /* ?? */
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
436 break;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
437 case 3: /* Mode: Counter / Register + Set */
76
0e2abe7083de more consistent console output
mroi
parents: 15
diff changeset
438 fprintf(MSG_OUT, "SetMode ");
148
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
439 if(vm_getbits(command, 23, 1))
76
0e2abe7083de more consistent console output
mroi
parents: 15
diff changeset
440 fprintf(MSG_OUT, "Counter ");
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
441 else
76
0e2abe7083de more consistent console output
mroi
parents: 15
diff changeset
442 fprintf(MSG_OUT, "Register ");
155
840e99bfb57d Some updates from ifodump at dvd.sf.net
jcdutton
parents: 154
diff changeset
443 print_g_reg(vm_getbits(command, 19, 4));
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
444 print_set_op(0x1); /* '=' */
148
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
445 print_reg_or_data(command, vm_getbits(command, 60, 1), 47);
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
446 break;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
447 case 6: /* Set system reg 8 (Highlighted button) */
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
448 print_system_reg(8);
148
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
449 if(vm_getbits(command, 60, 1)) /* immediate */
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
450 fprintf(MSG_OUT, " = 0x%x (button no %d)", vm_getbits(command, 31, 16), vm_getbits(command, 31, 6));
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
451 else
148
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
452 fprintf(MSG_OUT, " = g[%" PRIu8 "]", vm_getbits(command, 19, 4));
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
453 break;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
454 default:
76
0e2abe7083de more consistent console output
mroi
parents: 15
diff changeset
455 fprintf(MSG_OUT, "WARNING: Unknown system set instruction (%i)",
148
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
456 vm_getbits(command, 59, 4));
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
457 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
458 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
459
11
1f479a99339c Change the bits function so that there are no global variables left.
jcdutton
parents: 10
diff changeset
460 static void print_set_version_1(command_t* command) {
148
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
461 uint8_t set_op = vm_getbits(command, 59, 4);
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
462
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
463 if(set_op) {
155
840e99bfb57d Some updates from ifodump at dvd.sf.net
jcdutton
parents: 154
diff changeset
464 print_g_reg(vm_getbits(command, 35, 4));
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
465 print_set_op(set_op);
148
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
466 print_reg_or_data(command, vm_getbits(command, 60, 1), 31);
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
467 } else {
76
0e2abe7083de more consistent console output
mroi
parents: 15
diff changeset
468 fprintf(MSG_OUT, "NOP");
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
469 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
470 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
471
11
1f479a99339c Change the bits function so that there are no global variables left.
jcdutton
parents: 10
diff changeset
472 static void print_set_version_2(command_t* command) {
148
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
473 uint8_t set_op = vm_getbits(command, 59, 4);
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
474
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
475 if(set_op) {
155
840e99bfb57d Some updates from ifodump at dvd.sf.net
jcdutton
parents: 154
diff changeset
476 print_g_reg(vm_getbits(command, 51, 4));
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
477 print_set_op(set_op);
148
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
478 print_reg_or_data(command, vm_getbits(command, 60, 1), 47);
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
479 } else {
76
0e2abe7083de more consistent console output
mroi
parents: 15
diff changeset
480 fprintf(MSG_OUT, "NOP");
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
481 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
482 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
483
148
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
484 static void print_set_version_3(command_t* command) {
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
485 uint8_t set_op = vm_getbits(command, 59, 4);
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
486
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
487 if(set_op) {
155
840e99bfb57d Some updates from ifodump at dvd.sf.net
jcdutton
parents: 154
diff changeset
488 print_g_reg(vm_getbits(command, 51, 4));
148
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
489 print_set_op(set_op);
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
490 print_reg_or_data_3(command, vm_getbits(command, 60, 1), 47);
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
491 } else {
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
492 fprintf(MSG_OUT, "NOP");
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
493 }
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
494 }
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
495
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
496
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
497 void vm_print_mnemonic(vm_cmd_t *vm_command) {
11
1f479a99339c Change the bits function so that there are no global variables left.
jcdutton
parents: 10
diff changeset
498 command_t command;
1f479a99339c Change the bits function so that there are no global variables left.
jcdutton
parents: 10
diff changeset
499 command.instruction =( (uint64_t) vm_command->bytes[0] << 56 ) |
1f479a99339c Change the bits function so that there are no global variables left.
jcdutton
parents: 10
diff changeset
500 ( (uint64_t) vm_command->bytes[1] << 48 ) |
1f479a99339c Change the bits function so that there are no global variables left.
jcdutton
parents: 10
diff changeset
501 ( (uint64_t) vm_command->bytes[2] << 40 ) |
1f479a99339c Change the bits function so that there are no global variables left.
jcdutton
parents: 10
diff changeset
502 ( (uint64_t) vm_command->bytes[3] << 32 ) |
1f479a99339c Change the bits function so that there are no global variables left.
jcdutton
parents: 10
diff changeset
503 ( (uint64_t) vm_command->bytes[4] << 24 ) |
1f479a99339c Change the bits function so that there are no global variables left.
jcdutton
parents: 10
diff changeset
504 ( (uint64_t) vm_command->bytes[5] << 16 ) |
1f479a99339c Change the bits function so that there are no global variables left.
jcdutton
parents: 10
diff changeset
505 ( (uint64_t) vm_command->bytes[6] << 8 ) |
1f479a99339c Change the bits function so that there are no global variables left.
jcdutton
parents: 10
diff changeset
506 (uint64_t) vm_command->bytes[7] ;
1f479a99339c Change the bits function so that there are no global variables left.
jcdutton
parents: 10
diff changeset
507 command.examined = 0;
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
508
148
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
509 switch(vm_getbits(&command,63,3)) { /* three first bits */
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
510 case 0: /* Special instructions */
11
1f479a99339c Change the bits function so that there are no global variables left.
jcdutton
parents: 10
diff changeset
511 print_if_version_1(&command);
1f479a99339c Change the bits function so that there are no global variables left.
jcdutton
parents: 10
diff changeset
512 print_special_instruction(&command);
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
513 break;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
514 case 1: /* Jump/Call or Link instructions */
148
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
515 if(vm_getbits(&command,60,1)) {
11
1f479a99339c Change the bits function so that there are no global variables left.
jcdutton
parents: 10
diff changeset
516 print_if_version_2(&command);
1f479a99339c Change the bits function so that there are no global variables left.
jcdutton
parents: 10
diff changeset
517 print_jump_instruction(&command);
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
518 } else {
11
1f479a99339c Change the bits function so that there are no global variables left.
jcdutton
parents: 10
diff changeset
519 print_if_version_1(&command);
1f479a99339c Change the bits function so that there are no global variables left.
jcdutton
parents: 10
diff changeset
520 print_link_instruction(&command, 0); /* must be pressent */
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
521 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
522 break;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
523 case 2: /* Set System Parameters instructions */
11
1f479a99339c Change the bits function so that there are no global variables left.
jcdutton
parents: 10
diff changeset
524 print_if_version_2(&command);
1f479a99339c Change the bits function so that there are no global variables left.
jcdutton
parents: 10
diff changeset
525 print_system_set(&command);
1f479a99339c Change the bits function so that there are no global variables left.
jcdutton
parents: 10
diff changeset
526 print_link_instruction(&command, 1); /* either 'if' or 'link' */
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
527 break;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
528 case 3: /* Set General Parameters instructions */
11
1f479a99339c Change the bits function so that there are no global variables left.
jcdutton
parents: 10
diff changeset
529 print_if_version_3(&command);
1f479a99339c Change the bits function so that there are no global variables left.
jcdutton
parents: 10
diff changeset
530 print_set_version_1(&command);
1f479a99339c Change the bits function so that there are no global variables left.
jcdutton
parents: 10
diff changeset
531 print_link_instruction(&command, 1); /* either 'if' or 'link' */
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
532 break;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
533 case 4: /* Set, Compare -> LinkSub instructions */
11
1f479a99339c Change the bits function so that there are no global variables left.
jcdutton
parents: 10
diff changeset
534 print_set_version_2(&command);
76
0e2abe7083de more consistent console output
mroi
parents: 15
diff changeset
535 fprintf(MSG_OUT, ", ");
11
1f479a99339c Change the bits function so that there are no global variables left.
jcdutton
parents: 10
diff changeset
536 print_if_version_4(&command);
1f479a99339c Change the bits function so that there are no global variables left.
jcdutton
parents: 10
diff changeset
537 print_linksub_instruction(&command);
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
538 break;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
539 case 5: /* Compare -> (Set and LinkSub) instructions */
148
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
540 print_if_version_5(&command);
76
0e2abe7083de more consistent console output
mroi
parents: 15
diff changeset
541 fprintf(MSG_OUT, "{ ");
148
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
542 print_set_version_3(&command);
76
0e2abe7083de more consistent console output
mroi
parents: 15
diff changeset
543 fprintf(MSG_OUT, ", ");
11
1f479a99339c Change the bits function so that there are no global variables left.
jcdutton
parents: 10
diff changeset
544 print_linksub_instruction(&command);
76
0e2abe7083de more consistent console output
mroi
parents: 15
diff changeset
545 fprintf(MSG_OUT, " }");
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
546 break;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
547 case 6: /* Compare -> Set, always LinkSub instructions */
148
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
548 print_if_version_5(&command);
76
0e2abe7083de more consistent console output
mroi
parents: 15
diff changeset
549 fprintf(MSG_OUT, "{ ");
148
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
550 print_set_version_3(&command);
76
0e2abe7083de more consistent console output
mroi
parents: 15
diff changeset
551 fprintf(MSG_OUT, " } ");
11
1f479a99339c Change the bits function so that there are no global variables left.
jcdutton
parents: 10
diff changeset
552 print_linksub_instruction(&command);
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
553 break;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
554 default:
148
5ddb33e104a8 Fix getbits to be more sensible.
jcdutton
parents: 136
diff changeset
555 fprintf(MSG_OUT, "WARNING: Unknown instruction type (%i)", vm_getbits(&command, 63, 3));
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
556 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
557 /* Check if there still are bits set that were not examined */
11
1f479a99339c Change the bits function so that there are no global variables left.
jcdutton
parents: 10
diff changeset
558
1f479a99339c Change the bits function so that there are no global variables left.
jcdutton
parents: 10
diff changeset
559 if(command.instruction & ~ command.examined) {
76
0e2abe7083de more consistent console output
mroi
parents: 15
diff changeset
560 fprintf(MSG_OUT, " libdvdnav: vmcmd.c: [WARNING, unknown bits:");
0e2abe7083de more consistent console output
mroi
parents: 15
diff changeset
561 fprintf(MSG_OUT, " %08llx", (command.instruction & ~ command.examined) );
0e2abe7083de more consistent console output
mroi
parents: 15
diff changeset
562 fprintf(MSG_OUT, "]");
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
563 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
564 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
565
153
175d5fef21e4 Minor changes.
jcdutton
parents: 152
diff changeset
566 void vm_print_cmd(int row, vm_cmd_t *vm_command) {
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
567 int i;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
568
76
0e2abe7083de more consistent console output
mroi
parents: 15
diff changeset
569 fprintf(MSG_OUT, "(%03d) ", row + 1);
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
570 for(i = 0; i < 8; i++)
76
0e2abe7083de more consistent console output
mroi
parents: 15
diff changeset
571 fprintf(MSG_OUT, "%02x ", vm_command->bytes[i]);
0e2abe7083de more consistent console output
mroi
parents: 15
diff changeset
572 fprintf(MSG_OUT, "| ");
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
573
153
175d5fef21e4 Minor changes.
jcdutton
parents: 152
diff changeset
574 vm_print_mnemonic(vm_command);
76
0e2abe7083de more consistent console output
mroi
parents: 15
diff changeset
575 fprintf(MSG_OUT, "\n");
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
576 }
10
6f0fb88d1463 Added some debug info, to hopefully help in tracking bugs in libdvdnav.
jcdutton
parents: 0
diff changeset
577
189
f050b83857c9 Changed the linkage for msvc
tchamp
parents: 155
diff changeset
578 /*
f050b83857c9 Changed the linkage for msvc
tchamp
parents: 155
diff changeset
579 * $Log$
f050b83857c9 Changed the linkage for msvc
tchamp
parents: 155
diff changeset
580 * Revision 1.14 2003/05/05 00:25:11 tchamp
f050b83857c9 Changed the linkage for msvc
tchamp
parents: 155
diff changeset
581 * Changed the linkage for msvc
f050b83857c9 Changed the linkage for msvc
tchamp
parents: 155
diff changeset
582 *
f050b83857c9 Changed the linkage for msvc
tchamp
parents: 155
diff changeset
583 * Revision 1.12 2003/05/01 16:44:43 tchamp
f050b83857c9 Changed the linkage for msvc
tchamp
parents: 155
diff changeset
584 * ifo_dump should now build with msvc version of libdvdnav
f050b83857c9 Changed the linkage for msvc
tchamp
parents: 155
diff changeset
585 *
f050b83857c9 Changed the linkage for msvc
tchamp
parents: 155
diff changeset
586 * Revision 1.11 2003/04/28 15:17:18 jcdutton
f050b83857c9 Changed the linkage for msvc
tchamp
parents: 155
diff changeset
587 * Update ifodump to work with new libdvdnav cvs, instead of needing libdvdread.
f050b83857c9 Changed the linkage for msvc
tchamp
parents: 155
diff changeset
588 *
f050b83857c9 Changed the linkage for msvc
tchamp
parents: 155
diff changeset
589 * Revision 1.10 2003/04/05 16:31:53 jcdutton
f050b83857c9 Changed the linkage for msvc
tchamp
parents: 155
diff changeset
590 * Some minor changes and updates.
f050b83857c9 Changed the linkage for msvc
tchamp
parents: 155
diff changeset
591 *
f050b83857c9 Changed the linkage for msvc
tchamp
parents: 155
diff changeset
592 * Revision 1.9 2003/04/05 15:23:07 jcdutton
f050b83857c9 Changed the linkage for msvc
tchamp
parents: 155
diff changeset
593 * Minor updates
f050b83857c9 Changed the linkage for msvc
tchamp
parents: 155
diff changeset
594 *
f050b83857c9 Changed the linkage for msvc
tchamp
parents: 155
diff changeset
595 * Revision 1.8 2003/04/05 13:03:49 jcdutton
f050b83857c9 Changed the linkage for msvc
tchamp
parents: 155
diff changeset
596 * Small updates.
f050b83857c9 Changed the linkage for msvc
tchamp
parents: 155
diff changeset
597 *
f050b83857c9 Changed the linkage for msvc
tchamp
parents: 155
diff changeset
598 * Revision 1.7 2003/04/05 12:45:47 jcdutton
f050b83857c9 Changed the linkage for msvc
tchamp
parents: 155
diff changeset
599 * Use MSG_OUT instead of stdout.
f050b83857c9 Changed the linkage for msvc
tchamp
parents: 155
diff changeset
600 *
f050b83857c9 Changed the linkage for msvc
tchamp
parents: 155
diff changeset
601 * Revision 1.6 2003/04/05 09:15:43 jcdutton
f050b83857c9 Changed the linkage for msvc
tchamp
parents: 155
diff changeset
602 * Minor fix
f050b83857c9 Changed the linkage for msvc
tchamp
parents: 155
diff changeset
603 *
f050b83857c9 Changed the linkage for msvc
tchamp
parents: 155
diff changeset
604 * Revision 1.5 2003/04/03 11:05:20 jcdutton
f050b83857c9 Changed the linkage for msvc
tchamp
parents: 155
diff changeset
605 * Tidy up.
f050b83857c9 Changed the linkage for msvc
tchamp
parents: 155
diff changeset
606 *
f050b83857c9 Changed the linkage for msvc
tchamp
parents: 155
diff changeset
607 * Revision 1.4 2003/04/03 11:01:36 jcdutton
f050b83857c9 Changed the linkage for msvc
tchamp
parents: 155
diff changeset
608 * Change byte references to bits.
f050b83857c9 Changed the linkage for msvc
tchamp
parents: 155
diff changeset
609 *
f050b83857c9 Changed the linkage for msvc
tchamp
parents: 155
diff changeset
610 * Revision 1.3 2003/04/03 10:51:28 jcdutton
f050b83857c9 Changed the linkage for msvc
tchamp
parents: 155
diff changeset
611 * Change getbits start param to actually start at the right bit.
f050b83857c9 Changed the linkage for msvc
tchamp
parents: 155
diff changeset
612 * e.g. lowest bit in a 64 bit number bit 0 and represents value of 1
f050b83857c9 Changed the linkage for msvc
tchamp
parents: 155
diff changeset
613 * next bit is a 64 bit number is bit 1 and represents a value of 2
f050b83857c9 Changed the linkage for msvc
tchamp
parents: 155
diff changeset
614 * next bit is a 64 bit number is bit 2 and represents a value of 4
f050b83857c9 Changed the linkage for msvc
tchamp
parents: 155
diff changeset
615 *
f050b83857c9 Changed the linkage for msvc
tchamp
parents: 155
diff changeset
616 * Before, a start value of 0 would represent bit 63, and a start value of 63 would represent bit 0.
f050b83857c9 Changed the linkage for msvc
tchamp
parents: 155
diff changeset
617 *
f050b83857c9 Changed the linkage for msvc
tchamp
parents: 155
diff changeset
618 * So, I changed it to be more common sense.
f050b83857c9 Changed the linkage for msvc
tchamp
parents: 155
diff changeset
619 *
f050b83857c9 Changed the linkage for msvc
tchamp
parents: 155
diff changeset
620 * Revision 1.2 2003/04/02 13:58:19 jcdutton
f050b83857c9 Changed the linkage for msvc
tchamp
parents: 155
diff changeset
621 * Fix some instruction printouts.
f050b83857c9 Changed the linkage for msvc
tchamp
parents: 155
diff changeset
622 *
f050b83857c9 Changed the linkage for msvc
tchamp
parents: 155
diff changeset
623 * Revision 1.1.1.1 2002/08/28 09:48:35 jcdutton
f050b83857c9 Changed the linkage for msvc
tchamp
parents: 155
diff changeset
624 * Initial import into CVS.
f050b83857c9 Changed the linkage for msvc
tchamp
parents: 155
diff changeset
625 *
f050b83857c9 Changed the linkage for msvc
tchamp
parents: 155
diff changeset
626 *
f050b83857c9 Changed the linkage for msvc
tchamp
parents: 155
diff changeset
627 *
f050b83857c9 Changed the linkage for msvc
tchamp
parents: 155
diff changeset
628 */