Как я могу установить ядро ​​реального времени?

Я прочитал много тем с похожими вопросами, но после прочтения ответов я очень растерялся. Я нашел в них много ссылок с репозиториями, но люди обсуждают, какие репозитории созданы для одной или двух версий ubuntu, но я ничего не нашел в версии 11.10. Слишком рано просить об этом? Должен ли я понижать версию своего Ubuntu до ядра реального времени?

26
задан 5 June 2012 в 19:51

4 ответа

Долгосрочная цель проекта ядра RT состоит в том, чтобы закончить тем, что имела всю функциональность RT в стандартном ядре, и это прогрессирует приятно. Патч RT имел неправильные выпуски в прошлом, и взламывание kernel.org в августе 2011 делало 3,0 версии недоступными в течение многих месяцев, но теперь вещи выглядят хорошими: существует патч для 3,0, другой для 3,2 (совпадающий с версиями ядра в Ubuntu 11.10 и 12.04) и другой для 3,4, видят здесь.

Если Вы используете Точный, можно использовать PPA Alessio Bogani В реальном времени, кто любезно упаковал ванильное ядро с примененным патчем RT и сохраняет его в синхронизации с номерами версий в Точном.

Если Вы предпочитаете создавать ядро RT вручную, сначала установите необходимые пакеты программного обеспечения:

sudo apt-get install kernel-package fakeroot build-essential libncurses5-dev

Затем выберите ванильное ядро, и патч RT (номера версий несколько стары, настраивают по мере необходимости):

mkdir -p ~/tmp/linux-rt
cd ~/tmp/linux-rt
wget http://www.kernel.org/pub/linux/kernel/v3.x/linux-3.4.tar.bz2
# Alternatively, try http://mirror.be.gbxs.net/pub/linux/kernel/projects/rt/3.4/patch-3.4-rt7.patch.bz2
# if the following is not available:
wget http://www.kernel.org/pub/linux/kernel/projects/rt/3.4/patch-3.4-rt7.patch.bz2
tar xjvf linux-3.4.tar.bz2
cd linux-3.4
patch -p1 < <(bunzip2 -c ../patch-3.4-rt7.patch.bz2)

Затем настройте использование ядра:

cp /boot/config-$(uname -r) .config && make oldconfig

где необходимо выбрать "полное вытеснение" (опция 5) при запросе, и оставьте все остальное в ее значении по умолчанию путем нажатия Enter при каждой подсказке. Конфигурация от-lowlatency ядра могла бы быть лучшей начальной точкой, чем тот из - универсальное ядро.

Затем создайте ядро с:

sed -rie 's/echo "\+"/#echo "\+"/' scripts/setlocalversion
make-kpkg clean
CONCURRENCY_LEVEL=$(getconf _NPROCESSORS_ONLN) fakeroot make-kpkg --initrd --revision=0 kernel_image kernel_headers

И наконец установите свое новое ядро с:

sudo dpkg -i ../linux-{headers,image}-3.4.0-rt7_0_*.deb

Необходимо смочь перезагрузить в ядро RT в этой точке. Если Вашему ядру не удается загрузиться, удостоверяются, что Вы перепроверяете параметры начальной загрузки и редактируете их соответственно в Вашем загрузчике. Например, функции ACPI могут влиять на Вашу систему реального времени (как указано на rt.wiki.kernel.org). Добавление acpi=off может быть решением в таком случае.

Заметьте, хотя это патч RT является несовместимым с двоичным драйвером Nvidia (но см. сообщение пользователя "rt-ядро" ниже, и этот вопрос для обходного решения), и что патчи ядра Ubuntu не будут присутствовать, таким образом, у Вас смогут быть аппаратные проблемы, которые Вы не имели прежде. Это верно и для пакетов PPA и для скомпилированного ядра. Можно всегда загружаться в Ваш - универсальное ядро и удалять пакеты ядра в реальном времени, если они дают Вам проблему, конечно.

27
ответ дан 5 June 2012 в 19:51

Другой вариант - установить RTKernel из репозиториев KXStudio. Он хранит набор пакетов, предназначенных для производства аудио и музыки, и у него есть пакеты в режиме реального времени и с низкой задержкой.

http://kxstudio.sourceforge.net/Main_Page https://launchpad.net/~kxstudio-team/+archive/kernel

