Anthony Jaguenaud a écrit 1967 commentaires

  • [^] # Re: sécurité et pointeurs

    Posté par  . En réponse au message structure dans une fonction sans pointeur. Évalué à 3.

    Tu sais, le seul moyen de ne pas fabriquer des failles, c’est de ne pas développer.
    Les pointeurs ne sont qu’un outil, il faut apprendre à les utiliser, comprendre à quoi ils servent et enfin prendre suffisamment de recul pour savoir quand les utiliser ou non.
    Se limiter parce qu’il y a un risque n’est àmha pas la meilleure solution.

  • # Utiliser ton gestionnaire de paquet ?

    Posté par  . En réponse au message mon programme n'arrive pas a trouver la lib. Évalué à 2.

    Sur debian, sokoban est dans le paquet : games-puzzle

    $ apt install games-puzzle
    …
    $

    Je ne l’ai pas trouvé pour fedora.

  • [^] # Re: Mais il va rester quoi à Linux ?

    Posté par  . En réponse au journal Windows est enfin prêt pour le desktop . Évalué à 3.

    mouais, moi je vois un noyau linux captif dans un windows, et un noyau linux captif dans un environnement Android, plus des linux enfermés dans des clouds.

    Pourquoi captif ? Linux est en relation direct avec plein de monde, sur Android, il gère les communications externe, les interactions avec l’utilisateur, etc. d’accord, il n’est pas en relation direct avec les applicatifs puisqu’il y a Dalvik en intermédiaire. Mais je ne trouve pas que le noyau Linux soit captif.
    Sur windows, il communique avec les applications et le hardware, il rend service à l’utilisateur qui lui est peut-être captif (c’est mon cas au boulot 😭), mais le noyau n’est pas captif… au pire, on ne l’a pas laissé emmener ses amis (GNU) avec lui.

  • [^] # Re: sqlite en RAM

    Posté par  . En réponse au message Base de donnée en RAM. Évalué à 2.

    Merci pour les réponses. Par contre, je ne vois pas la section « Why Not Use TinyDB » :'(

  • [^] # Re: Transactionnel et en RAM sont incompatibles

    Posté par  . En réponse au message Base de donnée en RAM. Évalué à 5.

    La durabilité doit être le temps d’un test. La base sera réinitialisé pour le suivant.

    Donc, la transaction sera durable dans mon environnement et mon besoin.

  • [^] # Re: Transactionnel et en RAM sont incompatibles

    Posté par  . En réponse au message Base de donnée en RAM. Évalué à 2.

    J’ai un système à simuler qui contient un certain nombre d’éléments. Plusieurs process qui accède aux données pour répondre aux messages à la place des vrais systèmes en temps réél.
    Lorsqu’on change des données pour changer d’état, je veux que l’ensemble soit toujours cohérent.
    D’où l’idée de faire du transactionnel. Mais je n’ai pas besoin de persistance, à la fin de mon test, je vais réinitialiser l’ensemble pour le suivant.

  • [^] # Re: Redis ?

    Posté par  . En réponse au message Base de donnée en RAM. Évalué à 2.

    Je vais regarder, merci.

  • [^] # Re: sqlite en RAM

    Posté par  . En réponse au message Base de donnée en RAM. Évalué à 2.

    Bah, mon besoin c’est surtout de partager les états de mon système qui sont des (clé—valeur)… Une base relationnel me semble un peu overkill.

  • [^] # Re: sqlite en RAM

    Posté par  . En réponse au message Base de donnée en RAM. Évalué à 2.

    Oui. Je me demandais juste s’il n’y avait pas mieux. Après l’avantage de cette solution, c’est que on peut avoir des process codé dans d’autres langages.

  • # ZODB

    Posté par  . En réponse au message Base de donnée en RAM. Évalué à 2.

    J’avais trouvé ça. Quelqu’un l’a-t-il utilisé ?

    Y-a-t-il mieux ?

  • [^] # Re: Pas mieux, ou presque

    Posté par  . En réponse au message Qt : positionnement "proportionnel" d'un bouton. Évalué à 3.

    Regarde du côté des ressorts (stretch) en mettant les bon coef. ça doit faire ce que tu veux…

    voir là.

    Tu met dans un VBoyLayout un stretch dessus, un HBoxLayout, un stretch dessous.
    Dans le HBoxLayout un stretch gauche, bouton, strech droite.

    C’est des souvenir ;-)

    J’espère avoir pu t’aider.

  • [^] # Re: 737 Too Much

    Posté par  . En réponse au lien Le Boeing 737 Max et les limites du logiciel avec un matériel mal conçu. Évalué à 4.

    Sauf que l’agence de sécurité aéronautique américaine a délégué la certification à Boing… ne cherchait pas de conflit d’intérêt ou d’indépendance, c’est la sécurité des passagers qui prime…

  • [^] # Re: Vraiment présente ?

    Posté par  . En réponse au message Cherche driver linux : TNT5004. Évalué à 2. Dernière modification le 11 avril 2019 à 17:22.

    Il faut que tu installes les headers du noyau.

    Par contre, je suis intéressé par le résultat du lspci.

  • [^] # Re: Vraiment présente ?

    Posté par  . En réponse au message Cherche driver linux : TNT5004. Évalué à 2.

    Sur ma machine Virtuelle :

    $ lspci
    00:00.0 Host bridge: Intel Corporation 440FX - 82441FX PMC [Natoma] (rev 02)
    00:01.0 ISA bridge: Intel Corporation 82371SB PIIX3 ISA [Natoma/Triton II]
    00:01.1 IDE interface: Intel Corporation 82371AB/EB/MB PIIX4 IDE (rev 01)
    00:02.0 VGA compatible controller: InnoTek Systemberatung GmbH VirtualBox Graphics Adapter
    00:03.0 Ethernet controller: Intel Corporation 82540EM Gigabit Ethernet Controller (rev 02)
    00:04.0 System peripheral: InnoTek Systemberatung GmbH VirtualBox Guest Service
    00:05.0 Multimedia audio controller: Intel Corporation 82801AA AC'97 Audio Controller (rev 01)
    00:06.0 USB controller: Apple Inc. KeyLargo/Intrepid USB
    00:07.0 Bridge: Intel Corporation 82371AB/EB/MB PIIX4 ACPI (rev 08)
    $

    Il liste tous ce que le noyau détecte, mais ça ne veut pas dire qu’il sache les prendre en compte.

  • [^] # Re: Vraiment présente ?

    Posté par  . En réponse au message Cherche driver linux : TNT5004. Évalué à 2.

    A priori elle n'est pas reconnu.

    Oups

    Il faut compiler le driver et le charger avec modprobe.

    Non, n’importe quelle carte sur le BUS PCI doit donner son vendorID et son ID. C’est une fois en possession de cette information que le noyau peut charger le bon driver.

    Si la carte n’est pas reconnu :

    • Vérifier qu’elle est correctement enfoncée dans le connecteur PCI.
    • Changer la carte de slot au cas où une soudure ait sautée (peu probable)
    • La remplacer par une carte que tu sais fonctionner.
    • Vérifier si la carte est reconnue sur un autre PC (Windows)
      • Oui :
      • Redémarrer avec un live CD linux et refaire un lspci.

    Voila mes idées là, maintenant, tout de suite.

    Bonne chance.

  • [^] # Re: Java > 1.8

    Posté par  . En réponse au journal Java XII est dehors. Évalué à 1.

    Et le java ? La téléréalité ? :-p

    ---->[]

  • [^] # Re: Retour de fonction

    Posté par  . En réponse au sondage De quelle pratique de développement avez‐vous honte ?. Évalué à 2.

    Ok, je ne pensais pas. Merci d’améliorer ma culture.

  • [^] # Re: Retour de fonction

    Posté par  . En réponse au sondage De quelle pratique de développement avez‐vous honte ?. Évalué à 2.

    Non, si ta source est plus petite que str, le dernier caractère ne sera pas écrit… et rien ne prouve qu’il vaille '\0'.

  • [^] # Re: Retour de fonction

    Posté par  . En réponse au sondage De quelle pratique de développement avez‐vous honte ?. Évalué à 4.

    Je vois un cas d’usage dont il ne faut pas abuser pour la lecture…

      int n = 50;
      char str[n];
    
      
      // Si len(source) >= 50, il n’y a pas la place pour le caractère
      // terminal. Donc on peut l’ajouter directement.
      // Par contre, attention à la compréhension du code.
      strncpy(str, source, n)[n-1] = '\0';
      
  • # Join

    Posté par  . En réponse au message Trier un fichier CSV avec une boucle while read en Bash. Évalué à 2.

    J’ai pas tout saisi, mais un petit man join pourra peut-être t’aider.

  • # Problématique Temps Réel

    Posté par  . En réponse au message Polling ou Interrupt ?. Évalué à 3.

    Pour maîtriser le temps Réel, il faut voir ça comme de l’échantillonnage en fréquence. Il te manque une donnée : le temps de réponse voulue.

    Question 1 : À la réception du message au bout de combien de temps, l’action doit être réalisée ?

    Question 2 : À la lecture du message, en combien de temps l’action est réalisée ?

    À partir de là, tu peux déterminer et prouver que ton logiciel répond en temps et en heure.

    Dans ton exemple, la réponse à la question 2 est : 4s.

    Avec 4s de traitement, ta période ne peut descendre en dessous de 4s (voir un poil plus).
    Disons 5s. Donc, tu peux garantir que le traitement sera réaliser 10s après la réception. Des fois ce sera 4,1s des fois 9,1s. Mais toujours moins de 10s.

    Si tu n’as pas cette problématique de temps de réponse voulu, j’aurais tendance à utiliser des solutions bloquante de type : select pour la lecture et communication inter thread pour prévenir en sécurité de la réception. Cette solution sera sûrement plus réactive, mais le temps non garanti.

    Question : As-tu vraiment besoin de la maîtrise de ton temps réel pour ton application ? Tu ne donne pas beaucoup de détail (OS ou Bare metal), plateforme, etc.

    Si tu as un CPU multi cœur par exemple, et que tu peux dédier un cœur à ça, alors, tu peux faire un thread bloquant qui va te garantir une réponse en moins de 5s. Mais ton cœur n’est pas disponible pour autre chose… c’est un choix de design à faire.

  • [^] # Re: Le temps

    Posté par  . En réponse au journal Grand débat. Évalué à 5.

    Ton problème c’est que soit c’est les clients qui payent le journal, donc le journal fait plaisir à ses clients, donc est partial. La solution c’est de payer un impôt pour la presse ? Non, car le journal serait à la solde de l’État…

    Il n’y a pas de solution !

  • [^] # Re: C'est nul

    Posté par  . En réponse au journal Hacker du dimanche. Évalué à 2.

    Même chose pour moi, à la différence que le sujet était un mot de passe que j’ai longtemps utilisé (je l’utilise même encore sur linuxfr). Mais aucun compte important, mail, achat en ligne, etc. n’utilise ce mot de passe.

  • [^] # Re: Executable

    Posté par  . En réponse au message comment est ce possible de faire un noyau avec python ou un langage interprété. Évalué à 2.

    Une bare machine ?

    Je ne connaissais pas l’expression.

    Ce qui n'est d'ailleurs pas juste un concept d'école : les premières ébauches du système de contrôle-commande des centrales nucléaires 1400MW de EDF étaient basées sur une bare machine Ada (fin des années 80).

    Aucune idée, à la fin des années 80 j’étais encore au lycée.

    Ce que j’aime dans la pyboard, que je trouve aussi très moderne c’est son système de boot.
    La carte contient une flash qui est formatée, le firmware démarre, et cherche un fichier boot.py, il l’exécute. Celui-ci cherche ensuite un fichier main.py. Il est déconseillé de modifier le boot.py car il initialise notamment la communication avec l’ordinateur quand la carte est connectée en USB.

    D’ailleurs, en USB, la pyboard s’enregistre comme une clé USB, ce qui permet de modifier les fichiers python, mais aussi de créer des sous répertoire, etc. La carte s’enregistre aussi comme console série, en l’ouvrant on a un interpréteur python exécuté directement sur la carte. Très intéressant en phase de dév. et de test.

    Vous aurez compris, je suis fan.

  • # Executable

    Posté par  . En réponse au message comment est ce possible de faire un noyau avec python ou un langage interprété. Évalué à 2. Dernière modification le 15 février 2019 à 13:23.

    Salut,
    Comme répondu au dessus, il faut faire tourné l’exécutable sur la cible. Il faudra un minimum de code comme le boot, et il faut aussi linker statiquement toutes les bibliothèques nécessaire à l’interpréteur. Il faut entre autre réimplémenter certaines fonctions de base comme l’allocation mémoire, etc.

    Je pense qu’un bon exemple est μpython, tu as une carte utilisant cette solution la pyboard. Je n’ai pas regardé comment c’est implémenté, mais le code est .

    Par contre, tu n’as pas vraiment un OS, juste une plateforme pour exécuter du code python.