qu'est-ce que Linux Mtd
Sous Linux, mtd fait référence à « périphérique technologique de mémoire » et est un sous-système du périphérique de stockage. Linux a introduit le système MTD pour fournir une interface unifiée pour les appareils NOR FLASH et NAND FLASH. Les périphériques MTD peuvent généralement être divisés en quatre couches : le nœud de périphérique, la couche de périphérique MTD, la couche de périphérique d'origine MTD et la couche de pilote matériel.
L'environnement d'exploitation de ce tutoriel : système linux5.9.8, ordinateur Dell G3.
Qu'est-ce que Linux MTD ?
MTD signifie « Memory Technology Device », qui signifie « périphérique de technologie de mémoire » et est un sous-système de périphériques de stockage Linux.
Dans le noyau Linux, la couche MTD est introduite pour fournir une interface unifiée pour les appareils NOR FLASH et NAND FLASH. MTD isole le système de fichiers de la mémoire FLASH sous-jacente.
Le but de la conception de ce système MTD est de fournir une couche d'abstraction et une interface pour les périphériques de mémoire, de sorte que les concepteurs de pilotes matériels n'aient qu'à fournir la lecture/écriture/effacement la plus simple des périphériques matériels sous-jacents. vous n'avez pas besoin de vous soucier de la façon dont les données sont représentées aux utilisateurs de couche supérieure, car le sous-système du périphérique de stockage MTD l'a fait pour vous.
MTD framework
Le périphérique MTD de Linux se trouve sous drivers/mtd/.
Le contenu du fichier MTD est le suivant :
Les appareils MTD peuvent généralement être divisés en quatre couches
De haut en bas : le nœud de périphérique, la couche de périphérique MTD, la couche de périphérique d'origine MTD et la couche de pilote matériel.
1.cmdlinepart.c
Lorsque la table de partition mtd est transmise à Linux par u-boot via le paramètre cmd, le noyau Linux n'a pas besoin d'enregistrer et d'ajouter mtdparts, et n'a besoin que de définir le option de partition en ligne de commande dans MTD Activez-la simplement. Pour utiliser cette méthode, u-boot doit prendre en charge MTD et les paramètres de partition mtd transmis doivent répondre aux exigences de format.
Dossier 2.devices
Lorsque nous avons un périphérique spi flash et que nous souhaitons utiliser mtd pour le gérer, nous le plaçons généralement dans le dossier devices, tel que m25p80.c sous le dossier devices est un exemple typique de spi flash appareil.
3.chips/nand/onenand dossier
le pilote flash nand se trouve sous le dossier nand
le pilote flash onenand se trouve sous le dossier onenand
nor flash est assez compliqué, et il se trouvera sous ce qui suit ; fichiers :
puces : pilote universel d'interface cfi/jedec
périphériques : ni pilote flash sous-jacent (spi flash)
cartes : ni fonctions liées aux relations de mappage flash
4. Fichier principal
mtdchar.c : caractère MTD. interface de périphérique Implémentation pertinente, numéro de périphérique 31 ;
mtdblock.c : implémentation liée à l'interface de périphérique de bloc MTD, numéro de périphérique 90, ; mise en œuvre.
5.ubiLa couche de support des fichiers ubifs. Lorsque vous utilisez le système de fichiers ubifs, vous devez sélectionner Activer UBI dans les pilotes de périphérique -> Prise en charge des périphériques de technologie de mémoire (MTD) -> Sélectionnez la prise en charge du système de fichiers UBIFS dans Systèmes de fichiers -> Systèmes de fichiers divers.
Implémentation de la table de partition MTD
Pendant le processus de démarrage, vous pouvez souvent voir des informations similaires aux suivantes depuis la console,
0x000000000000-0x000000100000 : "Bootloade" 0x000000100000-0x000002000000 : "Kernel" 0x000002000000-0x000003000000 : "User" 0x000003000000-0x000008000000 : "File System"
C'est la forme de représentation la plus intuitive que MTD nous offre, nous montrant les différentes partitions de la mémoire. La structure des partitions du module, mais comment ces partitions sont-elles implémentées ? Il existe plusieurs façons d'implémenter la table de partition, qui sont expliquées ci-dessous : Remarque : La condition préalable à l'implémentation de la table de partition est que le pilote de périphérique MTD ait réussi, sinon il n'y aura pas de partition dont parler même si le pilote ne réussit pas.
1. Ajout au noyau
L'ajout au noyau est une méthode plus couramment utilisée. Elle devrait être trouvée dans n'importe quel livre de transplantation de pilotes. L'essentiel est d'ajouter mtd_partition dans le périphérique de la plate-forme. Ce qui suit. Informations, je ne les décrirai pas trop icistruct mtd_partition s3c_nand_part[] = {
{
.name = "Bootloader",
.offset = 0,
.size = (1 * SZ_1M),
.mask_flags = MTD_CAP_NANDFLASH,
},
{
.name = "Kernel",
.offset = (1 * SZ_1M),
.size = (31 * SZ_1M) ,
.mask_flags = MTD_CAP_NANDFLASH,
},
{
.name = "User",
.offset = (32 * SZ_1M),
.size = (16 * SZ_1M) ,
},
{
.name = "File System",
.offset = (48 * SZ_1M),
.size = (96 * SZ_1M),
}
};
static struct s3c_nand_set s3c_nand_sets[] = {
[0] = {
.name = "nand",
.nr_chips = 1,
.nr_partitions = ARRAY_SIZE(s3c_nand_part),
.partitions = ok6410_nand_part,
},
};
static struct s3c_platform_nand s3c_nand_info = {
.tacls = 25,
.twrph0 = 55,
.twrph1 = 40,
.nr_sets = ARRAY_SIZE(s3c_nand_sets),
.sets = ok6410_nand_sets,
};
static void __init s3c_machine_init(void)
{
s3c_nand_set_platdata(&s3c_nand_info);
}
Copier après la connexionParce que notre pilote MTD est terminé lorsque le périphérique et le pilote correspondent, la fonction d'interface de sonde dans le pilote sera appelée. add_mtd_partitions(s3c_mtd, sets dans la fonction de sonde ->partitions, sets->nr_partitions);Ajout de tables de partition.
2.u-boot transfert de paramètresstruct mtd_partition s3c_nand_part[] = { { .name = "Bootloader", .offset = 0, .size = (1 * SZ_1M), .mask_flags = MTD_CAP_NANDFLASH, }, { .name = "Kernel", .offset = (1 * SZ_1M), .size = (31 * SZ_1M) , .mask_flags = MTD_CAP_NANDFLASH, }, { .name = "User", .offset = (32 * SZ_1M), .size = (16 * SZ_1M) , }, { .name = "File System", .offset = (48 * SZ_1M), .size = (96 * SZ_1M), } }; static struct s3c_nand_set s3c_nand_sets[] = { [0] = { .name = "nand", .nr_chips = 1, .nr_partitions = ARRAY_SIZE(s3c_nand_part), .partitions = ok6410_nand_part, }, }; static struct s3c_platform_nand s3c_nand_info = { .tacls = 25, .twrph0 = 55, .twrph1 = 40, .nr_sets = ARRAY_SIZE(s3c_nand_sets), .sets = ok6410_nand_sets, }; static void __init s3c_machine_init(void) { s3c_nand_set_platdata(&s3c_nand_info); }
add_mtd_partitions(s3c_mtd, sets->partitions, sets->nr_partitions);
实现分区表的添加。
2.u-boot传参
在u-boot下可以通过添加mtdparts信息到bootargs中,u-boot启动后会将bootargs中的信息传送给kernel,,kernel在启动的时候会解析bootargs中mtdparts的部分,这边举个例子:
mtdparts=nand.0:1M(Bootloader)ro,31M(Kernel)ro,16M(User),96M(File System)
mtdparts=nand.0:1M(Bootloader)ro,31M(Kernel)ro,16M(User),96M(File System)</code. >, Pour un format mtdparts plus spécifique, veuillez vous référer aux informations pertinentes. 🎜🎜Pour que le noyau puisse analyser les informations mtdparts, nous devons activer l'option d'analyse de la table de partition de ligne de commande des pilotes de périphérique -> 🎜<p>在内核中添加分区表的时候,我们是在平台设备里面加入mtd_partition信息。这边通过u-boot传参则取消平台设备里面的partition信息,那我们需要怎样解析u-boot的传过来的mtdparts呢。</p><p>u-boot传参过来后,cmdlinepart.c中会将这些参数解析好,存在里面<code>LIST_HEAD(part_parsers)
链表里面,然后我们在驱动的probe函数中,通过调用mtd_device_parse_register(mtd, probe_types,&ppdata, NULL, 0);
函数。mtd_device_parse_register()
函数位于drivers/mtd/mtdcore.c 中,内容如下:
int mtd_device_parse_register(struct mtd_info *mtd, const char * const *types, struct mtd_part_parser_data *parser_data, const struct mtd_partition *parts, int nr_parts) { int err; struct mtd_partition *real_parts; err = parse_mtd_partitions(mtd, types, &real_parts, parser_data); if (err <= 0 && nr_parts && parts) { real_parts = kmemdup(parts, sizeof(*parts) * nr_parts, GFP_KERNEL); if (!real_parts) err = -ENOMEM; else err = nr_parts; } if (err > 0) { err = add_mtd_partitions(mtd, real_parts, err); kfree(real_parts); } else if (err == 0) { err = add_mtd_device(mtd); if (err == 1) err = -ENODEV; } return err; }
可以看到该函数会先执行parse_mtd_partitions(mtd, types, &real_parts, parser_data);
函数,后面还是通过add_mtd_partitions()
函数来实现分区表的添加。
parse_mtd_partitions()
函数位于drivers/mtd/mtdpart.c中,内容如下:
int parse_mtd_partitions(struct mtd_info *master, const char *const *types, struct mtd_partition **pparts, struct mtd_part_parser_data *data) { struct mtd_part_parser *parser; int ret = 0; if (!types) types = default_mtd_part_types; for ( ; ret <= 0 && *types; types++) { parser = get_partition_parser(*types); if (!parser && !request_module("%s", *types)) parser = get_partition_parser(*types); if (!parser) continue; ret = (*parser->parse_fn)(master, pparts, data); put_partition_parser(parser); if (ret > 0) { printk(KERN_NOTICE "%d %s partitions found on MTD device %s\n", ret, parser->name, master->name); break; } } return ret; }
进入parse_mtd_partitions()
函数会先判断types的类型,如果为空则给默认值,types的类型一般就两种,如下:
static const char * const default_mtd_part_types[] = { "cmdlinepart", "ofpart", NULL };
第一个"cmdlinepart"即u-boot传参的方式,第二个"ofpart"即下面要讲到的使用dts传参的方式,判断完类型后,就通过get_partition_parser
去解析part_parsers
链表里面的数据,这样就完成u-boot参数的解析。
3.dts传参
在Linux3.14以后的linux版本中,加入一个新的知识DTS(Device tree),dts其实就是为了解决ARM Linux中的冗余代码,在Linux2.6版本的arch/arm/plat.xxx和arch/arm/mach.xxx中充斥着大量的垃圾代码,采用Device Tree后,许多硬件的细节可以直接透过它传递给Linux,而不再需要在kernel中进行大量的冗余编码,关于dts可以自行查阅资料。
dts传参的原理其实和u-boot一样,区别在于:u-boot的时候是通过cmdlinepart.c文件实现分区信息写入LIST_HEAD(part_parsers)
链表,dts则是用过ofpart.c文件实现分区信息写入LIST_HEAD(part_parsers)
链表,所以同样要把ofpart.c文件的宏打开,在调用mtd_device_parse_register(mtd, probe_types,&ppdata, NULL, 0);
函数的时候types要设置成ofpart。
如果去对比Linux2.6版本和Linux3.14版本,会发现drivers/mtd/ofpart.c和drivers/mtd/mtdpart.c文件有所不同,Linux3.8版本里面多了Device tree这一部分的内容,感兴趣的可以自己深究下。
这边举个dts的例子:
pinctrl-0 = <&s3c_nand_flash>; ranges = <0 0 0x000000000000 0x000008000000>; /* CS0: NAND */ nand@0,0 { partition@1 { label = "Bootloader"; reg = <0x000000000000 0x000000100000>; }; partition@2 { label = "Kernel"; reg = <0x000000100000 0x000002000000>; }; partition@3 { label = "User"; reg = <0x000002000000 0x000003000000>; }; partition@4 { label = "File System"; reg = <0x000003000000 0x000008000000>; }; };
Linux mtd system的分析就到这边,有感悟时会持续会更新。
相关推荐:《Linux视频教程》
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!

