-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathChangeLog
490 lines (433 loc) · 23.4 KB
/
ChangeLog
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
2013-09-07 Hugo Villeneuve <hugo@hugovil.com>
* Fix compiler warnings
* Fix error with CJNE instruction.
Error report and patch submission by Tobias Diedrich
(ranma at tdiedrich.de).
2011-12-11 Hugo Villeneuve <hugo@hugovil.com>
* Added optional size parameter when dumping memory.
* Created two separate executables, emu8051-cli (default)
and optional emu8051-gtk if Gtk+ is detected.
2011-10-29 Hugo Villeneuve <hugo@hugovil.com>
* Fixed SJMP error and improved columns and rows sizing.
Error reported and patch submitted by Pierre Ferrari
(piferr4ri at gmail.com).
2010-03-19 Hugo Villeneuve <hugo@hugovil.com>
* Reintroduced the console mode if no GTK+ librairies are
detected. The default is to build the GUI if GTK+ is detected,
but the console mode can always be forced by using
"--enable-gui=no" as a configure option.
2009-02-09 Hugo Villeneuve <hugo@hugovil.com>
* Updated Free Software Foundation address.
2008-11-05 Hugo Villeneuve <hugo@hugovil.com>
* Added licencing informations for each source file.
* Removed some debugging messages.
2008-04-28 Hugo Villeneuve <hugo@hugovil.com>
* Removed gtk+-1.0 support, now requires gtk+-2
2004-05-07 Hugo Villeneuve <hugo@hugovil.com>
* Corrected a bug with the CJNE instruction.
* Modified the directory layout and autoconf files.
* Added support for GTK2.
* Added project to subversion.
2002-11-12 Hugo Villeneuve <hugo@hugovil.com>
* Removed some warnings for GCC 3.2: replaced <fstream.h> by <fstream>
and <iostream.h> by <iostream>.
* Added "using namespace std;" in EmuGtk.hpp (for GCC 3.2)
* Removed all unused variables
* Corrected error in CPU8051.cpp, in function:
'void CPU8051::IntMemBitInfo( unsigned int BitAddress, char *Text )'
Modified this:
'sprintf( &Text[ TextLength ], ".%X", BitAddress );'
instead of:
'sprintf( &Text[ TextLength ], ".%X" );'
* In Opcode2cpp.pl (line 767), modified for GCC 3.2:
'print INST_IMP " funcptr[$i]=&CPU8051::$ifunc;\n";'
instead of:
'print INST_IMP " funcptr[$i]=&$ifunc;\n";'
* EmuGtk.cpp, added '#include <iostream>'
* Modified the return type of some functions to void to remove warnings.
* In function 'void RegWin::Show( CPU8051 *CPU )' (RegWin.cpp), removed all
the '\n' in 'gtk_clist_set_text' calls (to fix a display problem)
1999-04-27 Hugo Villeneuve <hugo@hugovil.com>
* Ajoute les fonctions DumpInt dans EmuConsole.hpp ainsi que ReadInt
dans CPU8051.hpp. Corrige des bugs dans WriteInt et WriteExt.
* Corrige l'implementation des timers. Les 4 modes ont ete testes et
semblent bien fonctionner maintenant. LEs flags sont mis correctement
et les timers augmentent maintenant (au lieu d'etre decrementes).
* Ajoute un fichier timer.hex pour tester les timers.
1999-04-22 Hugo Villeneuve <hugo@hugovil.com>
* Ajoute les fonctions ME, MI et MP (voir definitions dans
EmuConsole.cpp). Ajoute les fonctions membres WriteExt et WriteInt
dans la classe CPU8051 afin de suivre la logique de l'espace
memoire du 8051. WriteExt permet de modifier la memoire externe
qui va de $00 a $FFFF (et non de $100 a $FFFF comme c'etait le cas
avant). De meme, WriteInt permet de modifier la memoire interne qui
va de $00 a $FF (incluant les SFR). Meme si la memoire externe
contient les adresses $00 a $FF, il n'y a pas de conflit avec la
memoire interne de $00 a $FF car la memoire externe est accedee avec
l'instruction MOVX alors que la memoire interne l'est avec les
instructions MOV (direct ou indirect).
* Renomme l'option DD du menu pour DE (dump External data memory).
Change la description de l'option DI du menu pour Dump External
Data Memory.
* Ajoute la fonction ReadExt dans la classe CPU8051, toujours pour
la logique de la memoire du 8051. Ajoute la fonction DumpExt dans la
classe EmuConsole pour dumper la memoire externe.
* Ces nouvelles fonctions ont ete testees et semblent bien fonctionner.
1999-04-09 Jonathan St-Andre <standr00@gel.ulaval.ca>
* Refait marche le RunningState avec les classes.
* Reconnecte les signaux aux boutons Trace, Run, Reset et Quit.
* Ajoute bouton Step qui ajoute un breakpoint a la ligne suivante
et passe en RunningState. Pratique lorsqu'arrive un CALL et qu'on ne
veut pas y entrer contrairement a Trace.
1999-04-06 Jonathan St-Andre <standr00@gel.ulaval.ca>
* Creation de EmuConsole.hpp et EmuConsole.cpp
* Cette nouvelle archive est presque rendue au meme niveau que
l'ancienne. Vous allez pouvoir commencer a laisser faire l'ancienne
et vous concentrer sur celle-ci.
(Les modifs annoncee se rapportent a l'ancienne archive mais elles ont ete
ramenee dans celle-ci par Jonathan St-Andre)
1999-04-05 Jonathan St-Andre <standr00@gel.ulaval.ca>
* Corrige qq malfonctions dans exec de mainconsole.cpp (nb d'inst.
peut etre l'infini, caractere est attendu au clavier seulement
si l'execution est arretee par une touche.
* Corrige probleme d'instructions sans operandes mal desassemblees
(il ne faut pas ecrire le caractere ' ' dans la chaine, il faut
utiliser sprintf avec " " a la place car sprintf termine la chaine
avec un 0 a la fin. La chaine n'etait pas terminee par un 0 et elle
affichait du garbage de la memoire)
* Corrige probleme dans disasm.cpp en rapport avec addr11 qui ne
prenait pas opcode mais memoire[opcode] (je devais etre chaud quand
j'ai ecrit ca).
* Bouton Run se change en Stop dans l'interface Gtk+ lorsque l'on
clique dessus et le cpu se met en mode execution. Les fonctions de
l'interface restent disponibles. N'importe quelle action dans
l'interface(excepte le fait de cliquer dans les fenetre memoire
et programme) cause l'arret de l'execution et la mise a jour
de l'affichage.
* Il est possible de placer des breakpoints pendant qu'il est
dans le "RunningState".
* Enleve les pixmaps sur les boutons dans l'interface Gtk+
* Ajoute verification de breakpoint deja existant dans
setbreakpoint.
Hugo Villeneuve <hugo@hugovil.com>
* Modifie l'affichage de disasm pour que les operandes soient alignees.
* Modifie la fonction DP pour qu'elle prenne l'adresse du PC par
defaut si aucune adresse n'est specifiee.
* Erreur avec l'instruction ACALL qui ne calculait pas l'adresse
correctement et qui ne poussait pas l'adresse de retour sur la pile.
Il est important que le PC soit incremente de 2 avant de calculer
addr11 et de pousser le PC sur la pile...
Il faut aussi modifier le dessassemblage de cette instruction qui
n'affiche que la deuxieme operande (adresse de 8 bits), alors que
l'adresse est sur 11 bits...
* Erreur avec l'instruction RET( fichier siae1.asm adresse 03A4) ,
affiche RET @%K
* Ajoute la possibilite d'arreter l'execution du programme en pesant
sur n'importe quelle touche grace a la fonction kbhit().
* Ajoute les fonctions SB, RB et DB pour les breakpoints dans le
mode console. L'execution se fait jusqu'au breakpoint. Une fois
arrive au breakpoint, si on fait de nouveau EM, on peut continuer
l'execution du programme passe ce breakpoint. Autrement dit, EM
ne verifie pas si la premiere instruction qu'il execute est un
break point, ce qui est pratique pour continuer l'execution du prog
apres un breakpoint.
1999-03-31 Jonathan St-Andre <standr00@gel.ulaval.ca>
* Reecriture de TOUT les sources en imbriquant au maximum
dans des classes pour que ce soit plus lisible et reutilisable.
* Les classes sont CPU8051, Memory, EmuGtk, MemWin, RegWin, PgmWin
et les exceptions.
* Tout est en anglais pour rendre le programme disponible sur
internet.
* Je n'ai pas encore refais l'interface Console en classes donc
elle n'est pas incluse dans cette archive. Il faudrait vraiment
la refaire en tant que classe.
* Ajout fichiers TODO, CREDITS et COPYING (license GPL)
1999-03-30 Jonathan St-Andre <standr00@gel.ulaval.ca>
* Corrige bug lors du desassemblage dans l'interpretation des
adresses directes dans 0-7F. disasm.cpp
* Corrige bug dans l'opcode 0x85, ajoute conditions particulieres
pour cette instruction dans script Perl et dans desassemblage.
Les operandes de cette instruction sont inversees dans la memoire
programme. Ex.: MOV 50H,51H est ecrit 85 51 50 dans la memoire
programme.
Hugo Villeneuve <hugo@hugovil.com>
* Bug dans les instructions ayant un mode d'adressage direct qui
utilisent des adresses dans 0-7F. Le desassembleur interprete les
adresses comme etant des adresses de bit.
* Bug dans l'opcode 0x85 MOV direct,direct. La source et la
destination sont inverses dans le desassemblage et dans l'execution.
1999-03-29 Jonathan St-Andre <standr00@gel.ulaval.ca>
* Remplace string::erase pour string::replace partout, g++ a
l'universite ne connait pas encore string::erase, c'est trop recent.
* Ajoute "-w" pour disabler les warnings et "-fhandle-exceptions"
pour activer les exceptions a l'universite.
Pascal Fecteau <fectea00@gel.ulaval.ca>
* Ajoute .h comme extension aux fichiers inclus, sinon ca ne
fonctionne pas a l'universite.
Pascal Fecteau <fectea00@gel.ulaval.ca>
Hugo Villeneuve <hugo@hugovil.com>
* Corrige une erreur dans les instructions AJMP addr11
1999-03-28 Hugo Villeneuve <hugo@hugovil.com>
* Modification de la presentation de "Dump Register" sur la console.
Beaucoup plus facile a lire maintenant.
* Correction d'un bug dans l'instruction DA (opcode 0xD4).
1999-03-27 Hugo Villeneuve <hugo@hugovil.com>
* Correction d'un probleme avec l'instruction CJNE.
* Correction de bugs dans LoadHexFile (voir 1999-03-22)
Jonathan St-Andre <standr00@gel.ulaval.ca>
* Augmente la hauteur de la fenetre Internal RAM.
* Correction de probleme avec tous les XCH et XCHD, l'operande source
n'etait pas modifiee (Trouve par Hugo et suggestion de correction par
Hugo).
* Ajout de P0, P1, P2 et P3 dans la fenetre des registres.
(Suggestion d'Hugo).
* View -> Data Memory Dump et View -> Program Memory Dump sont
fonctionnels. On ne peut visionner que les 16384 premiers octets.
Il ne veut pas prendre 65536 lignes dans une scrolled window.
Probablement parce que 18colonnes x 65536lignes = 1179648 cellules
est beaucoup trop.
* J'ai remarque qu'avec Gtk, on peut facilement changer les raccoucis
dans les menus. Pour associer "View -> Program Memory Dump" au
raccourci "Alt-2" par exemple, il suffit d'aller dans le menu "View",
se placer au dessus de "Program Memory Dump" et appuyer "Alt-2".
Le menu se modifiera automatiquement pour afficher "Alt-2" au bout
de la ligne et desormais, lorsque vous appuierez "Alt-2", l'action
sera executee. Ca dure seulement durant la session presente.
* Reduit la taille de la fenetre principale en largeur de 120 pixels
et en hauteur de 20 pixels.
1999-03-25 Jonathan St-Andre <standr00@gel.ulaval.ca>
* Fenetre dump connais la position ou on clique dedans.
* Generalise dans une classe la fenetre memorydump, il sera plus
facile d'ajouter plusieurs fenetres memory dump a partir du menu
plus tard.
* Implemente Run jusqu'a un breakpoint (si aucun breakpoint,
loop sans fin -> il faut killer).
* Suffit de cliquer sur une ligne de programme dans Gtk pour placer
ou retirer un breakpoint. Les breakpoints apparaissent comme une
asterisque (*) a droite de l'adresse dans la fenetre program.
* Ajoute bouton Run dans interface Gtk
* Implemente quelques fonctions necessaires au breakpoints.
* Change un peu le layout
* Enleve image de fond (cause leger delai au chargement)
* Fait un peu de menage dans fichiers relatifs au Gtk
1999-03-23 Jonathan St-Andre <standr00@gel.ulaval.ca>
* Changement des champs GTK_TEXT des fenetres Registre, Program et
Internal RAM pour des champs GTK_CLIST. Plus beau, moins de
flickering quand on trace et plus pratique pour ce qui s'en vient.
* Integration des fichiers xpm dans l'executable. Mais c'est encore
trop long a charger lors de l'execution, va probablement falloir les
compresser ou laisser faire l'image de fond.
* Ajout de pixmaps sur les boutons Trace, Reset et Quit (Gtk)
* Ajout de pixmap comme fond (Gtk)
1999-03-22 Hugo Villeneuve <villen01@gel.ulaval.ca>
* Corrige un bug dans la fonction LoadHexFile : Le checksum n'etait
pas calcule correctement, ce qui entrainait des erreurs a l'ouverture
de certains fichiers HEX. L'erreur venait du fait que le checksum se
calculait avec la valeur absolue du LoadOffset, au lieu d'utiliser
les caracteres composant le LoadOffset. Exemple : si LoadOffset =
0103, il faut additionner 01h+03h=4h au Checksum et non pas 0103h =
259 en decimal.
* Deplace la fonction enleve_espaces de main_console vers mainemu
car elle est commune aux deux interfaces graphiques.
* Modifie la fonction majuscules pour qu'elle puisse convertir les
lettres de minuscule a majuscule meme si la chaine contient des
chiffres ou autres signes de ponctuation.
* Modifie la declaration des fonctions dans tous les fichiers .hpp:
enleve le nom des parametres car c'etait inutile.
* Stocke le nom des registres dans un fichier registres8051.hpp.
Ainsi, si on veut emuler un autre type de processeur, il suffira
de se creer un autre fichier registres8052xxx.hpp par exemple.
* Implemente l'affichage en francais ou en anglais dependant de
l'option passee sur la ligne de commande. L'interface est beaucoup
plus lisible de cette facon. Par defaut, l'affichage est en anglais.
1999-03-21 Hugo Villeneuve <villen01@gel.ulaval.ca>
* Ajoute deux parametres qu'on peut passer par la ligne de commande:
/? affiche les options disponibles sur la ligne de commande.
-f force l'affichage en francais (pas encore implemente!!!)
* Ajoute le controle d'erreur pour le chargement d'un fichier HEX.
Les differentes erreurs sont controlees ( checksum, rectype,
fin de fichier, etc.).
* Modifie la fonction unasm pour qu'elle accepte 0,1 ou 2 parametres.
U (adresse) (nombre d'instructions)
Si adresse et nombre d'instructions non-specifies:
Adresse = PC et Nombre d'Instructions = 16
Si adresse specifie et nombre d'instructions non-specifie:
Adresse = adresse specifiee et Nombre d'Instructions = 16
Si adresse specifie et nombre d'instructions specifie:
Adresse = adresse specifiee et Nombre d'Instructions = nb specifie
A noter: on peut specifier une adresse comme etant un nombre
hexadecimal, ou tout simplement en entrant "PC" ou "pc".
Jonathan St-Andre <standr00@gel.ulaval.ca
* Fait le menage dans la fonction main
* Modifie Makefile.console et Makefile.gtk
* Rearrangement des fichiers pour limiter les impacts sur
tout le projet lors de modifications dans une partie et
pour accelerer la compilation (en modules).
* Creation de mainconsole.hpp + mainconsole.cpp
* Creation de maingtk.cpp + maingtk.hpp
* Creation de mainemu.cpp + mainemu.hpp
* Elimine fonctions.cpp.
* Elimination du 2e parametre a unasm. Desassemble
de nouveau 16 instructions.
* Ajustement du menu pour qu'il rentre dans la largeur
d'un terminal 80x25.
Jimmy Ringuette <ringue00@gel.ulaval.ca>
* Ajout des interruptions du port serie.
* Ajout du timer 2 (8052).
1999-03-20 Hugo Villeneuve <villen01@gel.ulaval.ca>
* Separe le fichier main.cpp en deux: main.cpp et fonctions.cpp.
fonctions.cpp contient les fonctions necessaires a main.cpp.
* Ajoute un fichier exceptions.hpp qui permet de gerer les erreurs.
* Modifie le Makefile en consequence.
* On peut maintenant entrer les adresses < a quatre caracteres :
ex: adresse 0000h = 0 ou 00 ou 000 ou 0000.
* Enleve le include <stdlib.h>
* Remplace toutes les commandes printf du main par cout.
* Modifie l'apparence du menu.
* Le programme est maintenant plus robuste en ce qui concerne les
erreurs de syntaxe, les adresses invalides, etc (a tester...).
* Modifier l'operation et la syntaxe de certaines commandes
S (set register) devient MR (modify register) car set veut
plutot dire "mettre a 1", et on pourra aussi implementer
MM (modify Memory).
R devient DR (display Register), pour suivre la logique de
DP, DM et DI.
* Ajoute une commande Execute Memory: EM addr n
* La gestion des chaines de caracteres se fait maintenant
uniquement avec des variables de type STRING, selon le C++.
* Enleve variables i,j,k et inputcars dans le main.
* Modifie la fonction RESET pour quelle n'affiche pas les
registres au demarrage... ca faisait pas beau! Ajoute
cependant un message pour dire que le up est resette.
* Pour changer un registre, on doit entrer PC (et non p) ainsi
que SP (et non seulement s).
* Ajoute une fonction qui convertit une chaine de caracteres
en majuscules.
1999-03-19 Jonathan St-Andre <standr00@gel.ulaval.ca>
* Fonction reset51() ajoutee dans cpu8051.cpp, reset() ajoutee
dans main.cpp.
* Commande "Z" fait un reset du processeur sur la console et le
bouton Reset fonctionne dans le GUI.
Jimmy Ringuette <ringue00@gel.ulaval.ca>
* Les interruptions sont maintenant implementees. check_hardware() a
ete supprimee et Do_timers() est appelee directement de exec8051().
1999-03-18 Hugo Villeneuve <villen01@gel.ulaval.ca>
* Modifie l'entree des commandes pour gerer un peu plus les erreurs
de syntaxe (je n'ai pas fini, il y a encore de la job a faire pour
mettre ca error proof).
* Simplifie l'entree des parametres pour chacune des fonctions.
* Re-modifie l'instruction trace pour avoir seulement deux modes:
trace a adresse et trace 1 instruction. Cela simplifie l'entree de
la commande (on n'a pas a faire TA, qui n'est pas une commande
standard dans les emulateurs). Si on veut faire tracer pour plusieurs
instructions, alors il suffira d'implementer la commande
EXECUTE Nombre_instructions, ce qui est beaucoup plus logique et
c'est ce qu'on retrouve dans la plupart des emulateurs.
* Ajoute la description des commandes en francais (loi 101).
1999-03-18 Jonathan St-Andre <standr00@gel.ulaval.ca>
* Le bouton Trace dans la version Gtk+ fonctionne. On peut tracer
et les 3 fenetres(registres, memoire, programme) se mettent a jour.
* Ajout de 2 nouvelles fonctions trace : "tracenb()" et "traceat()"
Qui, respectivement, prenent un nombre d'instruction a executer ou
une adresse ou commencer l'execution. La fonction trace() a ete
resimplifiee.
* Dans les instructions RET, RETI, LCALL, PUSH et POP la pile prend
la iram seulement pour les adresses sous 0x80, la data RAM est
utilisee autrement. Avant, les SFR se faisaient ecraser!
* Modes d'addressage addr16, reladdr, #data16 modifies!
En tenant compte de ce que Hugo avait fait remarquer ce matin :
ex.: si PC++ apparait 2 fois sur une ligne, les 2 fois il repartira
de la meme valeur de PC et suite a cette ligne, on se trouve avec
un PC incremente 1 fois au lieu de 2.
* Menu accepte maj/minuscules
* Corrige bug dans "setreg", les registres peuvent vraiment
etre donnes en maj/minuscules maintenant.
1999-03-17 Hugo Villeneuve <villen01@gel.ulaval.ca
* Corrige les instructions LJMP et LCALL qui ne calculaient pas la
bonne adresse pour le PC. Toutes les autres instructions de
branchement sont probablement a revoir pour le meme probleme. Le
probleme etait cause par la syntaxe dans le fichier instructions.hpp
(lignes ou on retrouve addr16 = (pgm_mem[PC++] << 8)+pgm_mem[PC++] a
remplacer par addr16 = (pgm_mem[PC+1] << 8) + pgm_mem[PC+2] )
* Modifie la commande TRACE pour qu'on puisse lui passer une adresse
de depart comme parametre (main.cpp lignes 406-409) et modifie
en consequence ascii2hex pour qu'il ignore les espaces avant
l'adresse. (main.cpp ligne 133).
1999-03-14 Pascal Fecteau <fectea00@gel.ulaval.ca>
* Correction de bugs relatifs a la compilation sur VC5.
Dont ajout de #include <string.h>.
1999-03-13 Jimmy Ringuette <ringue00@gel.ulaval.ca>
* Ajout des timers dans cpu8051.cpp. Il faudrait tester a fond.
1999-03-12 Jonathan St-Andre <standr00@gel.ulaval.ca>
* Je crois qu'il sera plus interessant si on garde le memory
dump normal dans une fenetre exterieur et dont on pourra en ouvrir
plusieurs pour monitorer differents endroits de la memoire, c'est
pourquoi je n'ai place que "Internal RAM" comme memory dump dans
la fenetre principale.
* Au demarrage, effectue un premier memory dump dans la fenetre
"Internal RAM", un unasm dans "Program" et un show register dans
"Registers".
* Bouton Quit, menus "File -> Quit" et "Help -> About" reagissent.
* Comporte maintenant 2 Makefile : Makefile.console(fonctionne sur
toutes les plateformes) et Makefile.gtk(teste seulement sous Linux).
* DEBUT d'interface graphique Gtk+ (ne fait qu'afficher une fenetre
avec un layout tres simple), presentement je cours apres des sources
de documentations.(le manuel n'est pas encore complet)
1999-03-09 Jimmy Ringuette <ringue00@gel.ulaval.ca>
* Regle le bug avec mul (probleme avec les bits 15-8 du resultat
ne se ramenaient pas dans les bits 7-0 du registre B)
* La conversion chaine->hexadecimal accepte les minuscules
* Il n'est plus obligatoire d'ecrire les 4 caracteres lorsqu'il faut
entrer une valeur hexadecimale.
1999-03-05 Jonathan St-Andre <standr00@gel.ulaval.ca>
* Corrige un warning de compilation sous Solaris.
1999-03-04 Jonathan St-Andre <standr00@gel.ulaval.ca>
* Ca execute! (presque)
* Phase de corrections des bugs dans les instructions, une premiere
implementation est faite pour toutes les instructions.
* Ajout fonction "trace" et "dump internal memory"
* Les modes d'adressage sont pratiquement termines dans
les instructions.
* Certaines instructions ont un debut d'implementation.
* Desassembleur, bit addressable segment 00-7F -> 20.0-2F.7
1999-03-03 Jonathan St-Andre <standr00@gel.ulaval.ca>
* Ajout automatique de certaines lignes de codes concernant
l'adressage dans les fonctions d'instructions tres brouillon
* Ajout de stub pour write_mem et read_mem, modifs dans exec8051
* Ajout de la fonction showregister() et de la commande 'r'.
* Correction d'une erreur iram_mem doit etre unsigned char et non int
* Note : Il y a des references a certaines parties du 8052 mais
elles ne seront pas implementees. Ce n'est qu'a titre d'informations.
* Ajout de #define pour faire correspondre les registres SFR avec
leur adresse dans la iram.
* Renomme instructions.cpp a instructions.hpp et ajout du tableau
de pointeurs sur les fonctions
* Ajout de la ram interne 00-FF et valeurs initiale au reset
dans cpu8051.cpp avec le registre : unsigned int PC.
* Ajout de cpu8051.cpp contenant exec8051()
1999-03-02 Jonathan St-Andre <standr00@gel.ulaval.ca>
* Ajout de remarques dans le source
* Il faudrait maintenant tester avec plusieurs programmes pour
reperer les bugs.
* Le desassembleur reconnait maintenant les registres du SFR
(ex.: 88H est remplace par TCON, F0 par B, etc...)
* Changement au desassembleur (instructions peuvent avoir jusqu'a 3
arguments ex.: CJNE R0,#data,reladdr)
* La vrai instruction CJNE comporte 3 arguments il faut changer
radicalement le desassembleur
1999-03-01 Jonathan St-Andre <standr00@gel.ulaval.ca>
* Probleme dans opcodes.lst au niveau de l'instruction CJNE (mauvaise
definition)
* Tous les types d'adressages semblent fonctionner
* Le desassembleur peut lire les arguments et les afficher
(ex.: MOV A,#data peut devenir plus concret MOV A,#20)
* Desassembleur (instructions ont 2 arguments : instleftarg et
instrightarg)
1999-02-28 Jonathan St-Andre <standr00@gel.ulaval.ca>
* Charge un fichier .hex donne en parametre (format Intel Hexadecimal
produit par ASM51)
* Effectue le dump program memory et dump data memory
* On peut quitter (YEAH!)
* Affiche le menu
* Creation de opcodes.lst et script Perl pour l'interpreter
* Debut