Microchip, C18, variable folle
Fermé
titusIII
Messages postés
93
Date d'inscription
jeudi 16 octobre 2008
Statut
Membre
Dernière intervention
16 décembre 2014
-
7 févr. 2014 à 18:59
Utilisateur anonyme - 20 févr. 2014 à 16:10
Utilisateur anonyme - 20 févr. 2014 à 16:10
32 réponses
Utilisateur anonyme
18 févr. 2014 à 23:44
18 févr. 2014 à 23:44
Heureusement que quand je t'avais fait remarquer qu'une de tes variables était un int, tu m'avais confirmé que c'était un char. Maintenant, tu te rends compte que c'est un int. Passons encore, mais essaye de donner des réponses exactes.
As-tu fait l'essai que je t'avais demandé de faire deux affichages consécutifs :
Pour l'envoi du code, zippe tout en un seul fichier et utilise le site cjoint.com ou un autre si tu as une préférence.
As-tu fait l'essai que je t'avais demandé de faire deux affichages consécutifs :
ecr_data(tmp + '0'); ecr_data(tmp + '0');
Pour l'envoi du code, zippe tout en un seul fichier et utilise le site cjoint.com ou un autre si tu as une préférence.
fiddy
Messages postés
11069
Date d'inscription
samedi 5 mai 2007
Statut
Contributeur
Dernière intervention
23 avril 2022
1 842
7 févr. 2014 à 22:27
7 févr. 2014 à 22:27
Bonjour,
Tout d'abord, plutôt que mettre 48, je te conseille de mettre '0'. C'est plus lisible et plus portable :-).
Sinon, le problème est bizarre. Ca sent le bon vieux stack overflow. Peux-tu donner ton code en entier ?
Cdlt,
Tout d'abord, plutôt que mettre 48, je te conseille de mettre '0'. C'est plus lisible et plus portable :-).
Sinon, le problème est bizarre. Ca sent le bon vieux stack overflow. Peux-tu donner ton code en entier ?
Cdlt,
titusIII
Messages postés
93
Date d'inscription
jeudi 16 octobre 2008
Statut
Membre
Dernière intervention
16 décembre 2014
2
Modifié par titusIII le 10/02/2014 à 18:23
Modifié par titusIII le 10/02/2014 à 18:23
char tmp,hourNextL3;
char next3[] = "Next 3 : ";
cursor(0,1);
ecr_string(next3);
hourNextL3 = 28;
tmp = hourNextL3 % 10;
ecr_data(tmp + 48);
Mon code est pas beaucoup plus compliqué.
Les drivers de mon LCD est fait maison, il a fait ses preuves, je l'écarte donc.
titusIII
Messages postés
93
Date d'inscription
jeudi 16 octobre 2008
Statut
Membre
Dernière intervention
16 décembre 2014
2
10 févr. 2014 à 18:24
10 févr. 2014 à 18:24
J'ai eu pas mal de problème pas très cohérents avec C18... Une autre histoire de variable que j'ai résolu en appliquant un genre de décalage de bit un peu bourrin...
Si tu avais un autre compilateur moins nerveux?
Si tu avais un autre compilateur moins nerveux?
Vous n’avez pas trouvé la réponse que vous recherchez ?
Posez votre question
titusIII
Messages postés
93
Date d'inscription
jeudi 16 octobre 2008
Statut
Membre
Dernière intervention
16 décembre 2014
2
Modifié par titusIII le 12/02/2014 à 19:57
Modifié par titusIII le 12/02/2014 à 19:57
excuse moi :
Et toujours 0 en sortie.
Et tout mon code est consacré au drivers LCD pour l'instant, mais je l'écarte.
char tmp,hourNextL3;
char next3[] = "Next 3 : ";
void fct()
{
cursor(0,1);
ecr_string(next3);
hourNextL3 = 28;
tmp = hourNextL3 % 10;
ecr_data(tmp + '0');
}
Et toujours 0 en sortie.
Et tout mon code est consacré au drivers LCD pour l'instant, mais je l'écarte.
Utilisateur anonyme
12 févr. 2014 à 20:50
12 févr. 2014 à 20:50
Bonjour
Je n'ai jamais eu de problèmes avec C18.
Vois-tu bien l'affichage de la chaîne "Next 3 : " ?
Peux-tu donner le prototype de ecr_data ? Pourquoi n'as tu pas gardé la fonction printCar que tu utilisais dans ton post initial ?
Je n'ai jamais eu de problèmes avec C18.
Vois-tu bien l'affichage de la chaîne "Next 3 : " ?
Peux-tu donner le prototype de ecr_data ? Pourquoi n'as tu pas gardé la fonction printCar que tu utilisais dans ton post initial ?
titusIII
Messages postés
93
Date d'inscription
jeudi 16 octobre 2008
Statut
Membre
Dernière intervention
16 décembre 2014
2
Modifié par titusIII le 13/02/2014 à 13:03
Modifié par titusIII le 13/02/2014 à 13:03
Parce que j'ai changé le nom de ma fonction, ça reste la même.
C'est la fonction qui me permet d'écrire un caractère sur mon afficheur, elle tourne bien, "Next 3 : " est bien affiché!
void ecr_data(char data){
PORTBbits.RB2 = 1;
hbit = data;
hbit >>=4;
PORTBbits.RB4 = hbit&0x01;
PORTCbits.RC6 = (hbit>>1)&0x01;
PORTCbits.RC5 = (hbit>>2)&0x01;
PORTCbits.RC4 = (hbit>>3)&0x01;
PORTBbits.RB3 = 1;
PORTBbits.RB3 = 0;
Delay10TCYx(1);
PORTBbits.RB4 = data&0x01;
PORTCbits.RC6 = (data>>1)&0x01;
PORTCbits.RC5 = (data>>2)&0x01;
PORTCbits.RC4 = (data>>3)&0x01;
PORTBbits.RB3 = 1;
PORTBbits.RB3 = 0;
Delay10TCYx(5);
}
titusIII
Messages postés
93
Date d'inscription
jeudi 16 octobre 2008
Statut
Membre
Dernière intervention
16 décembre 2014
2
13 févr. 2014 à 13:20
13 févr. 2014 à 13:20
une autre exemple :
Alors que
hourNextL3 = 28;
tmp = hourNextL3 % 10;
if (tmp == 8) ecr_data(8 + '0'); // n'affiche rien
Alors que
ecr_data(8 + '0'); // affiche bien 8
Utilisateur anonyme
13 févr. 2014 à 14:12
13 févr. 2014 à 14:12
Je viens de tester chez moi, ça se passe bien (en simulation de 18F4550).
Peux-tu vérifier dans le .map à quelles adresses sont tes variables hourNextL3 et tmp ?
Peux-tu vérifier dans le .map à quelles adresses sont tes variables hourNextL3 et tmp ?
titusIII
Messages postés
93
Date d'inscription
jeudi 16 octobre 2008
Statut
Membre
Dernière intervention
16 décembre 2014
2
Modifié par titusIII le 15/02/2014 à 23:08
Modifié par titusIII le 15/02/2014 à 23:08
Hournextl3 à 0x74
Et tmp à 0x78
Je vois pas le probleme encore une fois!
Je précise que j'ai déja changé de variable pour voir, de type de variable également.
Sinon j'ai une piste, toute petite et autant improbable... J'ai un timer qui génère une interruption toutes les secondes (je m'en sers pour faire horloge, heures minutes secondes), c'est assez improbable que ça fasse planter mon code, vu qu'il y a un système de PUSH-POP en arrière plan je suppose.
Ma fonction avec le modulo est appelée toutes les secondes et j'ai JAMAIS le résultat attendu. Ca serai un sacré manque de chance que mon timer la perturbe à ce point. J'essayerai sans pour voir, demain, quand j'aurai les yeux sur mon matériel.
Et tmp à 0x78
Je vois pas le probleme encore une fois!
Je précise que j'ai déja changé de variable pour voir, de type de variable également.
Sinon j'ai une piste, toute petite et autant improbable... J'ai un timer qui génère une interruption toutes les secondes (je m'en sers pour faire horloge, heures minutes secondes), c'est assez improbable que ça fasse planter mon code, vu qu'il y a un système de PUSH-POP en arrière plan je suppose.
Ma fonction avec le modulo est appelée toutes les secondes et j'ai JAMAIS le résultat attendu. Ca serai un sacré manque de chance que mon timer la perturbe à ce point. J'essayerai sans pour voir, demain, quand j'aurai les yeux sur mon matériel.
Utilisateur anonyme
15 févr. 2014 à 23:43
15 févr. 2014 à 23:43
Tes variables déclarées char tmp,hourNextL3; se retrouvent à 4 octets d'écart ? Étonnant, non ? Tu as une explication ?
J'avais pensé aussi à une modification due à une interruption cyclique, mais si elle n'a lieu que toutes les secondes, elle ne peut pas fausser ton résultat à tous les coups.
As-tu essayé :
J'avais pensé aussi à une modification due à une interruption cyclique, mais si elle n'a lieu que toutes les secondes, elle ne peut pas fausser ton résultat à tous les coups.
As-tu essayé :
hourNextL3 = '8'; tmp = hourNextL3 ; ecr_data(tmp);
titusIII
Messages postés
93
Date d'inscription
jeudi 16 octobre 2008
Statut
Membre
Dernière intervention
16 décembre 2014
2
16 févr. 2014 à 15:58
16 févr. 2014 à 15:58
Oui je les déclarent pas sur la meme ligne, bizarre ça me ressemble pas.
Je vais essayer le code que tu me proposes, je connais je pense déjà le résultat! Ca va marcher
Je vais essayer le code que tu me proposes, je connais je pense déjà le résultat! Ca va marcher
Utilisateur anonyme
16 févr. 2014 à 18:03
16 févr. 2014 à 18:03
As-tu essayé ton code avec le simulateur de MPLABX pour voir à partir de quand les valeurs diffèrent de celles que tu attends ?
D'autre part, peux-tu mettre ici le code assembleur généré par le compilateur pour ton opération qui ne marche pas ?
D'autre part, peux-tu mettre ici le code assembleur généré par le compilateur pour ton opération qui ne marche pas ?
titusIII
Messages postés
93
Date d'inscription
jeudi 16 octobre 2008
Statut
Membre
Dernière intervention
16 décembre 2014
2
16 févr. 2014 à 20:44
16 févr. 2014 à 20:44
Ouaip,
Le code en C :
Et en asm j'arrive pas à mettre la main sur le .asm, y'a un moyen particulier sur mplabX ?
J'ai testé avec le simulateur intégré et aucun problème
Le code en C :
cursor(0,1); ecr_string(next3); testT = 17; tmp = testT%10; ecr_data(tmp + '0');
Et en asm j'arrive pas à mettre la main sur le .asm, y'a un moyen particulier sur mplabX ?
J'ai testé avec le simulateur intégré et aucun problème
Utilisateur anonyme
16 févr. 2014 à 22:04
16 févr. 2014 à 22:04
Pas facile de te suivre : ton code change à chaque fois, ainsi que les noms de tes fonctions et de tes variables... Et tu n'as pas répondu à l'essai que je t'avais demandé.
Quand tu dis qu'il n'y a aucun problème avec le simulateur, qu'est-ce que ça veut dire ? Le simulateur n'a pas d'afficheur ! Et quand tu simules, exécutes-tu tout bien depuis le reset du PIC ?
Est-il possible d'avoir le programme complet ?
Quand tu dis qu'il n'y a aucun problème avec le simulateur, qu'est-ce que ça veut dire ? Le simulateur n'a pas d'afficheur ! Et quand tu simules, exécutes-tu tout bien depuis le reset du PIC ?
Est-il possible d'avoir le programme complet ?
titusIII
Messages postés
93
Date d'inscription
jeudi 16 octobre 2008
Statut
Membre
Dernière intervention
16 décembre 2014
2
17 févr. 2014 à 17:53
17 févr. 2014 à 17:53
48: cursor(0,1); 0516 6EE6 MOVWF POSTINC1, ACCESS 0518 6AE6 CLRF POSTINC1, ACCESS 051A EC8E CALL 0x31C, 0 051C F001 NOP 051E 52E5 MOVF POSTDEC1, F, ACCESS 0520 52E5 MOVF POSTDEC1, F, ACCESS 49: ecr_string(next3); 0522 0EB6 MOVLW 0xB6 0524 6EE6 MOVWF POSTINC1, ACCESS 0526 0E01 MOVLW 0x1 0528 6EE6 MOVWF POSTINC1, ACCESS 052A EC6F CALL 0x2DE, 0 052C F001 NOP 052E 52E5 MOVF POSTDEC1, F, ACCESS 0530 52E5 MOVF POSTDEC1, F, ACCESS 50: testT = 17; 0532 0E11 MOVLW 0x11 0534 0100 MOVLB 0x0 0536 6F79 MOVWF testT, BANKED 0538 6B7A CLRF 0x7A, BANKED 51: tmp = testT%10; 053A C079 MOVFF testT, __tmp_0 053C F010 NOP 053E C07A MOVFF 0x7A, 0x11 0540 F011 NOP 0542 0E0A MOVLW 0xA 0544 6E0D MOVWF 0xD, ACCESS 0546 6A0E CLRF 0xE, ACCESS 0548 C010 MOVFF __tmp_0, 0x8 054A F008 NOP 054C C011 MOVFF 0x11, 0x9 054E F009 NOP 0550 ECB8 CALL 0x570, 0 0552 F002 NOP 0554 C004 MOVFF 0x4, __tmp_0 0556 F010 NOP 0558 C005 MOVFF 0x5, 0x11 055A F011 NOP 055C C010 MOVFF __tmp_0, tmp 055E F078 NOP 52: ecr_data(tmp + '0'); 0560 0E30 MOVLW 0x30 0562 0100 MOVLB 0x0 0564 2578 ADDWF tmp, W, BANKED 0566 6EE6 MOVWF POSTINC1, ACCESS 0568 EC0F CALL 0x21E, 0 056A F001 NOP 056C 52E5 MOVF POSTDEC1, F, ACCESS
titusIII
Messages postés
93
Date d'inscription
jeudi 16 octobre 2008
Statut
Membre
Dernière intervention
16 décembre 2014
2
17 févr. 2014 à 18:02
17 févr. 2014 à 18:02
0532 0E11 MOVLW 0x11 0534 0100 MOVLB 0x0 0536 6F79 MOVWF testT, BANKED 0538 6B7A CLRF 0x7A, BANKED
Quelque chose qui va pas ici me semble t'il...
On déplace 0x11 vers W, on sélectionne la banque 0x0 pour mettre mon 0x11 ?
Et on efface la banque 0x7A ?
Ca fait longtemps que j'ai pas fait d'assembleur, je dois pas être loin de la vérité
Et on efface la banque 0x7A ?
Non, on efface l'adresse 0x7A, qui est le poids fort de l'adresse 0x79 qui contient testT.
testT est défini comme un char ou un int ?
Je ne vois rien de choquant.
Par contre, tu ne m'as pas répondu : Quand tu dis qu'il n'y a aucun problème avec le simulateur, qu'est-ce que ça veut dire ?
Tu mets un point d'arrêt et tu observes les valeurs de variables ?
Et quand tu fais le test en réel, tu as un programme qui tourne en boucle je suppose : As-tu laissé tourner le simulateur pour que lui aussi fasse plusieurs boucles avent de vérifier l'état des variables ?
Non, on efface l'adresse 0x7A, qui est le poids fort de l'adresse 0x79 qui contient testT.
testT est défini comme un char ou un int ?
Je ne vois rien de choquant.
Par contre, tu ne m'as pas répondu : Quand tu dis qu'il n'y a aucun problème avec le simulateur, qu'est-ce que ça veut dire ?
Tu mets un point d'arrêt et tu observes les valeurs de variables ?
Et quand tu fais le test en réel, tu as un programme qui tourne en boucle je suppose : As-tu laissé tourner le simulateur pour que lui aussi fasse plusieurs boucles avent de vérifier l'état des variables ?
titusIII
Messages postés
93
Date d'inscription
jeudi 16 octobre 2008
Statut
Membre
Dernière intervention
16 décembre 2014
2
Modifié par titusIII le 18/02/2014 à 11:52
Modifié par titusIII le 18/02/2014 à 11:52
Bravo, si effectivement je suis à Beaulieu! J'ai la ligne 1 à faire aussi!
Sur simulation mon modulo se fait bien! Toutes mes variables sont en char!
Je met un point d'arrêt juste avant de commencer le code qui m'intéresse et je fais du pas à pas pour observer les variations de mes variables.
Le programme tourne quelques minutes oui, donc pas de doute ça marche pas.
Sur simulation mon modulo se fait bien! Toutes mes variables sont en char!
Je met un point d'arrêt juste avant de commencer le code qui m'intéresse et je fais du pas à pas pour observer les variations de mes variables.
Le programme tourne quelques minutes oui, donc pas de doute ça marche pas.
Utilisateur anonyme
18 févr. 2014 à 14:14
18 févr. 2014 à 14:14
J'étais INSAlien de 1974 à 1979 et c'était déjà la ligne 3 :)
ta ligne
Deux questions :
Est-il possible d'avoir le programme en entier ? (via cjoint.com ou autre)
Peux -tu afficher deux fois consécutives le chiffre :
ta ligne
0538 6B7A CLRF 0x7A, BANKEDmontre que ta variable testT est en fait un int. J'ai fait l'essai, quand on déclare un char, il n'essaye pas de mettre à 0 le poids fort d'un char, il ne le fait que pour un int. Mais passons.
Deux questions :
Est-il possible d'avoir le programme en entier ? (via cjoint.com ou autre)
Peux -tu afficher deux fois consécutives le chiffre :
ecr_data(tmp + '0');
ecr_data(tmp + '0');
titusIII
Messages postés
93
Date d'inscription
jeudi 16 octobre 2008
Statut
Membre
Dernière intervention
16 décembre 2014
2
18 févr. 2014 à 19:30
18 févr. 2014 à 19:30
Effectivement je l'avais laissée en int pour mes tests...
Je peux t'envoyer le programme, par mail? Peux-tu m'envoyer une adresse mail?
Je peux t'envoyer le programme, par mail? Peux-tu m'envoyer une adresse mail?
titusIII
Messages postés
93
Date d'inscription
jeudi 16 octobre 2008
Statut
Membre
Dernière intervention
16 décembre 2014
2
18 févr. 2014 à 19:42
18 févr. 2014 à 19:42
Rectification, en sortie avec :
J'ai 'T'.
Soit 84-48=36
36?
17%10=36 d'après mon pic
testT = 17; tmp = testT%10; ecr_data(tmp + '0');
J'ai 'T'.
Soit 84-48=36
36?
17%10=36 d'après mon pic
19 févr. 2014 à 15:53