[PATCH 12/14] Pramfs: test module

From: Marco
Date: Sat Jun 13 2009 - 09:28:34 EST


From: Marco Stornelli <marco.stornelli@xxxxxxxxx>

Test module.

Signed-off-by: Marco Stornelli <marco.stornelli@xxxxxxxxx>
---
diff -uprN linux-2.6.30-orig/fs/pramfs/pramfs_test.c linux-2.6.30/fs/pramfs/pramfs_test.c
--- linux-2.6.30-orig/fs/pramfs/pramfs_test.c 1970-01-01 01:00:00.000000000 +0100
+++ linux-2.6.30/fs/pramfs/pramfs_test.c 2009-06-13 13:07:38.000000000 +0200
@@ -0,0 +1,50 @@
+/*
+ * FILE NAME fs/pramfs/namei.c
+ *
+ * BRIEF DESCRIPTION
+ *
+ * Inode operations for directories.
+ *
+ * Copyright 2009 Marco Stornelli <marco.stornelli@xxxxxxxxx>
+ * Copyright 2003 Sony Corporation
+ * Copyright 2003 Matsushita Electric Industrial Co., Ltd.
+ * 2003-2004 (c) MontaVista Software, Inc. , Steve Longerbeam
+ * This file is licensed under the terms of the GNU General Public
+ * License version 2. This program is licensed "as is" without any
+ * warranty of any kind, whether express or implied.
+ */
+#include <linux/module.h>
+#include <linux/version.h>
+#include <linux/init.h>
+#include <linux/fs.h>
+#include "pram_fs.h"
+
+int __init test_pramfs_write(void)
+{
+ struct pram_super_block *psb;
+ char *ptr;
+
+ psb = get_pram_super();
+ if (!psb) {
+ printk(KERN_ERR
+ "%s: PRAMFS super block not found (not mounted?)\n",
+ __func__);
+ return 1;
+ }
+
+ /*
+ * Attempt an unprotected clear of all information in the superblock,
+ * this should cause a kernel page protection fault.
+ */
+ printk("%s: writing to kernel VA %p\n", __func__, psb);
+ memset(psb, 0 , PRAM_SB_SIZE);
+
+ return 0;
+}
+
+void test_pramfs_write_cleanup(void) {}
+
+/* Module information */
+MODULE_LICENSE("GPL");
+module_init(test_pramfs_write);
+module_exit(test_pramfs_write_cleanup);

--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/