From mboxrd@z Thu Jan 1 00:00:00 1970 From: Marco Subject: [PATCH 12/14] Pramfs: test module Date: Sat, 13 Jun 2009 15:22:51 +0200 Message-ID: <4A33A82B.9070306@gmail.com> Mime-Version: 1.0 Content-Type: text/plain; charset=ISO-8859-15 Content-Transfer-Encoding: 7bit Cc: Linux Embedded , Linux Kernel , Daniel Walker To: Linux FS Devel Return-path: Received: from mail-fx0-f216.google.com ([209.85.220.216]:37936 "EHLO mail-fx0-f216.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S932072AbZFMN0n (ORCPT ); Sat, 13 Jun 2009 09:26:43 -0400 Sender: linux-fsdevel-owner@vger.kernel.org List-ID: From: Marco Stornelli Test module. Signed-off-by: Marco Stornelli --- 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 + * 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 +#include +#include +#include +#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);