Les codes fantastiques : lib et introspection

Magazine
Marque
GNU/Linux Magazine
Numéro
260
Mois de parution
novembre 2022
Spécialité(s)


Résumé

Pour commencer cette série sur les codes fantastiques, nous allons faire un petit tour dans la page de manuel de dlopen et (re)découvrir une forme d’introspection au niveau bibliothèque partagée.


Body

Sous Linux, le chargement à l’exécution de bibliothèque partagée repose sur la libdl, et l’appel à la fonction dlopen. L’usage classique est de récupérer un pointeur vers une structure opaque représentant la bibliothèque ouverte par l’appel :

void* handle = dlopen(filename, flag);

avant de rechercher un symbole en passant ce pointeur et le nom du symbole recherché à la fonction dlsym :

void* sym = dlsym(handle, "mysymbol");

Il existe cependant un autre mode d’utilisation de dlsym qui repose sur un handle réservé, RTLD_DEFAULT, et qui permet de rechercher un symbole parmi les bibliothèques déjà ouvertes par le processus en cours. Cette fonctionnalité, qui est une extension GNU, peut s’avérer très utile pour avoir un comportement conditionnel suivant l’environnement dans lequel on s’exécute.

Jetons un œil au fichier suivant, destiné à être compilé en tant que bibliothèque partagée :

#include <stdio.h>
#include <dlfcn.h>
 
__attribute__((constructor)) void check_in_python() {
  if (dlsym(RTLD_DEFAULT, "Py_GetVersion()"))
    puts(Py_GetVersion());
  else
    puts("not in a python env");
}

Lorsque la bibliothèque est chargée, la fonction check_in_python va s’exécuter (elle est marquée comme constructor). Si le processus en cours ne contient aucune bibliothèque définissant le symbole Py_GetVersion, elle affichera « not in a python env ». Mais si elle est chargée depuis un processus Python, comme dans le cas suivant, elle affichera des informations de version.

>>> import ctypes
>>> ctypes.CDLL("./libpy.so") # libpy.so est notre petite bibliothèque partagée

Par exemple, on retrouve ce comportement dans le projet LLVM, pour détecter si le binaire dans lequel une bibliothèque est chargée a été compilé depuis le langage Swift :

static void InitializeSwiftDemangler() {
  swift_demangle_f = (swift_demangle_ft)dlsym(RTLD_DEFAULT, "swift_demangle");
}

En bonus, notons que l’on peut atteindre un résultat semblable, plus rapide, mais moins portable en utilisant les weak symbols :

#include <stdio.h>
__attribute__((weak)) const char* Py_GetVersion();
__attribute__((constructor)) void check_in_python() {
  if (Py_GetVersion)
    puts(Py_GetVersion());
  else
    puts("not in a python env");
}

Cette fois, l’astuce repose sur le comportement par défaut d’un symbole marqué weak et non initialisé : il est mis à zéro. Sauf que si ce symbole est défini dans le processus chargé, il prendra la valeur de ce symbole, ce qui permet de détecter la présence de ce dernier sans passer par la libdl : c’est le dynamic loader qui se charge du travail au chargement du binaire (ce n’est donc pas strictement équivalent à la libdl qui effectue le test au moment où le code est exécuté).



Article rédigé par

Par le(s) même(s) auteur(s)

Crévindiou, c’est pas du bon C d’chez nous ça, cé du C deu’l ville !

Magazine
Marque
GNU/Linux Magazine
Numéro
267
Mois de parution
janvier 2024
Spécialité(s)
Résumé

IANAL (I Am Not A Linguist), mais quand j’entends du québécois, je ne comprends pas tout, mais je comprends. Mais qu’en est-il des dialectes du langage C ? Car oui, le langage C a des dialectes, et nous allons voyager un peu à travers l’un d’entre eux, le dialecte GNU, supporté principalement par GCC, mais aussi, en partie, par Clang.

Les derniers articles Premiums

Les derniers articles Premium

Le combo gagnant de la virtualisation : QEMU et KVM

Magazine
Marque
Contenu Premium
Spécialité(s)
Résumé

C’est un fait : la virtualisation est partout ! Que ce soit pour la flexibilité des systèmes ou bien leur sécurité, l’adoption de la virtualisation augmente dans toutes les organisations depuis des années. Dans cet article, nous allons nous focaliser sur deux technologies : QEMU et KVM. En combinant les deux, il est possible de créer des environnements de virtualisation très robustes.

Brève introduction pratique à ZFS

Magazine
Marque
Contenu Premium
Spécialité(s)
Résumé

Il est grand temps de passer à un système de fichiers plus robuste et performant : ZFS. Avec ses fonctionnalités avancées, il assure une intégrité des données inégalée et simplifie la gestion des volumes de stockage. Il permet aussi de faire des snapshots, des clones, et de la déduplication, il est donc la solution idéale pour les environnements de stockage critiques. Découvrons ensemble pourquoi ZFS est LE choix incontournable pour l'avenir du stockage de données.

Générez votre serveur JEE sur-mesure avec Wildfly Glow

Magazine
Marque
Contenu Premium
Spécialité(s)
Résumé

Et, si, en une ligne de commandes, on pouvait reconstruire son serveur JEE pour qu’il soit configuré, sur mesure, pour les besoins des applications qu’il embarque ? Et si on pouvait aller encore plus loin, en distribuant l’ensemble, assemblé sous la forme d’un jar exécutable ? Et si on pouvait même déployer le tout, automatiquement, sur OpenShift ? Grâce à Wildfly Glow [1], c’est possible ! Tout du moins, pour le serveur JEE open source Wildfly [2]. Démonstration dans cet article.

Les listes de lecture

9 article(s) - ajoutée le 01/07/2020
Vous désirez apprendre le langage Python, mais ne savez pas trop par où commencer ? Cette liste de lecture vous permettra de faire vos premiers pas en découvrant l'écosystème de Python et en écrivant de petits scripts.
11 article(s) - ajoutée le 01/07/2020
La base de tout programme effectuant une tâche un tant soit peu complexe est un algorithme, une méthode permettant de manipuler des données pour obtenir un résultat attendu. Dans cette liste, vous pourrez découvrir quelques spécimens d'algorithmes.
10 article(s) - ajoutée le 01/07/2020
À quoi bon se targuer de posséder des pétaoctets de données si l'on est incapable d'analyser ces dernières ? Cette liste vous aidera à "faire parler" vos données.
Voir les 65 listes de lecture

Abonnez-vous maintenant

et profitez de tous les contenus en illimité

Je découvre les offres

Déjà abonné ? Connectez-vous