Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit e22af66f authored by Uwe Kleine-König's avatar Uwe Kleine-König
Browse files

Merge branch 'atags' into for-rmk

parents a4831fbe f7b0b939
Loading
Loading
Loading
Loading
+40 −43
Original line number Diff line number Diff line
#include <linux/slab.h>
#include <linux/kexec.h>
#include <linux/proc_fs.h>
#include <asm/setup.h>
#include <asm/types.h>
@@ -7,9 +6,8 @@

struct buffer {
	size_t size;
	char *data;
	char data[];
};
static struct buffer tags_buffer;

static int
read_buffer(char* page, char** start, off_t off, int count,
@@ -29,58 +27,57 @@ read_buffer(char* page, char** start, off_t off, int count,
	return count;
}

#define BOOT_PARAMS_SIZE 1536
static char __initdata atags_copy[BOOT_PARAMS_SIZE];

static int
create_proc_entries(void)
void __init save_atags(const struct tag *tags)
{
	struct proc_dir_entry* tags_entry;
	memcpy(atags_copy, tags, sizeof(atags_copy));
}

	tags_entry = create_proc_read_entry("atags", 0400, NULL, read_buffer, &tags_buffer);
	if (!tags_entry)
		return -ENOMEM;
static int __init init_atags_procfs(void)
{
	/*
	 * This cannot go into save_atags() because kmalloc and proc don't work
	 * yet when it is called.
	 */
	struct proc_dir_entry *tags_entry;
	struct tag *tag = (struct tag *)atags_copy;
	struct buffer *b;
	size_t size;

	return 0;
	if (tag->hdr.tag != ATAG_CORE) {
		printk(KERN_INFO "No ATAGs?");
		return -EINVAL;
	}

	for (; tag->hdr.size; tag = tag_next(tag))
		;

static char __initdata atags_copy_buf[KEXEC_BOOT_PARAMS_SIZE];
static char __initdata *atags_copy;
	/* include the terminating ATAG_NONE */
	size = (char *)tag - atags_copy + sizeof(struct tag_header);

void __init save_atags(const struct tag *tags)
{
	atags_copy = atags_copy_buf;
	memcpy(atags_copy, tags, KEXEC_BOOT_PARAMS_SIZE);
}
	WARN_ON(tag->hdr.tag != ATAG_NONE);

	b = kmalloc(sizeof(*b) + size, GFP_KERNEL);
	if (!b)
		goto nomem;

static int __init init_atags_procfs(void)
{
	struct tag *tag;
	int error;
	b->size = size;
	memcpy(b->data, atags_copy, size);

	if (!atags_copy) {
		printk(KERN_WARNING "Exporting ATAGs: No saved tags found\n");
		return -EIO;
	}
	tags_entry = create_proc_read_entry("atags", 0400,
			NULL, read_buffer, b);

	for (tag = (struct tag *) atags_copy; tag->hdr.size; tag = tag_next(tag))
		;
	if (!tags_entry)
		goto nomem;

	tags_buffer.size = ((char *) tag - atags_copy) + sizeof(tag->hdr);
	tags_buffer.data = kmalloc(tags_buffer.size, GFP_KERNEL);
	if (tags_buffer.data == NULL)
		return -ENOMEM;
	memcpy(tags_buffer.data, atags_copy, tags_buffer.size);
	return 0;

	error = create_proc_entries();
	if (error) {
nomem:
	kfree(b);
	printk(KERN_ERR "Exporting ATAGs: not enough memory\n");
		kfree(tags_buffer.data);
		tags_buffer.size = 0;
		tags_buffer.data = NULL;
	}

	return error;
	return -ENOMEM;
}

arch_initcall(init_atags_procfs);
+0 −2
Original line number Diff line number Diff line
@@ -14,8 +14,6 @@

#define KEXEC_ARCH KEXEC_ARCH_ARM

#define KEXEC_BOOT_PARAMS_SIZE 1536

#define KEXEC_ARM_ATAGS_OFFSET  0x1000
#define KEXEC_ARM_ZIMAGE_OFFSET 0x8000