Maison Tutoriel système Linux Une plongée approfondie dans les sujets avancés du débogueur Linux

Une plongée approfondie dans les sujets avancés du débogueur Linux

Jan 08, 2024 pm 10:42 PM
linux linux教程 红帽 linux系统 linux命令 certification Linux chapeau rouge Linux vidéo Linux

Présentation Nous arrivons enfin au dernier article de cette série ! Cette fois, je vais donner un aperçu général de certains des concepts les plus avancés du débogage : débogage à distance, prise en charge des bibliothèques partagées, évaluation des expressions et prise en charge du multithreading. Ces idées sont plus complexes à mettre en œuvre, je n'entrerai donc pas dans les détails sur la façon de procéder, mais je serai heureux de répondre aux questions sur ces concepts si vous avez des questions.
Index des séries
  1. Préparer l'environnement
  2. Point d'arrêt
  3. Registres et mémoire
  4. Elfes et nains
  5. Code source et signaux
  6. La couche de code source est exécutée étape par étape
  7. Points d'arrêt de la couche de code source
  8. Pile d'appels
  9. Gérer les variables
  10. Thème Premium
Débogage à distance

Le débogage à distance est très utile pour les systèmes embarqués ou le débogage de différents environnements. Il établit également une ligne fine entre les opérations de haut niveau du débogueur et l'interaction avec le système d'exploitation et le matériel. En fait, les débogueurs comme GDB et LLDB peuvent fonctionner comme débogueurs distants même lors du débogage de programmes locaux. La structure générale est la suivante :
Linux 调试器之高级主题!

debuarch

Le débogueur est le composant avec lequel nous interagissons via la ligne de commande. Peut-être que si vous utilisez un IDE, il y a une autre couche au-dessus qui communique avec le débogueur via l'interface de la machine. Sur la machine cible (probablement la même que la machine native), il existe un stub de débogage, qui est théoriquement un wrapper autour d'une très petite bibliothèque de débogage du système d'exploitation qui effectue toutes les tâches de débogage de bas niveau, comme la définition de points d'arrêt sur les adresses. Je dis "en théorie" parce que les talons de débogage sont de plus en plus gros de nos jours. Par exemple, la taille du stub de débogage LLDB sur ma machine est de 7,6 Mo. Le stub de débogage communique avec le processus débogué et le débogueur via le protocole distant en utilisant certaines fonctionnalités spécifiques au système d'exploitation (ptrace dans notre cas).
Le protocole de débogage distant le plus courant est le protocole distant GDB. Il s'agit d'un format de paquet textuel utilisé pour transmettre des commandes et des informations entre le débogueur et les stubs de débogage. Je n'entrerai pas dans les détails, mais vous pouvez en savoir plus ici. Si vous démarrez LLDB et exécutez la commande log activate gdb-remote packets, vous obtiendrez une trace de tous les paquets envoyés via le protocole distant. Sur GDB, vous pouvez faire la même chose avec set remotelogfile.

À titre d'exemple simple, voici le paquet sur lequel définir un point d'arrêt :

$Z0,400570,1#43
Copier après la connexion

$ marque le début du paquet. Z0 est la commande pour insérer un point d'arrêt mémoire. 400570 et 1 sont des paramètres, le premier étant l'adresse permettant de définir le point d'arrêt et le second le spécificateur de type de point d'arrêt pour une cible spécifique. Enfin, #43 est une somme de contrôle pour garantir que les données ne sont pas corrompues.

Le protocole distant GDB est très facile à étendre avec des paquets personnalisés, ce qui est utile pour implémenter des fonctionnalités spécifiques à une plate-forme ou à un langage.

Bibliothèques partagées et prise en charge du chargement dynamique

Le débogueur doit savoir quelles bibliothèques partagées sont chargées par le programme en cours de débogage afin de pouvoir définir des points d'arrêt, obtenir des informations et des symboles au niveau du code source, etc. En plus de rechercher les bibliothèques liées dynamiquement, le débogueur doit également tracer les bibliothèques chargées au moment de l'exécution via dlopen. Pour atteindre cet objectif, l'éditeur de liens dynamique maintient une structure d'intersection. Cette structure maintient une liste chaînée de descripteurs de bibliothèque partagée, ainsi qu'un pointeur vers une fonction qui est appelée chaque fois que la liste chaînée est mise à jour. Cette structure est stockée dans la section .dynamic du fichier ELF et est initialisée avant l'exécution du programme.

Un algorithme de suivi simple :

  • Le traceur recherche l'entrée du programme dans l'en-tête ELF (ou peut utiliser des vecteurs auxiliaires stockés dans /proc//aux).
  • Le programme de traçage définit un point d'arrêt à l'entrée du programme et démarre l'exécution.
  • Lorsque le point d'arrêt est atteint, recherchez l'adresse de la structure d'intersection en recherchant l'adresse de chargement de .dynamic dans le fichier ELF.
  • Vérifiez la structure d'intersection pour une liste des bibliothèques actuellement chargées.
  • Définissez un point d'arrêt sur la fonction de mise à jour de l'éditeur de liens.
  • La liste est mise à jour à chaque fois qu'un point d'arrêt est atteint.
  • Le programme de suivi boucle à l'infini, continuant à exécuter le programme et attendant les signaux jusqu'à ce que le signal du programme de suivi sorte.

J'ai écrit un petit exemple de ces concepts, que vous pouvez retrouver ici. Je pourrai écrire plus en détail à l'avenir si quelqu'un est intéressé.

Calcul d'expression

L'évaluation des expressions est une fonctionnalité du programme qui permet aux utilisateurs d'évaluer les expressions dans la langue source d'origine lors du débogage du programme. Par exemple, dans LLDB ou GDB, vous pouvez exécuter print foo() pour appeler la fonction foo et imprimer le résultat.

Il existe plusieurs méthodes de calcul différentes selon la complexité de l'expression. Si l'expression n'est qu'un simple identifiant, le débogueur peut consulter les informations de débogage, trouver la variable et imprimer la valeur, tout comme nous l'avons fait dans la dernière partie de cette série. Si l'expression est quelque peu complexe, il peut être possible de compiler le code en une expression intermédiaire (IR) et de l'interpréter pour obtenir le résultat. Par exemple, pour certaines expressions, LLDB utilisera Clang pour compiler l'expression dans un LLVM IR et l'interpréter. Si l'expression est plus complexe ou nécessite l'appel de certaines fonctions, le code devra peut-être être envoyé à la cible et exécuté dans l'espace d'adressage du débogué. Cela implique d'appeler mmap pour allouer de la mémoire exécutable, puis de copier le code compilé dans ce bloc et de l'exécuter. LLDB est implémenté à l’aide des capacités JIT de LLVM.

Si vous souhaitez en savoir plus sur la compilation JIT, je vous recommande vivement l'article d'Eli Bendersky sur le sujet.

多线程调试支持

本系列展示的调试器仅支持单线程应用程序,但是为了调试大多数真实程序,多线程支持是非常需要的。支持这一点的最简单的方法是跟踪线程的创建,并解析 procfs 以获取所需的信息。

Linux 线程库称为 pthreads。当调用 pthread_create 时,库会使用 clone 系统调用来创建一个新的线程,我们可以用 ptrace 跟踪这个系统调用(假设你的内核早于 2.5.46)。为此,你需要在连接到调试器之后设置一些 ptrace 选项:

ptrace(PTRACE_SETOPTIONS, m_pid, nullptr, PTRACE_O_TRACECLONE);
Copier après la connexion

现在当 clone 被调用时,该进程将收到我们的老朋友 SIGTRAP 信号。对于本系列中的调试器,你可以将一个例子添加到 handle_sigtrap 来处理新线程的创建:

case (SIGTRAP | (PTRACE_EVENT_CLONE << 8)):
//get the new thread ID
unsigned long event_message = 0;
ptrace(PTRACE_GETEVENTMSG, pid, nullptr, message);
//handle creation
//...
Copier après la connexion

一旦收到了,你可以看看 /proc//task/ 并查看内存映射之类来获得所需的所有信息。

GDB 使用 libthread_db,它提供了一堆帮助函数,这样你就不需要自己解析和处理。设置这个库很奇怪,我不会在这展示它如何工作,但如果你想使用它,你可以去阅读这个教程。

多线程支持中最复杂的部分是调试器中线程状态的建模,特别是如果你希望支持不间断模式或当你计算中涉及不止一个 CPU 的某种异构调试。

最后!

呼!这个系列花了很长时间才写完,但是我在这个过程中学到了很多东西,我希望它是有帮助的。如果你有关于调试或本系列中的任何问题,请在 Twitter @TartanLlama或评论区联系我。如果你有想看到的其他任何调试主题,让我知道我或许会再发其他的文章。

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Commandes de chat et comment les utiliser
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Différence entre Centos et Ubuntu Différence entre Centos et Ubuntu Apr 14, 2025 pm 09:09 PM

Les principales différences entre Centos et Ubuntu sont: l'origine (Centos provient de Red Hat, pour les entreprises; Ubuntu provient de Debian, pour les particuliers), la gestion des packages (Centos utilise Yum, se concentrant sur la stabilité; Ubuntu utilise APT, pour une fréquence de mise à jour élevée), le cycle de support (CentOS fournit 10 ans de soutien, Ubuntu fournit un large soutien de LT tutoriels et documents), utilisations (Centos est biaisé vers les serveurs, Ubuntu convient aux serveurs et aux ordinateurs de bureau), d'autres différences incluent la simplicité de l'installation (Centos est mince)

Comment installer CentOS Comment installer CentOS Apr 14, 2025 pm 09:03 PM

Étapes d'installation de CentOS: Téléchargez l'image ISO et Burn Bootable Media; démarrer et sélectionner la source d'installation; sélectionnez la langue et la disposition du clavier; configurer le réseau; partitionner le disque dur; définir l'horloge système; créer l'utilisateur racine; sélectionnez le progiciel; démarrer l'installation; Redémarrez et démarrez à partir du disque dur une fois l'installation terminée.

Centos arrête la maintenance 2024 Centos arrête la maintenance 2024 Apr 14, 2025 pm 08:39 PM

Centos sera fermé en 2024 parce que sa distribution en amont, Rhel 8, a été fermée. Cette fermeture affectera le système CentOS 8, l'empêchant de continuer à recevoir des mises à jour. Les utilisateurs doivent planifier la migration et les options recommandées incluent CentOS Stream, Almalinux et Rocky Linux pour garder le système en sécurité et stable.

Explication détaillée du principe docker Explication détaillée du principe docker Apr 14, 2025 pm 11:57 PM

Docker utilise les fonctionnalités du noyau Linux pour fournir un environnement de fonctionnement d'application efficace et isolé. Son principe de travail est le suivant: 1. Le miroir est utilisé comme modèle en lecture seule, qui contient tout ce dont vous avez besoin pour exécuter l'application; 2. Le Système de fichiers Union (UnionFS) empile plusieurs systèmes de fichiers, ne stockant que les différences, l'économie d'espace et l'accélération; 3. Le démon gère les miroirs et les conteneurs, et le client les utilise pour l'interaction; 4. Les espaces de noms et les CGROUP implémentent l'isolement des conteneurs et les limitations de ressources; 5. Modes de réseau multiples prennent en charge l'interconnexion du conteneur. Ce n'est qu'en comprenant ces concepts principaux que vous pouvez mieux utiliser Docker.

Le choix de Centos après l'arrêt de l'entretien Le choix de Centos après l'arrêt de l'entretien Apr 14, 2025 pm 08:51 PM

CentOS a été interrompu, les alternatives comprennent: 1. Rocky Linux (meilleure compatibilité); 2. Almalinux (compatible avec CentOS); 3. Serveur Ubuntu (configuration requise); 4. Red Hat Enterprise Linux (version commerciale, licence payante); 5. Oracle Linux (compatible avec Centos et Rhel). Lors de la migration, les considérations sont: la compatibilité, la disponibilité, le soutien, le coût et le soutien communautaire.

Que faire après Centos arrête la maintenance Que faire après Centos arrête la maintenance Apr 14, 2025 pm 08:48 PM

Une fois CentOS arrêté, les utilisateurs peuvent prendre les mesures suivantes pour y faire face: sélectionnez une distribution compatible: comme Almalinux, Rocky Linux et CentOS Stream. Migrez vers les distributions commerciales: telles que Red Hat Enterprise Linux, Oracle Linux. Passez à Centos 9 Stream: Rolling Distribution, fournissant les dernières technologies. Sélectionnez d'autres distributions Linux: comme Ubuntu, Debian. Évaluez d'autres options telles que les conteneurs, les machines virtuelles ou les plates-formes cloud.

Comment utiliser Docker Desktop Comment utiliser Docker Desktop Apr 15, 2025 am 11:45 AM

Comment utiliser Docker Desktop? Docker Desktop est un outil pour exécuter des conteneurs Docker sur les machines locales. Les étapes à utiliser incluent: 1. Installer Docker Desktop; 2. Démarrer Docker Desktop; 3. Créer une image Docker (à l'aide de DockerFile); 4. Build Docker Image (en utilisant Docker Build); 5. Exécuter Docker Container (à l'aide de Docker Run).

Quelle configuration de l'ordinateur est requise pour VScode Quelle configuration de l'ordinateur est requise pour VScode Apr 15, 2025 pm 09:48 PM

Vs Code Système Exigences: Système d'exploitation: Windows 10 et supérieur, MacOS 10.12 et supérieur, processeur de distribution Linux: minimum 1,6 GHz, recommandé 2,0 GHz et au-dessus de la mémoire: minimum 512 Mo, recommandée 4 Go et plus d'espace de stockage: Minimum 250 Mo, recommandée 1 Go et plus d'autres exigences: connexion du réseau stable, xorg / wayland (Linux) recommandé et recommandée et plus

See all articles