0
ответ дан 5 June 2012 в 19:51

Насколько я знаю, разработка ядра в реальном времени не имеет, идут в ногу с циклом релиза Ubuntu. Если необходимо выполнить ядро в реальном времени, вероятно, необходимо будет выполнить более старую версию.

Дополнительные сведения см. в https://help.ubuntu.com/community/UbuntuStudio/RealTimeKernel.

Обратите внимание, что, кажется, существует по крайней мере некоторая текущая работа над ядром низкой задержки: https://launchpad.net / ~ abogani / + archive/ppa? поле series_filter=oneiric.

2
ответ дан 5 June 2012 в 19:51

Если вы зависите от использования бинарного драйвера nvidia, вы можете патчить оригинальный драйвер этим патчем (только для ядер 3.4+ с rt-патчами). Этот патч поставляется без гарантии и гарантии! Используйте его на свой страх и риск .->

Index: kernel/conftest.sh
===================================================================
--- kernel/conftest.sh.orig
+++ kernel/conftest.sh
@@ -95,7 +95,7 @@
         fi
     fi

-    CFLAGS="$CFLAGS $OUTPUT_CFLAGS -I$HEADERS $AUTOCONF_CFLAGS"
+    CFLAGS="$CFLAGS $OUTPUT_CFLAGS -I$HEADERS -I$OUTPUT/arch/x86/include/generated $AUTOCONF_CFLAGS"

     test_xen

@@ -126,7 +126,7 @@
     CFLAGS="$BASE_CFLAGS $MACH_CFLAGS $OUTPUT_CFLAGS -I$HEADERS $AUTOCONF_CFLAGS"

     if [ "$ARCH" = "i386" -o "$ARCH" = "x86_64" ]; then
-        CFLAGS="$CFLAGS -I$SOURCES/arch/x86/include -I$SOURCES/arch/x86/include/generated"
+        CFLAGS="$CFLAGS -I$SOURCES/arch/x86/include -I$OUTPUT/arch/x86/include/generated"
 elif [ "$ARCH" = "ARMv7" ]; then
     CFLAGS="$CFLAGS -I$SOURCES/arch/arm/include -I$SOURCES/arch/arm/include/generated"
     fi
@@ -512,7 +512,12 @@
             # and if it as an 'event' member.
             #
             echo "$CONFTEST_PREAMBLE
