Форум программистов, компьютерный форум, киберфорум
Linux
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
5 / 5 / 2
Регистрация: 01.02.2013
Сообщений: 88

Монтирование device-mapper устройства при загрузке системы

16.02.2017, 20:02. Показов 1250. Ответов 0

Студворк — интернет-сервис помощи студентам
Доброго времени суток!

Веду настройку системы МСВС на базе ядра версии 2.4. Необходимо создать виртуальное устройство с помощью device-mapper модуля, которое "мэппило" бы root-раздел, монтировать это устройство в момент загрузки системы и использовать его в качестве реального root-раздела.

Для того, чтобы изменить процесс загрузки, мне необходимо изменить ramdisk.

На ядре 2.4 при загрузке используется образ ramdisk типа initrd. При запуске системы этот образ распаковывается, и в нём выполняется файл, лежащий в корне этого образа и именованный linuxrc. Вот его содержимое:
Кликните здесь для просмотра всего текста
#!/bin/nash

echo "Loading dm-mod.o module"
insmod /lib/dm-mod.o
echo "Loading scsi_mod.o module"
insmod /lib/scsi_mod.o
echo "Loading sd_mod.o module"
insmod /lib/sd_mod.o
echo "Loading cdrom.o module"
insmod /lib/cdrom.o
echo "Loading sr_mod.o module"
insmod /lib/sr_mod.o
echo "Loading sg.o module"
insmod /lib/sg.o
echo "Loading usbcore.o module"
insmod /lib/usbcore.o
echo "Loading usb-storage.o module"
insmod /lib/usb-storage.o
sleep 5
echo "Loading jbd.o module"
insmod /lib/jbd.o
echo "Loading ext3.o module"
insmod /lib/ext3.o
echo Mounting /proc filesystem
mount -t proc /proc /proc
echo Creating block devices
mkdevices /dev

echo Creating root device
mkrootdev /dev/root
echo 0x0100 > /proc/sys/kernel/real-root-dev
echo Mounting root filesystem
mount -o acl,nosecdel,secrm --ro -t ext3 /dev/root /sysroot
pivot_root /sysroot /sysroot/initrd
umount /initrd/proc

На этой системе установлен загрузчик LILO. Вот его конфиг-файл:
Кликните здесь для просмотра всего текста
prompt
timeout=100
default=MCBC
boot=/dev/hda
map=/boot/map
install=bmp
restricted
password=Qq123456
bitmap=/boot/mcbc.bmp
lba32

image=/boot/vmlinuz-2.4.32-vniins42
label=MCBC
initrd=/boot/initrd-2.4.32-vniins42.img
read-only
root=/dev/hda2
append="acpi=on"


Виртуальное устройство я создаю с помощью модуля device-mapper. При этом, мне в будущем понадобится обрабатывать запросы к устройству, поэтому я написал свой модуль на основе этой статьи. Текст этой статьи рассчитан на ядро 2.6, поэтому многие функции пришлось переделывать в соответствии с header-ами ядра. Вот код, который у меня сейчас (для сравнения я оставил директивы define):

C
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
#include <linux/module.h>
#include <linux/kernel.h>
#include <linux/init.h>
#include <linux/version.h>
#include <linux/fs.h>
#include <linux/device-mapper.h>
 
#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,32)
#include <linux/bio.h>
#endif
 
#include <linux/fs.h>
#include <linux/kdev_t.h>
 
#if LINUX_VERSION_CODE <= KERNEL_VERSION(2,4,32)
#include <linux/mm.h>
#endif
 
struct Sddm_target
{
    struct dm_dev *dev;
    sector_t start;
};
 
#if LINUX_VERSION_CODE <= KERNEL_VERSION(2,4,32)
static int sddm_target_map(struct dm_target *ti, struct buffer_head *bh, int rw, union map_info *map_context)
#elif LINUX_VERSION_CODE <= KERNEL_VERSION(2,6,32)
static int sddm_target_map(struct dm_target *ti, struct bio *bio, union map_info *map_context)
#else
static int sddm_target_map(struct dm_target *ti, struct bio *bio)
#endif
{
    struct Sddm_target *mdt;
 
    mdt = (struct Sddm_target *) ti->private;
 
#if LINUX_VERSION_CODE <= KERNEL_VERSION(2,4,32)
    bh->b_dev = mdt->dev->dev;
#else
    bio->bi_bdev = mdt->dev->bdev;
#endif
 
#if LINUX_VERSION_CODE <= KERNEL_VERSION(2,4,32)
    submit_bh(rw, bh);
#elif LINUX_VERSION_CODE <= KERNEL_VERSION(2,6,32)
    submit_bio(bio->bi_rw, bio);
#else
    submit_bio(bio);
#endif
 
#if LINUX_VERSION_CODE <= KERNEL_VERSION(2,4,32)
    return 0;
#else
    return DM_MAPIO_SUBMITTED;
#endif
}
 
static int sddm_target_ctr(struct dm_target *ti, unsigned int argc, char **argv)
{
    struct Sddm_target *mdt;
    unsigned long start;
    unsigned long len;
    int err;
 
    if (argc != 2)
    {
        ti->error = "Invalid argument count";
        return -EINVAL;
    }
 
    mdt = (struct Sddm_target*)kmalloc(sizeof(struct Sddm_target), GFP_KERNEL);
 
    if (mdt == NULL)
    {
        printk(KERN_CRIT "\n Mdt is null\n");
        ti->error = "dm-basic_target: Cannot allocate linear context";
        return -ENOMEM;
    }       
 
    if (sscanf(argv[1], "%lu", &start) != 1)
    {
        ti->error = "dm-basic_target: Invalid deviceee sector";
        kfree(mdt);
        printk(KERN_CRIT "\n>>out function basic_target_ctr with errorrrrrrrrrr \n");           
        return -EINVAL;
    }
 
    mdt->start = (sector_t)start;
 
#if LINUX_VERSION_CODE <= KERNEL_VERSION(2,4,32)
    err = dm_get_device(ti, argv[0], ti->begin, ti->len, dm_table_get_mode(ti->table), &mdt->dev);
#else
    err = dm_get_device(ti, argv[0], dm_table_get_mode(ti->table), &mdt->dev);
#endif
    if (err)
    {
        ti->error = "dm-basic_target: Device lookup failed";
        kfree(mdt);
        return -EINVAL;
    }
 
    ti->private = mdt;
 
    return 0;
}
 
static void sddm_target_dtr(struct dm_target *ti)
{
    struct Sddm_target *mdt = (struct Sddm_target *) ti->private;
 
    dm_put_device(ti, mdt->dev);
    kfree(mdt);
}
 
static struct target_type sddm_target = {
        .name = "sddm_target",
        .version = {1,0,0},
        .module = THIS_MODULE,
        .ctr = sddm_target_ctr,
        .dtr = sddm_target_dtr,
        .map = sddm_target_map,
};
 
static int __init init_sddm_target(void)
{
    int result;
 
    result = dm_register_target(&sddm_target);
 
    return 0;
}
 
static void __exit cleanup_sddm_target(void)
{
    dm_unregister_target(&sddm_target);
}
 
module_init(init_sddm_target);
 
module_exit(cleanup_sddm_target);
 
MODULE_LICENSE("GPL");
Но код скорее всего неверный, так как все эти особенности 2.4 ядра очень тяжело гуглятся. Основное внимание стоит уделить функциям sddm_target_map и sddm_target_ctr.

Собрав модуль, я перенёс его, необходимые мне бинарники и либы в соответствующие каталоги initrd образа, в том числе и dmsetup - утилита, необходимая для создания виртуальных устройств с помощью device-mapper-а.

Исправил конфиг LILO, исключив параметр root (монтирование буду делать руками).

Правлю linuxrc:
Кликните здесь для просмотра всего текста
#!/bin/nash

echo "Loading dm-mod.o module"
insmod /lib/dm-mod.o
echo "Loading scsi_mod.o module"
insmod /lib/scsi_mod.o
echo "Loading sd_mod.o module"
insmod /lib/sd_mod.o
echo "Loading cdrom.o module"
insmod /lib/cdrom.o
echo "Loading sr_mod.o module"
insmod /lib/sr_mod.o
echo "Loading sg.o module"
insmod /lib/sg.o
echo "Loading usbcore.o module"
insmod /lib/usbcore.o
echo "Loading usb-storage.o module"
insmod /lib/usb-storage.o
sleep 5
echo "Loading jbd.o module"
insmod /lib/jbd.o
echo "Loading ext3.o module"
insmod /lib/ext3.o
insmod /lib//sddm_target.o
echo Mounting /proc filesystem
mount -t proc /proc /proc
echo Creating block devices
mkdevices /dev
echo Creating root device

echo "=================================== ==="
ld-linux.so.2 /bin/dmsetup create root_part /opt/bin/table
echo "=================================== ==="

echo 0x0100 > /proc/sys/kernel/real-root-dev
mount -o acl,nosecdel,secrm --ro -t ext3 /dev/mapper/root_part /sysroot
pivot_root /sysroot /sysroot/initrd
umount /initrd/proc

Содержимое файла /opt/bin/table:
Кликните здесь для просмотра всего текста
0 62814150 sddm_target /dev/hda3 0

Создаю initrd, помещаю его в /boot каталог, переконфигурирую LILO одноимённой командой, перезагружаю систему.

Виртуальное устройство создаётся. Но в момент монтирования начинают происходить странные вещи. Выводя информацию о вызываемых функциях, я понял, что функция sddm_target_map вызывается 6 раз, после чего выводится сообщение:
Кликните здесь для просмотра всего текста
kjoutnald starting. Commit interval 5 seconds

Я почитал - это вполне логичное действие, которое выполняет проверку файловой системы. На обычных устройствах эта проверка длится одно мгновение. Здесь же она виснет, и сколько бы я не ждал - не отвисает.

В чём проблема - я не могу понять. Но подразумеваю, что проблема в коде модуля.

Тема довольно узкая, но я всё же надеюсь, что на свете существуют специалисты, которые в этом разбираются.

Если есть, что написать - пишите. И даже спрашивайте, если что-то интересно, потому что в разговоре порой может что-то проясниться.

Спасибо!
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
16.02.2017, 20:02
Ответы с готовыми решениями:

При загрузке системы выдаёт warning о "root device" и fsck
При загрузке Arch Linux выдает warning в консоли: **********************WARNING********************** * ...

При загрузке компьютера ошибка: Reboot and Select proper Boot device or Insert Boot Media in selected Boot device and press a kay
Всем привет, возникла проблема, надеюсь подскажете как ее решить. Сам мало что понимаю в компьютерном железе, поэтому просьба писать...

При загрузке компьютера ошибка: Reboot and Select proper Boot device or Insert Boot Media in selected Boot device and press a key
в компьютере разбираюсь плохо,напишите пожалуйста попроще,что это за проблема и как ее исправить?

0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
16.02.2017, 20:02
Помогаю со студенческими работами здесь

При запуске системы отключаются все USB-устройства, в т.ч. устройства ввода
При запуске видовс 8 появляется экран выбора учетки и сразу отключаются клавиатура и мышь, они подключены к usb. Пробывал менять порты не...

No bootable device - при этом все устройства видит
Ноутбук toshiba satelite с убунту. Одним прекрасным утром (накануне и много дней до этого с ним ничего примечательного не происходило) не...

Ошибка при загрузке No bootable device
Всем здравствуйте. Появилась проблема. На Xen сервере создан VM. На ней стоит CentOS 6.7. В какой-то момент потребовалось перезагрузить VM....

Select proper Boot device при загрузке компьютера
народ привет всем! я у вас впервые если что не так извиняйте. Помогите чем можете.Пришёл с работы а сынуля как всегда в своём репертуаре,...

Reboot and Select proper Boot device при загрузке
У меня такая проблема компьютер выводит на экран когда я его включаю: Reboot and Select proper Boot device or Insert Boot Media in selected...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
1
Ответ Создать тему
Новые блоги и статьи
Автозаполнение реквизита при выборе элемента справочника
Maks 27.03.2026
Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2. При выборе "Спецтехники" (Тип Справочник. Спецтехника), заполняется. . .
Сумматор с применением элементов трёх состояний.
Hrethgir 26.03.2026
Тут. https:/ / fips. ru/ EGD/ ab3c85c8-836d-4866-871b-c2f0c5d77fbc Первый документ красиво выглядит, но без схемы. Это конечно не даёт никаких плюсов автору, но тем не менее. . . всё может быть. . .
Автозаполнение реквизитов при создании документа
Maks 26.03.2026
Программный код из решения ниже размещается в модуле объекта документа, в процедуре "ПриСозданииНаСервере". Алгоритм проверки заполнения реализован для исключения перезаписи значения реквизита,. . .
Команды формы и диалоговое окно
Maks 26.03.2026
1. Команда формы "ЗаполнитьЗапчасти". Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2. В качестве источника данных. . .
Кому нужен AOT?
DevAlt 26.03.2026
Решил сделать простой ланчер Написал заготовку: dotnet new console --aot -o UrlHandler var items = args. Split(":"); var tag = items; var id = items; var executable = args;. . .
Отправка уведомления на почту при создании или изменении элементов справочника
Maks 24.03.2026
Программная отправка письма электронной почты на примере типового справочника "Склады" в конфигурации БП3. Перед реализацией необходимо выполнить настройку системной учетной записи электронной. . .
модель ЗдравоСохранения 5. Меньше увольнений- больше дохода!
anaschu 24.03.2026
Теперь система здравосохранения уменьшает количество увольнений. 9TO2GP2bpX4 a42b81fb172ffc12ca589c7898261ccb/ https:/ / rutube. ru/ video/ a42b81fb172ffc12ca589c7898261ccb/ Слева синяя линия -. . .
Midnight Chicago Blues
kumehtar 24.03.2026
Такой Midnight Chicago Blues, знаешь?. . Когда вечерние улицы становятся ночными, а ты не можешь уснуть. Ты идёшь в любимый старый бар, и бармен наливает тебе виски. Ты смотришь на пролетающие. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru