GoboLinux Downloads Documentation Community Recipes Screenshots

GoboLinux Recipe & Package Search Tool

71 versions of Linux.

ProgramAgeSizeByWWWSummary
Linux 4.13.2-r1 757  88794 Luca...
The Linux Kernel.
Linux 4.9.16-r3 928  100651 Luca...
The Linux Kernel.
Linux 4.9.4-r5 984  99374 Luca...
The Linux Kernel.
Linux 4.8.2-r2 1050  89394 Luca...
The Linux Kernel.
Linux 4.7.4-r1 1120  82767 Luca...
The Linux Kernel.
Linux 4.7.0-r4 1175  82585 Luca...
The Linux Kernel.
Linux 3.13.3-r1 2055  252629 Luca...
The Linux Kernel.
Linux 3.12.6-r1 2115  238949 Luca...
The Linux Kernel.
Linux 3.9.4-r2 2310  70048 Luca...
The Linux Kernel.
Linux 3.7.1-r2 2483  67579 Luca...
The Linux Kernel.
Linux 3.5.0-r1 2634  124391 Luca...
The Linux Kernel.
Linux 3.4.4-r1 2634  124348 Luca...
The Linux Kernel.
Linux 3.3.6-r1 2634  124410 Luca...
The Linux Kernel.
Linux 3.2.12-r2 2762  124345 Luca...
The Linux Kernel.
Linux 3.2.7-r1 2792  123550 Mich...
The Linux Kernel.
Linux 3.1.1-r1 2897  122907 Mich...
The Linux Kernel.
Linux 3.0.4-r4 2958  122754 Luca...
The Linux Kernel.
Linux 2.6.36.3-r1 3181  116087 Diog...
The Linux Kernel.
Linux 2.6.32.3-r1 3559  117990 Luca...
The Linux Kernel.
Linux 2.6.32-r1 3600  117751 Luca...
The Linux Kernel.
Linux 2.6.31.6-r3 3605  126499 Luca...
The Linux Kernel.
Linux 2.6.30.5-r1 3684  166102 Jona...
The Linux Kernel.
Linux 2.6.29.1-r1 3827  117500 Luca...
The Linux Kernel.
Linux 2.6.28.7-r1 3883  115518 Giam...
The Linux Kernel.
Linux 2.6.28.1-r1 3883  115487 Giam...
The Linux Kernel.
Linux 2.6.28-r1 3883  116681 Mich...
The Linux Kernel.
Linux 2.6.27.8-r1 3883  134160 Giam...
The Linux Kernel.
Linux 2.6.27.4-r3 3883  149529 Luca...
The Linux Kernel.
Linux 2.6.25.17-r1 3883  172834 Giam...
The Linux Kernel.
view entry at GitHub | download recipe.bz2 file
01-gobohide.patch
02-unionfs-2.4_for_2.6.25.12.patch
03-squashfs-3.3-cvs_20080310.patch
04-squashfs-3.3-cvs_20080310-fix.patch
05-thinkpad-acpi-0.19-20080321_v2.6.25-rc6.patch
06-vm_splice_fix.patch
07-applesmc_int.patch
08-applesmc-retry-when-accessing-keys.patch
09-appletouch-add-macbook3-trackpad.patch
10-appletouch.patch
11-appletouch-new.patch
12-sigmatel_audio_display_all_controls_when_subsystem_id_is_wrong.patch
13-sigmatel_audio_fix_macbook_v2.patch
14-appletouch-2.6.24_rc8.patch
15-applesmc-remove-debugging-messages.patch
16-squashfs-2.6.25_port.patch
17-decrypt_failed_as_debug.patch
Recipe
Resources/BuildInformation
Resources/Dependencies
Resources/Description
cell/01-ps3-backports.patch
cell/02-ps3vram.patch
cell/03-ps3-stable.patch
cell/04-copy4k-cell.patch
cell/05-memcpy-cell.patch
cell/06-usb-fix-hcd-interrupt-disabling.patch
cell/Recipe
cell/dot-config
i686/01-acpi-dsdt-initrd-v0.9a-2.6.25.patch
i686/Recipe
i686/dot-config
ppc/Recipe
ppc/dot-config
x86_64/Recipe
x86_64/dot-config
From de31945e20bc0bd255d0264c5d97a6b24906b30a Mon Sep 17 00:00:00 2001
From: Eric Piel <piel@localhost.(none)>
Date: Wed, 19 Mar 2008 23:00:04 +0100
Subject: [PATCH 1/1] ACPI: initramfs DSDT override support

Permits to load of DSDT (the main ACPI table) from initramfs. In case this
option is selected, the initramfs is parsed at ACPI initialization (very early
boot time) to look for a file DSDT.aml . This aims at allowing users to
override the DSDT without recompiling the kernel. This is done by adding a new
feature to the initramfs parser so that one specific file can be directly
copied into memory.

This is derived from the patch v0.8 from http://gaugusch.at/kernel.shtml but
with kernel inclusion in mind: some clean-up's in the documentation, default
set to No, a kernel parameter to disable it at runtime, and most important, a
different approach for reading the initramfs which avoids using the filesystem
infrastructure.

It also contains a fix for compilation on non-ACPI platforms provided by Rene Rebe.

Signed-off-by: Eric Piel <eric.piel@tremplin-utc.net>
Signed-off-by: Thomas Renninger <trenn@suse.de>
Signed-off-by: Len Brown <len.brown@intel.com>
---
 Documentation/acpi/dsdt-override.txt     |   12 ++++-
 Documentation/acpi/initramfs-add-dsdt.sh |   43 +++++++++++++++++
 Documentation/kernel-parameters.txt      |    3 +
 drivers/acpi/Kconfig                     |   11 ++++
 drivers/acpi/osl.c                       |   24 ++++++++++
 init/initramfs.c                         |   76 ++++++++++++++++++++++++++++++
 6 files changed, 167 insertions(+), 2 deletions(-)
 create mode 100644 Documentation/acpi/initramfs-add-dsdt.sh

diff --git a/Documentation/acpi/dsdt-override.txt b/Documentation/acpi/dsdt-override.txt
index febbb1b..5008f25 100644
--- a/Documentation/acpi/dsdt-override.txt
+++ b/Documentation/acpi/dsdt-override.txt
@@ -1,7 +1,15 @@
-Linux supports a method of overriding the BIOS DSDT:
+Linux supports two methods of overriding the BIOS DSDT:
 
 CONFIG_ACPI_CUSTOM_DSDT builds the image into the kernel.
 
-When to use this method is described in detail on the
+CONFIG_ACPI_CUSTOM_DSDT_INITRD adds the image to the initrd.
+
+When to use these methods is described in detail on the
 Linux/ACPI home page:
 http://www.lesswatts.org/projects/acpi/overridingDSDT.php
+
+Note that if both options are used, the DSDT supplied
+by the INITRD method takes precedence.
+
+Documentation/initramfs-add-dsdt.sh is provided for convenience
+for use with the CONFIG_ACPI_CUSTOM_DSDT_INITRD method.
diff --git a/Documentation/acpi/initramfs-add-dsdt.sh b/Documentation/acpi/initramfs-add-dsdt.sh
new file mode 100644
index 0000000..17ef6e8
--- /dev/null
+++ b/Documentation/acpi/initramfs-add-dsdt.sh
@@ -0,0 +1,43 @@
+#!/bin/bash
+# Adds a DSDT file to the initrd (if it's an initramfs)
+# first argument is the name of archive
+# second argument is the name of the file to add
+# The file will be copied as /DSDT.aml
+
+# 20060126: fix "Premature end of file" with some old cpio (Roland Robic)
+# 20060205: this time it should really work
+
+# check the arguments
+if [ $# -ne 2 ]; then
+	program_name=$(basename $0)
+	echo "\
+$program_name: too few arguments
+Usage: $program_name initrd-name.img DSDT-to-add.aml
+Adds a DSDT file to an initrd (in initramfs format)
+
+  initrd-name.img: filename of the initrd in initramfs format
+  DSDT-to-add.aml: filename of the DSDT file to add
+  " 1>&2
+    exit 1
+fi
+
+# we should check it's an initramfs
+
+tempcpio=$(mktemp -d)
+# cleanup on exit, hangup, interrupt, quit, termination
+trap 'rm -rf $tempcpio' 0 1 2 3 15
+
+# extract the archive
+gunzip -c "$1" > "$tempcpio"/initramfs.cpio || exit 1
+
+# copy the DSDT file at the root of the directory so that we can call it "/DSDT.aml"
+cp -f "$2" "$tempcpio"/DSDT.aml
+
+# add the file
+cd "$tempcpio"
+(echo DSDT.aml | cpio --quiet -H newc -o -A -O "$tempcpio"/initramfs.cpio) || exit \
1
+cd "$OLDPWD"
+
+# re-compress the archive
+gzip -c "$tempcpio"/initramfs.cpio > "$1"
+
diff --git a/Documentation/kernel-parameters.txt b/Documentation/kernel-parameters.txt
index 622f784..49318b9 100644
--- a/Documentation/kernel-parameters.txt
+++ b/Documentation/kernel-parameters.txt
@@ -177,6 +177,9 @@ and is between 256 and 4096 characters. It is defined in the \
file
 
 	acpi_no_auto_ssdt	[HW,ACPI] Disable automatic loading of SSDT
 
+	acpi_no_initrd_override	[KNL,ACPI]
+			Disable loading custom ACPI tables from the initramfs
+
 	acpi_os_name=	[HW,ACPI] Tell ACPI BIOS the name of the OS
 			Format: To spoof as Windows 98: ="Microsoft Windows"
 
diff --git a/drivers/acpi/Kconfig b/drivers/acpi/Kconfig
index b4f5e85..fbcaa06 100644
--- a/drivers/acpi/Kconfig
+++ b/drivers/acpi/Kconfig
@@ -300,6 +300,17 @@ config ACPI_CUSTOM_DSDT
 	bool
 	default ACPI_CUSTOM_DSDT_FILE != ""
 
+config ACPI_CUSTOM_DSDT_INITRD
+	bool "Read Custom DSDT from initramfs"
+	depends on BLK_DEV_INITRD
+	default n
+	help
+	  This option supports a custom DSDT by optionally loading it from initrd.
+	  See Documentation/acpi/dsdt-override.txt
+
+	  If you are not using this feature now, but may use it later,
+	  it is safe to say Y here.
+
 config ACPI_BLACKLIST_YEAR
 	int "Disable ACPI for systems before Jan 1st this year" if X86_32
 	default 0
diff --git a/drivers/acpi/osl.c b/drivers/acpi/osl.c
index a697fb6..8fa630f 100644
--- a/drivers/acpi/osl.c
+++ b/drivers/acpi/osl.c
@@ -91,6 +91,11 @@ static DEFINE_SPINLOCK(acpi_res_lock);
 #define	OSI_STRING_LENGTH_MAX 64	/* arbitrary */
 static char osi_additional_string[OSI_STRING_LENGTH_MAX];
 
+#ifdef CONFIG_ACPI_CUSTOM_DSDT_INITRD
+static int acpi_no_initrd_override;
+extern struct acpi_table_header *acpi_find_dsdt_initrd(void);
+#endif
+
 /*
  * "Ode to _OSI(Linux)"
  *
@@ -333,6 +338,16 @@ acpi_os_table_override(struct acpi_table_header * existing_table,
 	if (strncmp(existing_table->signature, "DSDT", 4) == 0)
 		*new_table = (struct acpi_table_header *)AmlCode;
 #endif
+#ifdef CONFIG_ACPI_CUSTOM_DSDT_INITRD
+	if ((strncmp(existing_table->signature, "DSDT", 4) == 0) &&
+	    !acpi_no_initrd_override) {
+		struct acpi_table_header *initrd_table;
+
+		initrd_table = acpi_find_dsdt_initrd();
+		if (initrd_table)
+			*new_table = initrd_table;
+	}
+#endif
 	if (*new_table != NULL) {
 		printk(KERN_WARNING PREFIX "Override [%4.4s-%8.8s], "
 			   "this is unsafe: tainting kernel\n",
@@ -343,6 +358,15 @@ acpi_os_table_override(struct acpi_table_header * existing_table,
 	return AE_OK;
 }
 
+#ifdef CONFIG_ACPI_CUSTOM_DSDT_INITRD
+static int __init acpi_no_initrd_override_setup(char *s)
+{
+	acpi_no_initrd_override = 1;
+	return 1;
+}
+__setup("acpi_no_initrd_override", acpi_no_initrd_override_setup);
+#endif
+
 static irqreturn_t acpi_irq(int irq, void *dev_id)
 {
 	u32 handled;
diff --git a/init/initramfs.c b/init/initramfs.c
index d53fee8..495380c 100644
--- a/init/initramfs.c
+++ b/init/initramfs.c
@@ -6,6 +6,9 @@
 #include <linux/delay.h>
 #include <linux/string.h>
 #include <linux/syscalls.h>
+#ifdef CONFIG_ACPI_CUSTOM_DSDT_INITRD
+#include <acpi/acpi.h>
+#endif
 
 static __initdata char *message;
 static void __init error(char *x)
@@ -90,6 +91,12 @@ static __initdata unsigned long body_len, name_len;
 static __initdata uid_t uid;
 static __initdata gid_t gid;
 static __initdata unsigned rdev;
+#ifdef CONFIG_ACPI_CUSTOM_DSDT_INITRD
+static __initdata char *file_looked_for;
+static __initdata struct acpi_table_header *file_mem;
+#else
+const char *file_looked_for = NULL;
+#endif
 
 static void __init parse_header(char *s)
 {
@@ -123,6 +130,7 @@ static __initdata enum state {
 	SkipIt,
 	GotName,
 	CopyFile,
+	CopyFileMem,
 	GotSymlink,
 	Reset
 } state, next_state;
@@ -267,6 +275,9 @@ static int __init do_name(void)
 		free_hash();
 		return 0;
 	}
+	if (file_looked_for && S_ISREG(mode) &&
+		(strcmp(collected, file_looked_for) == 0))
+		state = CopyFileMem;
 	if (dry_run)
 		return 0;
 	clean_path(collected, mode);
@@ -299,6 +310,40 @@ static int __init do_name(void)
 	return 0;
 }
 
+#ifdef CONFIG_ACPI_CUSTOM_DSDT_INITRD
+static int __init do_copy_mem(void)
+{
+	static void *file_current; /* current position in the memory */
+	if (file_mem == NULL) {
+		if (body_len < 4) { /* check especially against empty files */
+			error("file is less than 4 bytes");
+			return 1;
+		}
+		file_mem = kmalloc(body_len, GFP_ATOMIC);
+		if (!file_mem) {
+			error("failed to allocate enough memory");
+			return 1;
+		}
+		file_current = file_mem;
+	}
+	if (count >= body_len) {
+		memcpy(file_current, victim, body_len);
+		eat(body_len);
+		file_looked_for = NULL; /* don't find files with same name */
+		state = SkipIt;
+		return 0;
+	} else {
+		memcpy(file_current, victim, count);
+		file_current += count;
+		body_len -= count;
+		eat(count);
+		return 1;
+	}
+}
+#else
+#define do_copy_mem NULL
+#endif
+
 static int __init do_copy(void)
 {
 	if (count >= body_len) {
@@ -333,6 +378,7 @@ static __initdata int (*actions[])(void) = {
 	[SkipIt]	= do_skip,
 	[GotName]	= do_name,
 	[CopyFile]	= do_copy,
+	[CopyFileMem]	= do_copy_mem,
 	[GotSymlink]	= do_symlink,
 	[Reset]		= do_reset,
 };
@@ -578,3 +624,31 @@ static int __init populate_rootfs(void)
 	return 0;
 }
 rootfs_initcall(populate_rootfs);
+
+#ifdef CONFIG_ACPI_CUSTOM_DSDT_INITRD
+struct acpi_table_header *acpi_find_dsdt_initrd(void)
+{
+	char *err, *ramfs_dsdt_name = "DSDT.aml";
+
+	printk(KERN_INFO "ACPI: Checking initramfs for custom DSDT\n");
+	file_mem = NULL;
+	file_looked_for = ramfs_dsdt_name;
+	err = unpack_to_rootfs((char *)initrd_start,
+			initrd_end - initrd_start, 1);
+	file_looked_for = NULL;
+
+	if (err) {
+		/*
+		 * Even if reading the DSDT file was successful,
+		 * we give up if the initramfs cannot be entirely read.
+		 */
+		kfree(file_mem);
+		printk(KERN_ERR "ACPI: Aborded because %s.\n", err);
+		return NULL;
+	}
+	if (file_mem)
+		printk(KERN_INFO "ACPI: Found DSDT in %s.\n", ramfs_dsdt_name);
+
+	return file_mem;
+}
+#endif
-- 
1.5.4.3

Linux 2.6.25.16-r1 3883  166500 Giam...
The Linux Kernel.
Linux 2.6.25.10-r2 3883  165320 Giam...
The Linux Kernel.
Linux 2.6.25.7-r1 3883  157294 Giam...
The Linux Kernel.
Linux 2.6.25.4-r1 3883  133017 Hopp...
The Linux Kernel.
Linux 2.6.25-r1 3883  133216 Luca...
The Linux Kernel.
Linux 2.6.24.4-r5 3883  150733
The Linux Kernel.
Linux 2.6.24.3-r5 3883  150221 Luca...
The Linux Kernel.
Linux 2.6.24.2-r3 3883  146488 Giam...
The Linux Kernel.
Linux 2.6.24.1-r1 3883  146454 Giam...
The Linux Kernel.
Linux 2.6.24-r1 3883  146428 Luca...
The Linux Kernel.
Linux 2.6.23.8-r4 3883  155842 Luca...
The Linux Kernel.
Linux 2.6.22.7-r4 3883  114727 Luca...
The Linux Kernel.
Linux 2.6.22.1-r1 3883  121391 Luca...
The Linux Kernel.
Linux 2.6.21.1-r3 3883  118854 Luca...
The Linux Kernel.
Linux 2.6.20.7-r1 3883  117945 Luca...
The Linux Kernel.
Linux 2.6.20.4-r3 3883  151150 Luca...
The Linux Kernel.
Linux 2.6.20-r1 3883  106429 Luca...
The Linux Kernel.
Linux 2.6.18.3-r2 3883  111124 Luca...
The Linux Kernel.
Linux 2.6.17.11-r1 3883  164053 Luca...
The Linux Kernel.
Linux 2.6.17.3-r1 3883  165067 Luca...
The Linux Kernel.
Linux 2.6.16.20-r1 3883  133625 Luca...
The Linux Kernel.
Linux 2.6.16.14-r1 3883  168270 Luca...
The Linux Kernel.
Linux 2.6.15.5-r1 3883  224686 Jona...
The Linux Kernel.
Linux 2.6.15.2-r1 3883  177165 Carl...
The Linux Kernel.
Linux 2.6.15.1-r1 3883  149219 Jona...
The Linux Kernel.
Linux 2.6.15-r1 3883  149214 Luca...
The Linux Kernel.
Linux 2.6.14.4-r1 3883  150166 Jona...
The Linux Kernel.
Linux 2.6.14.3-r1 3883  150060 Jona...
The Linux Kernel.
Linux 2.6.14.2-r1 3883  149791 Carl...
The Linux Kernel.
Linux 2.6.13.4-r1 3883  149559 Luca...
The Linux Kernel.
Linux 2.6.13.2-r1 3883  56611 Jona...
The Linux Kernel.
Linux 2.6.13.1-r1 3883  56378 Luca...
The Linux Kernel.
Linux 2.6.12.2-r1 3883  50355 Luca...
The Linux Kernel.
Linux 2.6.11.9-r1 3883  98969 Luca...
The Linux Kernel.
Linux 2.6.11.8-r1 3883  109424 Jona...
The Linux Kernel.
Linux 2.6.11-r1 3883  99032 Luca...
The Linux Kernel.
Linux 2.6.10-r1 3883  65969 Luca...
The Linux Kernel.
Linux 2.6.9-r1 3883  278461 Luca...
The Linux Kernel.
Linux 2.6.8.1-r1 3883  35576 Luca...
The Linux Kernel.
Linux 2.6.7-r1 3883  22610 Luca...
The Linux Kernel.
Linux 2.6.6-r1 3883  21958 Luca...
The Linux Kernel.
Linux 2.4.26-r1 3883  22359 Luca...
The Linux Kernel.