Outils d'IA chauds

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

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

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

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

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)

É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 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.

La politique de sauvegarde et de récupération de GitLab dans le système CentOS afin d'assurer la sécurité et la récupérabilité des données, Gitlab on CentOS fournit une variété de méthodes de sauvegarde. Cet article introduira plusieurs méthodes de sauvegarde courantes, paramètres de configuration et processus de récupération en détail pour vous aider à établir une stratégie complète de sauvegarde et de récupération de GitLab. 1. MANUEL BACKUP Utilisez le Gitlab-RakegitLab: Backup: Créer la commande pour exécuter la sauvegarde manuelle. Cette commande sauvegarde des informations clés telles que le référentiel Gitlab, la base de données, les utilisateurs, les groupes d'utilisateurs, les clés et les autorisations. Le fichier de sauvegarde par défaut est stocké dans le répertoire / var / opt / gitlab / backups. Vous pouvez modifier / etc / gitlab

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 support de disque dur CentOS est divisé en étapes suivantes: Déterminez le nom du périphérique du disque dur (/ dev / sdx); créer un point de montage (il est recommandé d'utiliser / mnt / newdisk); Exécutez la commande Mount (mont / dev / sdx1 / mnt / newdisk); modifier le fichier / etc / fstab pour ajouter une configuration de montage permanent; Utilisez la commande umount pour désinstaller l'appareil pour vous assurer qu'aucun processus n'utilise l'appareil.

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.

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).