-            #include <asm/system.h>
+            #include <linux/version.h>
+       #if LINUX_VERSION_CODE > KERNEL_VERSION(3, 3, 0)
+         #include <asm/switch_to.h>
+       #else
+         #include <asm/system.h>
+       #endif
             #include <linux/pm.h>
             void conftest_pm_message_t(pm_message_t state) {
                 pm_message_t *p = &state;
@@ -965,11 +970,12 @@
             #
             echo "$CONFTEST_PREAMBLE
             #include <linux/acpi.h>
+            #include <acpi/acpixf.h>
             void conftest_acpi_walk_namespace(void) {
                 acpi_walk_namespace();
             }" > conftest$.c

-            $CC $CFLAGS -c conftest$.c > /dev/null 2>&1
+            #CC $CFLAGS -c conftest$.c > /dev/null 2>&1
             rm -f conftest$.c

             if [ -f conftest$.o ]; then
@@ -980,6 +986,7 @@

             echo "$CONFTEST_PREAMBLE
             #include <linux/acpi.h>
+       #include <acpi/acpixf.h>
             void conftest_acpi_walk_namespace(void) {
                 acpi_walk_namespace(0, NULL, 0, NULL, NULL, NULL, NULL);
             }" > conftest$.c
@@ -996,6 +1003,7 @@

             echo "$CONFTEST_PREAMBLE
             #include <linux/acpi.h>
+            #include <acpi/acpixf.h>
             void conftest_acpi_walk_namespace(void) {
                 acpi_walk_namespace(0, NULL, 0, NULL, NULL, NULL);
             }" > conftest$.c
@@ -1603,6 +1611,9 @@
                 fi
             fi
         fi
+
+   RET=0
+   SELECTED_MAKEFILE=Makefile.kbuild

         if [ "$RET" = "0" ]; then
             ln -s $SELECTED_MAKEFILE Makefile
Index: kernel/nv-linux.h
===================================================================
--- kernel/nv-linux.h.orig
+++ kernel/nv-linux.h
@@ -111,7 +111,11 @@
 #include <linux/timer.h>

 #include <asm/div64.h>              /* do_div()                         */
+#if LINUX_VERSION_CODE > KERNEL_VERSION(3, 3, 0)
+#include <asm/switch_to.h>
+#else
 #include <asm/system.h>             /* cli, sli, save_flags             */
+#endif
 #include <asm/io.h>                 /* ioremap, virt_to_phys            */
 #include <asm/uaccess.h>            /* access_ok                        */
 #include <asm/page.h>               /* PAGE_OFFSET                      */
@@ -291,17 +295,17 @@
 #endif
 #endif

-#if defined(CONFIG_PREEMPT_RT)
-typedef atomic_spinlock_t         nv_spinlock_t;
-#define NV_SPIN_LOCK_INIT(lock)   atomic_spin_lock_init(lock)
-#define NV_SPIN_LOCK_IRQ(lock)    atomic_spin_lock_irq(lock)
-#define NV_SPIN_UNLOCK_IRQ(lock)  atomic_spin_unlock_irq(lock)
-#define NV_SPIN_LOCK_IRQSAVE(lock,flags) atomic_spin_lock_irqsave(lock,flags)
+#if defined(CONFIG_PREEMPT_RT_FULL)
+typedef raw_spinlock_t            nv_spinlock_t;
+#define NV_SPIN_LOCK_INIT(lock)   raw_spin_lock_init(lock)
+#define NV_SPIN_LOCK_IRQ(lock)    raw_spin_lock_irq(lock)
+#define NV_SPIN_UNLOCK_IRQ(lock)  raw_spin_unlock_irq(lock)
+#define NV_SPIN_LOCK_IRQSAVE(lock,flags) raw_spin_lock_irqsave(lock,flags)
 #define NV_SPIN_UNLOCK_IRQRESTORE(lock,flags) \
-  atomic_spin_unlock_irqrestore(lock,flags)
-#define NV_SPIN_LOCK(lock)        atomic_spin_lock(lock)
-#define NV_SPIN_UNLOCK(lock)      atomic_spin_unlock(lock)
-#define NV_SPIN_UNLOCK_WAIT(lock) atomic_spin_unlock_wait(lock)
+  raw_spin_unlock_irqrestore(lock,flags)
+#define NV_SPIN_LOCK(lock)        raw_spin_lock(lock)
+#define NV_SPIN_UNLOCK(lock)      raw_spin_unlock(lock)
+#define NV_SPIN_UNLOCK_WAIT(lock) raw_spin_unlock_wait(lock)
 #else
 typedef spinlock_t                nv_spinlock_t;
 #define NV_SPIN_LOCK_INIT(lock)   spin_lock_init(lock)
@@ -956,8 +960,8 @@
     return ret;
 }

-#if defined(CONFIG_PREEMPT_RT)
-#define NV_INIT_MUTEX(mutex) semaphore_init(mutex)
+#if defined(CONFIG_PREEMPT_RT_FULL)
+#define NV_INIT_MUTEX(mutex) sema_init(mutex,1)
 #else
 #if !defined(__SEMAPHORE_INITIALIZER) && defined(__COMPAT_SEMAPHORE_INITIALIZER)
 #define __SEMAPHORE_INITIALIZER __COMPAT_SEMAPHORE_INITIALIZER

Сохраните патч как «nv295.33_for 3.3 + _rt.patch». Примените патч ->

sh NVIDIA-Linux-x86_64-295.33.run --apply-patch nv295.33_for 3.3+_rt.patch

. Это создаст новый двоичный установщик nvidia с именем «NVIDIA-Linux-x86_64-295.33-custom.run».

Запустите установщик с помощью

sh NVIDIA-Linux-x86_64-295.33-custom.run

. Это исправление не предоставляется без гарантии и гарантии! Используйте его на свой страх и риск.

Перезагрузитесь и получайте удовольствие.

Вы найдете больше информации на форуме nv. Там вы можете найти решение и для серии 295.40.

http://www.nvnews.net/vbulletin/showthread.php?p=2546508

0
ответ дан 5 June 2012 в 19:51

Другие вопросы по тегам:

Похожие вопросы: