Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Sous Windows: first experience #1

Open
KiwiHC16 opened this issue Jan 30, 2018 · 31 comments
Open

Sous Windows: first experience #1

KiwiHC16 opened this issue Jan 30, 2018 · 31 comments

Comments

@KiwiHC16
Copy link

KiwiHC16 commented Jan 30, 2018

Salut Jerome-PS,
J'essaye de faire marcher ta version en partant de la mienne et en avancent pas à pas.
Je suis sous windows 7
Premiere étage: script Sniff.py

  • cd répertoire du script
  • lancement du script -> plantage, il manque le () pour les appels à print
    -- print "" => print("")
  • Je relance
  • Wireshark s'ouvre mais se plaint de zb.lua
    capture d ecran 2018-01-30 a 11 00 18
    -- si je mets cette ligne en commentaire alors plus d erreur mais cela ne fonctionne pas, pas surprenant.
    -- Je mets donc des \ partout.
    Il semble content mais apres il ne trouve pas ser car non defini...
  • je decommente la ligne 28 pour definir ser.

Côté wireshark ca semble ok maintenant, je passe a la compile du firmware.

@KiwiHC16
Copy link
Author

KiwiHC16 commented Jan 30, 2018

Côté firmware, je ne trouve aucune modification des *.h, *.c par contre visiblement un main.c complet qui doit être exécuté sur un bouton xiaomi avec le JN5169.
Est ce bien cela ?
(Makefile APPSRC += main.c UartBuffered.c Queue.c Printf.c -> compilé sur un linux)

@KiwiHC16
Copy link
Author

Sur quel type de bouton tu as fait tourné le truc ? Je vois 2 PIN en entrée dans le code mais le bouton que je possède n'a qu'un bouton accessible.

#ifdef XIAMO_SMART_BUTTON
#define LED_PIN_BIT (1 << 11)
#define MAIN_PIN_BIT (1 << 16)
#define PAIR_PIN_BIT (1 << 0)
#endif //def XIAMO_SMART_BUTTON

@KiwiHC16
Copy link
Author

As tu ajouté la date sur chaque paquet ?

u8tstFrame[0] = ((uint8_t*)&u32Seconds)[3];
u8tstFrame[1] = ((uint8_t*)&u32Seconds)[2];
u8tstFrame[2] = ((uint8_t*)&u32Seconds)[1];
u8tstFrame[3] = ((uint8_t*)&u32Seconds)[0];
u8tstFrame[4] = ((uint8_t*)&u32Fraction)[3];
u8tstFrame[5] = ((uint8_t*)&u32Fraction)[2];
u8tstFrame[6] = ((uint8_t*)&u32Fraction)[1];
u8tstFrame[7] = ((uint8_t*)&u32Fraction)[0];

@Jerome-PS
Copy link
Owner

Jerome-PS commented Jan 30, 2018 via email

@Jerome-PS
Copy link
Owner

Jerome-PS commented Jan 30, 2018 via email

@Jerome-PS
Copy link
Owner

Jerome-PS commented Jan 30, 2018 via email

@Jerome-PS
Copy link
Owner

Jerome-PS commented Jan 30, 2018 via email

@Jerome-PS
Copy link
Owner

Est-ce que tu utilises python 2 ou python 3?

@Jerome-PS
Copy link
Owner

Est-ce que tu peux tester avec le nouveau commit?

@KiwiHC16
Copy link
Author

KiwiHC16 commented Jan 30, 2018

Sur la base de mon premier post j ai reussi a compile pour un JN5168 (C est ce que j ai), le programmer, lancer sniffer.py, avoir wireshark, lancer le menu ZB-> start avoir les traces qui démarrent mais crash.

Dans lua j ai mis:
comport = '\\.\pipe\wiresharkTx',

capture d ecran 2018-01-30 a 13 56 59

capture d ecran 2018-01-30 a 13 53 51

capture d ecran 2018-01-30 a 13 53 59

@KiwiHC16
Copy link
Author

capture d ecran 2018-01-30 a 14 01 21

@Jerome-PS
Copy link
Owner

D'accord, j'ai testé avec Python 2.7 ...
Faut que j'installe Python3 du coup

@Jerome-PS
Copy link
Owner

C'est le code qui reouvre le pipe qui est à changer...
Tu peux mettre un print(dir(e)) entre la ligne 123 et 124 de Sniff.py (juste avant le if(e[0]...

@KiwiHC16
Copy link
Author

Je n'ai pas récupéré ton push car les modifs sont celles que j'ai dans ma version.
Dans le code il y a le traitement de l exception 109, c'est donc probabement un cas que tu as deja rencontré. Une idée sur le problème ?
Est ce que tu essayes aussi sous windows ?

Dans le main.c j ai du commenter 2 instructions pour pouvoir compiler pour le JN5168:
vJPT_GetRadioConfig(&u32RadioParamVersion);
vJPT_SetMaxInputLevel(E_MAX_INP_LEVEL_10dB);
mais je ne pense pas que cela explique le plantage python.

@KiwiHC16
Copy link
Author

Avec le print(dir(e))
capture d ecran 2018-01-30 a 14 11 13

@Jerome-PS
Copy link
Owner

Ce script ne sert que sous Windows (j'ai testé sous Windows 10). En fait quand le scipt lua a fini d'écrire, il ferme le pipe, ce qui le ferme aussi côté python, donc il faut le rouvrir (ce que fait le code de traitement de l'exception).
Mais le code d'accès au contenu de l'exception doit être différent entre python3 et python2, ce qui pose le problème...

@KiwiHC16
Copy link
Author

Sais tu ou trouver le fichier pipe dans windows ? Impossible de le trouver...

@Jerome-PS
Copy link
Owner

Tu peux mettre un print(e.winerror) entre la ligne 123 et 124 de Sniff.py (juste avant le if(e[0]...

@KiwiHC16
Copy link
Author

KiwiHC16 commented Jan 30, 2018

J ai aussi essayé d'enlever les com:close() dans lua pour function zbstart() mais aussi un problème.
capture d ecran 2018-01-30 a 14 15 48

@Jerome-PS
Copy link
Owner

Pour la compil pour JN5168, merci de l'info, je vais ajouter un #ifdef pour que ça marche à la fois avec JN5168 et JN5169.

@KiwiHC16
Copy link
Author

KiwiHC16 commented Jan 30, 2018

capture d ecran 2018-01-30 a 14 17 26
Pour print(e.winerror)
Y aussi le print("<0:x>".format(ord(data))), que j enleve pour la suite

@Jerome-PS
Copy link
Owner

Sais tu ou trouver le fichier pipe dans windows ? Impossible de le trouver... <<<< Je ne comprends pas ta question

remplace e[0]==109 par e.winerror==109

@KiwiHC16
Copy link
Author

Ce script ne sert que sous Windows (j'ai testé sous Windows 10). En fait quand le scipt lua a fini d'écrire, il ferme le pipe, ce qui le ferme aussi côté python, donc il faut le rouvrir (ce que fait le code de traitement de l'exception).
Mais le code d'accès au contenu de l'exception doit être différent entre python3 et python2, ce qui pose le problème...

C est ma comprehension aussi mais python plante et lua ne trouve plus le pipe. C est comme si python ne parvient pas a recréer le pipe.
Pour ino python ne rend pas la main je suis obligé de le tuer (y aussi des dumpcap.exe qui restent de temps en temps)

@Jerome-PS
Copy link
Owner

remplace e[0]==109 par e.winerror==109 et ça devrait arrêter de planter...
Pour tuer le script python, tu peux faire CTRL+Pause dans ta fenêtre de ligne de commande.

@KiwiHC16
Copy link
Author

capture d ecran 2018-01-30 a 14 25 55

C est mieux avec remplace e[0]==109 par e.winerror==109 python en crash plus. Par contre si j envoie des commandes de puis le menu lua, rien ne se passe. Je ne sais pas si le JN516x recoit la moindre demande.

@KiwiHC16
Copy link
Author

Pour tuer le script python, tu peux faire CTRL+Pause dans ta fenêtre de ligne de commande. en fait non car je suis dans une VM mais c est pas grave, le gestionnaire de tache fait le boulot.

@KiwiHC16
Copy link
Author

J arrete pour l instant. Si tu peux faire les tests de ton coté a me dire ce que tu trouves....

@Jerome-PS
Copy link
Owner

OK, je vais essayer de tester avec Python3, sinon, tu peux essayer avec Python2 aussi si tu veux...

@Jerome-PS
Copy link
Owner

Par contre, le 232 arrive dans le writefile, donc ce serait plutôt que tu as fermé wireshark ou coupé la capture...

@KiwiHC16 KiwiHC16 changed the title script Lua Sous Windows: first experience Jan 30, 2018
@Jerome-PS
Copy link
Owner

Chez moi ça a l'air de marcher avec Python3 et Windows 10... (avec le dernier commit)

@KiwiHC16
Copy link
Author

KiwiHC16 commented Feb 1, 2018

Je regarderai de nouveau dans les jours à venir en fonction aussi des modifs que j'ai faites.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants