X-Git-Url: http://gitweb.hugovil.com/?a=blobdiff_plain;f=ChangeLog;fp=ChangeLog;h=0000000000000000000000000000000000000000;hb=6281db4c82900528c483089a10bbe96e3d9c9907;hp=e69986677431370a839d0f1b4757484e3051282c;hpb=34513fc19fe828b6dfba47fdadf7fc3363787515;p=emu8051.git diff --git a/ChangeLog b/ChangeLog deleted file mode 100644 index e699866..0000000 --- a/ChangeLog +++ /dev/null @@ -1,490 +0,0 @@ -2013-09-07 Hugo Villeneuve - * 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 - * 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 - * 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 - * 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 - * Updated Free Software Foundation address. - -2008-11-05 Hugo Villeneuve - * Added licencing informations for each source file. - * Removed some debugging messages. - -2008-04-28 Hugo Villeneuve - * Removed gtk+-1.0 support, now requires gtk+-2 - -2004-05-07 Hugo Villeneuve - * 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 - * Removed some warnings for GCC 3.2: replaced by - and by . - * 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 ' - * 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 - * 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 - * 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 - * 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 - * 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 - * 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 - - * 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 - * 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 - * 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 - - * 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 - * 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 - - * Ajoute .h comme extension aux fichiers inclus, sinon ca ne - fonctionne pas a l'universite. - - Pascal Fecteau - Hugo Villeneuve - - * Corrige une erreur dans les instructions AJMP addr11 - -1999-03-28 Hugo Villeneuve - * 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 - * Correction d'un probleme avec l'instruction CJNE. - * Correction de bugs dans LoadHexFile (voir 1999-03-22) - - Jonathan St-Andre - - * 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 - * 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 - * 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 - * 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 - * 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 - - * Ajout des interruptions du port serie. - * Ajout du timer 2 (8052). - -1999-03-20 Hugo Villeneuve - * 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 - * 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 - * 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 - - * Les interruptions sont maintenant implementees. check_hardware() a - ete supprimee et Do_timers() est appelee directement de exec8051(). - -1999-03-18 Hugo Villeneuve - * 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 - * 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 - * Correction de bugs relatifs a la compilation sur VC5. - Dont ajout de #include . - -1999-03-13 Jimmy Ringuette - * Ajout des timers dans cpu8051.cpp. Il faudrait tester a fond. - -1999-03-12 Jonathan St-Andre - * 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 - * 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 - * Corrige un warning de compilation sous Solaris. - -1999-03-04 Jonathan St-Andre - * 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 - * 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 - * 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 - * 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 - * 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