Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752130AbbKKIYc (ORCPT ); Wed, 11 Nov 2015 03:24:32 -0500 Received: from mail-pa0-f53.google.com ([209.85.220.53]:34602 "EHLO mail-pa0-f53.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751082AbbKKIYb (ORCPT ); Wed, 11 Nov 2015 03:24:31 -0500 From: Saurabh Sengar To: computersforpeace@gmail.com, joe@perches.com Cc: andy.shevchenko@gmail.com, joern@lazybastard.org, dwmw2@infradead.org, linux-mtd@lists.infradead.org, linux-kernel@vger.kernel.org Subject: [PATCH] mtd: phram: error handling Date: Wed, 11 Nov 2015 13:53:58 +0530 Message-Id: <1447230238-3693-1-git-send-email-saurabh.truth@gmail.com> X-Mailer: git-send-email 1.9.1 In-Reply-To: <20151110194157.GS12143@google.com> References: <20151110194157.GS12143@google.com> Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 4359 Lines: 88 Brian Norris wrote: > Well, today you're in luck! You're touching a driver that requires no > special hardware, so you should be able to test it. > I think you can try using the mem= kernel parameter (see > Documentation/kernel-parameters.txt) to restrict your system memory, and > then try using that unreachable portions of memory for phram. You can > try this driver as either a module or built-in. For the former, you can > specify the parameters during modprobe time, or later by writing to > /sys/module/phram/parameters/phram. For the latter, you can specify on > the kernel command line or in /sys/module/phram/parameters/phram. > Let me know if you have any more questions about testing your patch. Hi Brian, As you have suggested I have restricted my laptop's memory to 1GB and tried to access unreachable portion of memory(2GB). It seems to be successfully registered(this is OK right ?). I have also tested below error scenarios; all exiting gracefully - parameter too long - too many arguments - not enough arguments - invalid start adddress - invalid device length This is my first interaction with phram device so I request you to verify my testing. Below are the commands and output I did for this testing. ----------------------------------------------------- saurabh@saurabh:~/little/Task02/linux$ cat /proc/meminfo | grep Mem MemTotal: 1016588 kB MemFree: 126016 kB MemAvailable: 295508 kB saurabh@saurabh:~/little/Task02/linux$ cat /proc/cmdline BOOT_IMAGE=/boot/vmlinuz-4.3.0-10333-gdfe4330-dirty mem=1024M root=UUID=2b66d4b2-ac21-4554-bf3b-64bc973e1dad ro quiet splash vt.handoff=7 saurabh@saurabh:~/little/Task02/linux$ sudo insmod drivers/mtd/devices/phram.ko phram=ram,2048Mi,1ki saurabh@saurabh:~/little/Task02/linux$ sudo dmesg -c [ 634.748495] phram: ram device: 0x400 at 0x80000000 saurabh@saurabh:~/little/Task02/linux$ sudo insmod drivers/mtd/devices/phram.ko phram=abcdefghijklmnopqrstuvwxyzabcdefghijklmnopqrstuvwxyzabcdefghijklmnopqrstuvwxyzabcdefghijklmnopqrstuvwxyz,256Mi,1Mi insmod: ERROR: could not insert module drivers/mtd/devices/phram.ko: Invalid parameters saurabh@saurabh:~/little/Task02/linux$ sudo dmesg -c [ 1469.763787] phram: parameter too long [ 1469.763797] phram: `abcdefghijklmnopqrstuvwxyzabcdefghijklmnopqrstuvwxyzabcdefghijklmnopqrstuvwxyzabcdefghijklmnopqrstuvwxyz,256Mi,1Mi' invalid for parameter `phram' saurabh@saurabh:~/little/Task02/linux$ sudo insmod drivers/mtd/devices/phram.ko phram=swap,256Mi,1Mi,extra_parameter insmod: ERROR: could not insert module drivers/mtd/devices/phram.ko: Invalid parameters saurabh@saurabh:~/little/Task02/linux$ sudo dmesg -c [ 1650.081694] phram: too many arguments [ 1650.081703] phram: `swap,256Mi,1Mi,extra_parameter' invalid for parameter `phram' saurabh@saurabh:~/little/Task02/linux$ sudo insmod drivers/mtd/devices/phram.ko phram=swap,256Mi insmod: ERROR: could not insert module drivers/mtd/devices/phram.ko: Invalid parameters saurabh@saurabh:~/little/Task02/linux$ sudo dmesg -c [ 1707.437130] phram: not enough arguments [ 1707.437138] phram: `swap,256Mi' invalid for parameter `phram' saurabh@saurabh:~/little/Task02/linux$ sudo insmod drivers/mtd/devices/phram.ko phram=swap,256xyz,1Mi insmod: ERROR: could not insert module drivers/mtd/devices/phram.ko: Invalid parameters saurabh@saurabh:~/little/Task02/linux$ sudo dmesg -c [ 1783.014351] phram: invalid start address [ 1783.014359] phram: `swap,256xyz,1Mi' invalid for parameter `phram' saurabh@saurabh:~/little/Task02/linux$ sudo insmod drivers/mtd/devices/phram.ko phram=swap,256Mi,1xyz insmod: ERROR: could not insert module drivers/mtd/devices/phram.ko: Invalid parameters saurabh@saurabh:~/little/Task02/linux$ sudo dmesg -c [ 1831.746108] phram: invalid device length [ 1831.746117] phram: `swap,256Mi,1xyz' invalid for parameter `phram' ------------------------------------------- -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/