Se connecter
Se connecter
Inscription
Mot de passe perdu
Connexion:
[Actualités]
iOS 26.3 arrive bientôt : date de sortie et ouverture historique à Android
[Actualités]
Les États-Unis interdisent les drones étrangers. DJI et Autel en difficulté.
[Actualités]
Apple va augmenter les prix de l'iPhone à cause des puces mémoire
[Actualités]
Test Wizordum (PS5) - Un FPS à l'ambiance et aux mécaniques old-school (Hereti...
[Actualités]
Android 16 : une fonctionnalité qui va révolutionner votre façon de contrôle...
[Actualités]
Android Auto pourrait nous permettre de diffuser du contenu multimédia directem...
[Actualités]
LG a résolu le principal problème des écrans OLED. De nouveaux moniteurs arri...
[Actualités]
Pourquoi les SSD pourraient être en pénurie en 2026
[Actualités]
ChatGPT modifie désormais votre ton automatiquement et vous aide même avec vos...
[Actualités]
Les taxis autonomes ont paralysé la circulation. Il a suffi d'éteindre les lum...
[Articles]
Wizordum
[Articles]
Tombi! 2: The Evil Swine Return Special Edition
[Articles]
Stranger Things - Le Voyage
[Articles]
Les Chevaliers du ciel Tanguy et Laverdure tome 13 :Opération "Aube Rouge"
[Articles]
Outlaws tome 3 : Prémisses
[Articles]
Tanis tome 2 : Le démon de la mer morte
[Articles]
Boxville 2
[Articles]
Une faille critique exploitant les fichiers Windows JPG, analysée par ESET Rese...
[Articles]
Outlaws + Handful of Missions: Remaster
[Articles]
Ninn tome 7 : Un zoo de papier
Actualités
Lettre d'information
Proposer une actualité
Archives
Actualités
Articles
Programmation
Press Release
Matériel
Logiciels
Livres
Interviews
Derniers commentaires
Jeux Vidéos
XBox One
XBox 360
Wii U
PSP
PS4
PS3
PC
DS
GameCube
3DS
Forum
Derniers messages
Informatique
Fun
Divers
Logithèque
Blogs
Divers
A Propos
Annonceurs
Contact
Recherche
RSS
Editer un article
Titre
Mots Clés
Texte
[size=18] [b]Nom[/b] [/size] init_bh, remove_bh, mark_bh, disable_bh, enable_bh - gestionnaire d'interruption découplé [size=18] [b]Résumé[/b] [/size] [b]#include
[/b] .HP [b][i]void init_bh(int nr , void (* routine )(void));[/i][/b] .HP [b][i]void remove_bh(int nr );[/i][/b] .HP [b][i]void mark_bh(int nr );[/i][/b] .HP [b][i]void disable_bh(int nr );[/i][/b] .HP [b][i]void enable_bh(int nr );[/i][/b] [size=18] [b]Description[/b] [/size] [b]Théorie[/b] Le découpage d'un gestionnaire d'interruptions en deux permet d'assurer un traitement des interruptions entrantes en temps réél critique par le gestionnaire haut tandis que le gestionnaire bas les traitera réellement dès que possible. Le gestionnaire haut (enregistré par [b]request_irq (9))[/b] se contente généralement de déplacer des données entre un périphérique et un tampon en mémoire, et de s'assurer que le périphérique est dans un état normal. Tant que ce gestionnaire est en cours d'éxécution, l'interruption correspondante est désactivée. S'il s'agit d'un gestionnaire d'interruption rapide (i.e., si [b]SA_INTERRUPT[/b] est positionné), toutes les interruptions sont désactivées. Le gestionnaire bas fait ce qu'il reste à traiter pour l'interruption correspondante. Un gestionnaire bas est éxécuté alors que les interruptions sont autorisées. Cependant, un mécanisme de blocage assure qu'une seule instance d'un gestionnaire bas donné est exécutée à un instant donné. Les gestionnaires bas sont lancés par [b]do_bottom_half() ,[/b] qui est appelé par [b]schedule()[/b] et [b]ret_from_sys_call() . [/b] [b]Usage[/b] [b]init_bh()[/b] installe [i]routine()[/i] en tant que gestionnaire bas numéro [b]nr . [/b] Cela est réalisé par l'ajout d'une entrée au tableau [b]bh_base[] ,[/b] et le positionnement du bit approprié du vecteur [b]bh_mask .[/b] Plutôt que forcer un numéro explicite, il est recommandé d'ajouter une entrée à l'énumération anonyme dans [b]include/linux/interrupt.h . [/b] [b]remove_bh()[/b] enlève le gestionnaire bas numéro [i]nr[/i] de la liste des gestionnaires bas. L'entrée correspondante est enlevée de [b]bh_base[][/b] le bit approprié de [b]bh_mask[/b] est réinitialisé. [b]mark_bh()[/b] demande au noyau d'éxécuter le gestionnaire bas correspondant dès que possible. Cette fonction n'est normalement appelée que par le gestionnaire haut d'un gestionnaire d'interruptions. Il fonctionne en positionnant le bit correspondant du vecteur [b]bh_active .[/b] [b]disable_bh()[/b] désactive le gestionnaire bas numéro [i]nr[/i] en réinitialisant le bit approprié de [b]bh_mask .[/b] Cette fonction incrémente également [b][i]bh_mask_count[ nr ],[/i][/b] qui est utilisé pour assurer que des appels imbriqués à [b]disable_bh()[/b] doivent correspondre à un nombre égal d'appels à [b]enable_bh() .[/b] [b]enable_bh()[/b] active un gestionnaire bas précédemment désactivé par [b]disable_bh() .[/b] Cette fonction décrémente [b][i]bh_mask_count[ nr ].[/i][/b] Ensuite, si cette valeur est zéro, le gestionnaire bas correspondant est activé en positionnant le bit approprié de [b]bh_mask .[/b] [size=18] [b]Valeur renvoyée[/b] [/size] Aucune valeur n'est renvoyée. [size=18] [b]DisponibilitÈ[/b] [/size] Linux 2.0+. [b]init_bh()[/b] et [b]remove_bh()[/b] n'étaient pas présentes dans les anciennes versions de Linux. Dans ces versions, [b]bh_base[][/b] et [b]bh_mask[/b] doivent être modifiés à la main. [size=18] [b]Voir aussi[/b] [/size] [b]request_irq (9), queue_task (9)[/b] [b]include/asm*/softirq.h , include/linux/interrupt.h , kernel/softirq.c[/b] (lqKernel Korner(rq dans l'article 26 du magazine [i]The Linux Journal[/i] comprend un article sur les gestionnaires bas d'interruptions sous Linux. Une copie en est disponible sur le web à [b]http://www.ssc.com/lj/issue26/interrupt.html .[/b] [size=18] [b]Auteur[/b] [/size] [i]Neil Moore < amethyst@maxwell.ml.org >[/i] [size=18] [b]Traducteur[/b] [/size] [i]Thierry Vignaud < tvignaud@mandrakesoft.com >, 2000[/i] [size=18] [b]Bugs[/b] [/size] Seuls 32 gestionnaires bas peuvent exister. Augmenter ce nombre impose de modifier la taille de [b]bh_base[][/b] et [b][i]bh_mask_count[][/i][/b] dans [b]kernel/softirq.c,[/b] ainsi que de changer [b]bh_active[/b] et [b]bh_mask[/b] (dans le même fichier) pour un type plus large. Une meilleure solution, cependant, serait de rassembler les multiples gestionnaires bas en un seul en utilisant une liste chaînée de tâches. Voir [b]queue_task (9)[/b] pour les détails.
Fichier
Forum
-
Derniers messages
Bavardages
Aujourd'hui, je rénove ou je construis ^^
Informations
Besoin d’avis sur l’UX de mon mini-projet web (et plus globalement sur ce qui vous rebute sur un site) ?
Software
problème sur windows 10
Réseaux et Télécom
Problème wifi (POE)
Software
Postfix - Need help
Bavardages
Oh râge oh désespoir !
Programmation
Enregistrement client et envoi mail
Software
SÉCURITÉ MACBOOK
Hardware
conseil matos réseau?
Hardware
nVidia Shield Android TV
Actualités
-
Archives
iOS
iOS 26.3 arrive bientôt : date de sortie et ouverture historique à Android
Matériel
Les États-Unis interdisent les drones étrangers. DJI et Autel en difficulté.
Apple
Apple va augmenter les prix de l'iPhone à cause des puces mémoire
Jeux Vidéos
Test Wizordum (PS5) - Un FPS à l'ambiance et aux mécaniques old-school (Heretic, Hexen, etc).
Android
Android 16 : une fonctionnalité qui va révolutionner votre façon de contrôler votre réseau
Ada
CSS
Cobol
CPP
HTML
Fortran
Java
JavaScript
Pascal
Perl
PHP
Python
SQL
VB
XML
Anon URL
DailyMotion
eBay
Flickr
FLV
Google Video
Google Maps
Metacafe
MP3
SeeqPod
Veoh
Yahoo Video
YouTube
6px
8px
10px
12px
14px
16px
18px
Informaticien.be
- © 2002-2025
Akretio
SPRL - Generated via
Kelare
The Akretio Network:
Akretio
-
Freedelity
-
KelCommerce
-
Votre publicité sur informaticien.be ?