01-05-2016, 03:04 PM | #1 | |
Junior Member
Posts: 4
Karma: 546
Join Date: Jan 2016
Location: France
Device: Kobo Aura H2O
|
Boot from external SD
Dear all,
I am new to the forum and a bit late on the topic! I would like to know the method for allowing boot from the external SD on the H2O. Apparently it is possible to do so : Quote:
Some context: Ideally I would like to run Android and/or Debian from the external SD (dual boot?), I believe some have managed to do just that on other Kobo devices but I haven't found someone reporting success and specific method for the H2O. Thanks in advance for reading this. Best whishes, Bastien |
|
01-19-2016, 08:48 AM | #2 |
Junior Member
Posts: 1
Karma: 549
Join Date: Jan 2016
Location: France
Device: Kobo Aura
|
U-boot setting for external SD?
Salut Bastien.
I'm facing the same issue with my Aura. I tried to build a mmcblk1 bootable SD by copying the internal one (dd if=mmcblk0...) with its 3 partitions. But it did not boot. I digged a little bit in the u-boot from firmware. Looks like the U-boot parameters are set to internal SD (mmcblk0) first. baudrate=115200 loadaddr=0x70800000 uboot=u-boot.bin kernel=uImage bootcmd_mmc=run bootargs_base bootargs_mmc;load_ntxkernel;bootm bootcmd_SD=run bootargs_base bootargs_SD;load_ntxkernel;bootm bootcmd_recovery=run bootargs_base bootargs_recovery;load_ntxkernel;bootm verify=no bootcmd=run bootcmd_mmc bootargs_recovery=setenv bootargs ${bootargs} root=/dev/mmcblk0p2 rootfstype=ext4 bootargs_mmc=setenv bootargs ${bootargs} root=/dev/mmcblk0p1 rootfstype=ext4 bootargs_SD=setenv bootargs ${bootargs} root=/dev/mmcblk1p1 rootfstype=ext4 bootargs_base=setenv bootargs console=ttymxc0,115200 rootwait rw quiet lpj=3997696 stdin=serial stdout=serial stderr=serial bootdelay=0 I guess we have to set bootcmd=bootcmd_SD. But I don't know how to do that since I have no console and delay for interrupting u-boot and get the CLI is zero (bootdelay=0). I don't know either how the order of precedence is managed by u-boot. Could some expert help? Thanks in advance. |
01-24-2016, 06:18 AM | #3 |
Guru
Posts: 897
Karma: 149877
Join Date: Jul 2013
Location: Netherlands
Device: Cracked HiSenseA5ProCC, Cracked OnyxNotePro, Note5, Kobo Glo, Aura
|
Nice thread! I am thinking of installing Arch Arm on it using archroot. So I will need the same u-boot hack, when I get around to it.
Searching the forum is nearly impossible it seems at times, especially when you don't have the correct search terms. Use the thread tips and tricks for your initial searches. I think the uboot hack is part of the threads on turning your kobo into a debian tablet. Here is the u-boot wiki. If you want shell access to your kobo device: enable telnet (tips&tricks), enable wifi, telnet to the IP of your Kobo. (On windows use putty). If you want more access, I would install KoboLauncher which comes with USBnet. You can than telnet and ftp to your USB gadget. (To get it working: again T&T). After you have made a backup of your SDcard to your PC with dd, you should also be able to dd a custom block to the SDcard. So you extract the current uboot image. Hack it and copy it. The hack is done by changing hexadecimal codes. So obviously, this could be a trial and error procedure. If it goes wrong, you will have to open up the Kobo to restore the original Uboot image. So no, do not expect to do this, if you never want to open your case. I've opened the Glo, Aura, HD and since day before yesterday the H2O. It always scares the crap out of me, but I still haven't broken anything. Fingers crossed. Please be advised to use a plastic tool that breaks before the reader case gets damaged. (I rather like the ones on the right.) The Aura H2Ois actually one of the least damaged readers, because it only has adhesives keeping the top and case together. There are two glue rings. One on the back case at the outer edge. One on the inner edge on the screen. It will take you some repetitions before you can get the glue to separate. Last edited by Markismus; 01-24-2016 at 06:32 AM. |
01-28-2016, 11:30 AM | #4 | |||
Junior Member
Posts: 4
Karma: 546
Join Date: Jan 2016
Location: France
Device: Kobo Aura H2O
|
Thank you Paraglider & Markismus for your pointers and kind advices.
I intalled KSM and koreader in the mean time and it does the thrick nicely enough for pdfs at the moment (it was one of the reason I was curious about dual-boot in the first place). I still have to get the dictionnaries to work properly but it is mostly about about finding the proper eng/fre resource and convert it to the appropriate format I also have to see what can be done with columned articles but for what I've learned here so far, it is more about converting the pdfs on a PC so I should be fine as well I am still curious about dual-booting so some reactions/questions below if you don't mind: @Paraglider Quote:
bootcmd= run bootcmd_SD. Probably something you don't want to overlook when fumbling with hex. @Markismus Quote:
someone to actually solve their problem but I like to do my own homework and pointers for some correct search terms are greatly appreciated. Thanks a lot for doing just that Quote:
something goes wrong (which I also understand is quite likely - there is "error" in "trial and error" after all). If yes does that mean that once the backup is modified/hacked it can be written to the kobo over telnet? I am not a 100% reluctant to opening the case but I would be happy if there is a reasonable chance to preserve the waterproofness of the device (maybe someday I'll own a bathtub!). Well I guess there is no harm in me playing with the SD card backup until I want to make an actual attempt. I'll dig into this. Just in case: is there a cheaper or older device known to behave similarly to the H2O? Best regards, Bastien |
|||
01-28-2016, 04:17 PM | #5 | ||
Guru
Posts: 897
Karma: 149877
Join Date: Jul 2013
Location: Netherlands
Device: Cracked HiSenseA5ProCC, Cracked OnyxNotePro, Note5, Kobo Glo, Aura
|
Quote:
Quote:
The extra advantage is that a _lot_ of work has already been done on the Touch and Glo for dual-booting and debian on kobo. Only some work has been done on the Aua HD (IIRC). In a week I will get my mail-ordered 2-sided tape for mobile screens. Currently my H2O has no screws fixing the screen and PCB to the bottom case, nor have I used new glue or tape to fix the top to the screen and the bottom case. I have a small gap between the cases, no gap between the bezel and the screen. Still, it works beautifully for reading. If I am able to reassemble my Aura H2O with no gaps between top and bottom case, I'll post a Howto. For now there are only some posts on how to disassemble the H2O |
||
11-22-2016, 05:59 PM | #6 |
Junior Member
Posts: 5
Karma: 22094
Join Date: Nov 2014
Device: kindle PaperWhite, kobo Aura H2O
|
This thread is somewhat old, but I think it is worth to resurrect it:
It seems the kernel is loaded from a fixed location and one can change the location of the root file system only. While it appears possible to generate and write a valid binary of a customized u-boot environment this would not allow for a simple dual-boot configuration. However, looking into the u-boot code published by kobo there is an upgrade from SD card functionality built-in. It is triggered by keeping the power button pressed at power-on and expects a flag being set in the hardware configuration area on the SD card. Today I managed to boot from the SD card following these steps (simplified):
I will post more details (if there still is interest), but right now I am curious if I can adopt Marek's or Guang's Debian system. Best regards Stefan |
11-22-2016, 06:04 PM | #7 |
Resident Curmudgeon
Posts: 73,970
Karma: 128903378
Join Date: Nov 2006
Location: Roslindale, Massachusetts
Device: Kobo Libra 2, Kobo Aura H2O, PRS-650, PRS-T1, nook STR, PW3
|
How would one setup a bootable microSD card under Windows?
|
11-23-2016, 08:33 AM | #8 |
Linux User
Posts: 2,279
Karma: 6123806
Join Date: Sep 2010
Location: Heidelberg, Germany
Device: none
|
|
11-23-2016, 05:23 PM | #9 |
Junior Member
Posts: 5
Karma: 22094
Join Date: Nov 2014
Device: kindle PaperWhite, kobo Aura H2O
|
HowTo: Aura H2O boot from external SD
@JSWolf: I can't tell you which tools you need to do this on Windows, but here comes a (hopefully complete) howto for Linux.
Disclaimer While the procedure below does not make any modifications to the contents of the internal storage of the Kobo Aura H2O many of the commands below require root privileges on your computer. It is assumed you are aware of the risks when writing to devices and filesystems with root privileges. I do not take any responsibility for damage or loss of data by doing so. Prerequisites
Make backup copy of internal SD
Contents of the image From the image above we may extract the single partitions. But we will not need to do so. Let's have a look at the partition table: Code:
gzip -dc mmcblk0.img.gz | dd bs=512 count=1 of=mmcblk0.bs fdisk -l mmcblk0.bs Code:
Disk mmcblk0.bs: 512 B, 512 bytes, 1 sectors Units: sectors of 1 * 512 = 512 bytes Sector size (logical/physical): 512 bytes / 512 bytes I/O size (minimum/optimal): 512 bytes / 512 bytes Disklabel type: dos Disk identifier: 0x00000000 Device Boot Start End Sectors Size Id Type mmcblk0.bs1 49152 573440 524289 256M 83 Linux mmcblk0.bs2 573441 1097729 524289 256M 83 Linux mmcblk0.bs3 1097730 7744511 6646782 3.2G b W95 FAT32 Write the image to an SD card The size of the SD card must be 4 GiB or larger. Write the image onto the SD card: Code:
gzip -dc mmcblk0.img.gz | dd of=/dev/sdX Check the new partitioning of your SD card: Code:
fdisk -l /dev/sdX Code:
Disk /dev/sdg: 14.9 GiB, 15931539456 bytes, 31116288 sectors Units: sectors of 1 * 512 = 512 bytes Sector size (logical/physical): 512 bytes / 512 bytes I/O size (minimum/optimal): 512 bytes / 512 bytes Disklabel type: dos Disk identifier: 0x00000000 Device Boot Start End Sectors Size Id Type /dev/sdg1 49152 573440 524289 256M 83 Linux /dev/sdg2 573441 1097729 524289 256M 83 Linux /dev/sdg3 1097730 7744511 6646782 3.2G b W95 FAT32 Code:
dosfsck /dev/sdX3 Modify hardware configuration data Extract the hardware configuration data: Code:
gzip -dc mmcblk0.img.gz | dd bs=512 skip=1024 count=1 of=mmcblk0.hwconfig Write the modified hardware configuration back to the SD card: Code:
dd if=mmcblk0.hwconfig bs=512 seek=1024 of=/dev/sdX Adjust the system to work from the external SD card The image contains commands mounting partitions from the internal SD card mmcblk0. In order to obtain a truly independent system a few changes are necessary. Mount the root filesystem of the SD card: Code:
mount /dev/sdX1 /mnt Code:
mknod /mnt/dev/mmcblk1 b 179 8 mknod /mnt/dev/mmcblk1p1 b 179 9 mknod /mnt/dev/mmcblk1p2 b 179 10 mknod /mnt/dev/mmcblk1p3 b 179 11 rm /mnt/etc/udev.tgz Edit /mnt/etc/init.d/rcS and replace references to mmcblk0p1 and mmcblk0p3 with mmcblk1p1 and mmcblk1p3 respectively. This is the corresponding diff: Code:
--- a/rcS 2015-08-03 10:53:08.000000000 +0200 +++ b/rcS 2016-11-23 19:43:30.000000000 +0100 @@ -12,7 +12,7 @@ [ $PRODUCT != trilogy ] && PREFIX=$PRODUCT- -mount -o remount,noatime,nodiratime /dev/mmcblk0p1 / +mount -o remount,noatime,nodiratime /dev/mmcblk1p1 / PLATFORM=freescale if [ `dd if=/dev/mmcblk0 bs=512 skip=1024 count=1 | grep -c "HW CONFIG"` == 1 ]; then @@ -79,7 +79,7 @@ if [ $(strings /usr/local/Kobo/pickel | grep -c wait-for-hit) -ge 1 ]; then FS_CORRUPT=0 - dosfsck -a -w /dev/mmcblk0p3 || dosfsck -a -w /dev/mmcblk0p3 || dosfsck -a -w /dev/mmcblk0p3 || dosfsck -a -w /dev/mmcblk0p3 || FS_CORRUPT=1 + dosfsck -a -w /dev/mmcblk1p3 || dosfsck -a -w /dev/mmcblk1p3 || dosfsck -a -w /dev/mmcblk1p3 || dosfsck -a -w /dev/mmcblk1p3 || FS_CORRUPT=1 if [ $FS_CORRUPT == 1 ]; then case $PRODUCT in kraken|phoenix) @@ -99,9 +99,9 @@ reboot fi else - dosfsck -a -w /dev/mmcblk0p3 + dosfsck -a -w /dev/mmcblk1p3 fi -mount -t vfat -o noatime,nodiratime,shortname=mixed,utf8 /dev/mmcblk0p3 /mnt/onboard +mount -t vfat -o noatime,nodiratime,shortname=mixed,utf8 /dev/mmcblk1p3 /mnt/onboard rm -rf /mnt/onboard/fsck* rm -rf /mnt/onboard/FSCK* rm -rf /usr/local/Kobo/db.tgz Code:
--- a/on-animator.sh 2012-09-07 22:45:42.000000000 +0200 +++ b/on-animator.sh 2016-11-23 18:50:34.000000000 +0100 @@ -6,6 +6,7 @@ i=0; while true; do i=$((((i + 1)) % 11)); - zcat /etc/images/$PREFIX\on-$i.raw.gz | /usr/local/Kobo/pickel showpic 1; + j=$((10 - i)) + zcat /etc/images/$PREFIX\on-$j.raw.gz | /usr/local/Kobo/pickel showpic 1; usleep 250000; done Code:
umount /mnt Start the system from the SD card
The warning message of ntx_hwconfig is not specific to the external SD card. On my system I get the same warning for the internal hardware configuration data on mmcblk0. Outlook It is not the most comfortable but probably the least invasive method to implement a kind of dual booting. The u-boot boot loader is still run from the internal SD card and also gets its boot environment from there. I do not know yet from where the kernel is loaded in this setup. Nevertheless I expect this method to provide a way to boot some other Linux system from the external SD card, albeit using kobo's kernel. I hope this triggers some happy hacking and am curious about any results... Best regards Stefan |
11-23-2016, 05:43 PM | #10 | |
Linux User
Posts: 2,279
Karma: 6123806
Join Date: Sep 2010
Location: Heidelberg, Germany
Device: none
|
Thanks for the very detailed description.
Quote:
|
|
11-24-2016, 01:13 PM | #11 |
Wizard
Posts: 3,489
Karma: 2914715
Join Date: Jun 2012
Device: kobo touch
|
Thank you sti! I tried this under windows for a Kobo Touch. Unfortunately, without success. Maybe somebody can tell me what I am doing wrong. This is what I did. I had already a copy of the internal sd, so I skip this part.
On the pc: With a hex editor, changed 0 to 1 at position 0x80040. (Or is the assumption that the position is the same as for the H2O wrong?) Wrote the image to a sd with USB Duplicator Image Writer.exe. Inserted the sd in the external slot of the (already running) Kobo. With telnet: Code:
### mount /dev/mmcblk1p1 /mnt/sd mknod /mnt/sd/dev/mmcblk1 b 179 8 mknod /mnt/sd/dev/mmcblk1p1 b 179 9 mknod /mnt/sd/dev/mmcblk1p2 b 179 10 mknod /mnt/sd/dev/mmcblk1p3 b 179 11 ## rm /mnt/sd/etc/udev.tgz ## sed -i -e 's/mmcblk0p/mmcblk1p/g' /mnt/sd/etc/init.d/rcS ## umount /mnt/sd mount /dev/mmcblk1p3 /mnt/sd dosfsck /mnt/sd ## umount /mnt/sd reboot Last edited by tshering; 11-24-2016 at 01:20 PM. |
11-24-2016, 08:31 PM | #12 | |
Junior Member
Posts: 5
Karma: 22094
Join Date: Nov 2014
Device: kindle PaperWhite, kobo Aura H2O
|
Hello tshering,
indeed the offsets might be different on the Kobo Touch or maybe the flag does not exist at all. Assuming they are the same, I am wondering about Quote:
In any case, being logged into the kobo I suppose you can run Code:
ntx_hwconfig -s /dev/mmcblk1 Code:
[47] BootOpt=ESD:ON Hope this helps. Stefan |
|
11-25-2016, 03:06 PM | #13 |
Wizard
Posts: 3,489
Karma: 2914715
Join Date: Jun 2012
Device: kobo touch
|
Thank you for the response, Stefan!
I had already some doubt whether my calculation was correct. After a long day, I was too tired to think it over again, and set the byte before and the one after too, just to be on the save side. (Maybe I should have mentioned this.) Today I set only byte 47. Code:
[root@(none) ~]# ntx_hwconfig -s /dev/mmcblk1 ... [0] PCB='E60610D' ... [47] BootOpt='[+] 0x01' ... [root@(none) ~]# cat /proc/cmdline console=ttymxc0,115200 rootwait rw quiet lpj=3997696 root=/dev/mmcblk0p1 rootfst ype=ext4 hwcfg_p=0x7ffffe00 hwcfg_sz=512 waveform_p=0x7fefd000 waveform_sz=10603 52 mem=254M Last edited by tshering; 11-25-2016 at 03:09 PM. |
11-25-2016, 03:56 PM | #14 |
Junior Member
Posts: 5
Karma: 22094
Join Date: Nov 2014
Device: kindle PaperWhite, kobo Aura H2O
|
Hello tshering,
is the cat /proc/cmdline after trying to boot from the external SD? If so, it looks like it doesn't work. I was going to ask about the KeyPad (byte 1) value but found its value on the net (1Key). I also found the u-boot sources for the Touch to be different, but the relevant part is the same. After some reading I draw the following conclusions: The Touch does not use the BootOpt flag at all. From the u-boot sources I believe it will boot the system partition on an external SD card when:
However, if it fails to detect the SD card or the power button press it will apparently boot into recovery. Good luck Stefan |
11-25-2016, 04:15 PM | #15 |
Wizard
Posts: 3,489
Karma: 2914715
Join Date: Jun 2012
Device: kobo touch
|
Stefan, thank you again! Yes, cat/proc/cmdline was after trying to boot from external SD.
I now tried it with a Kobo Glo, with the same result. Code:
[root@(none) ~]# ntx_hwconfig -s /dev/mmcblk1 HW CONFIG v1.3 @1024 secno, size=35 bytes : NtxHwCfg_GetCfgFldStrVal:[WARNING]Config version too old !! Please update config file !! [0] PCB='E606B0' NtxHwCfg_GetCfgFldStrVal:[WARNING]Config version too old !! Please update config file !! [1] KeyPad='FL_Key' ... [34] HallSensor='TLE4913' [35] DisplayBusWidth=[+] [36] FrontLight_Flags=[+] [37] PCB_Flags=[+] [38] FrontLight_LEDrv=[+] [39] VCOM_10mV_HiByte=[+] [40] VCOM_10mV_LoByte=[+] [41] PCB_REV=[+] [42] PCB_LVL=[+] [43] HOME_LED_PWM=[+] [44] PMIC=[+] [45] FL_PWM=[+] [46] RTC=[+] [47] BootOpt=[+] [48] Touch2Ctrl=[+] [49] Touch2Type=[+] [50] GPS=[+] [51] FM=[+] [root@(none) ~]# cat /proc/cmdline console=ttymxc0,115200 rootwait rw quiet lpj=4997120 root=/dev/mmcblk0p1 rootfst ype=ext4 hwcfg_p=0x7ffffe00 hwcfg_sz=512 waveform_p=0x7fee2c00 waveform_sz=11678 72 mem=254M mx50_1GHz |
Tags |
debi, dual boot, h2o |
|
Similar Threads | ||||
Thread | Thread Starter | Forum | Replies | Last Post |
How to show kernel boot information instead Amazon boot picture? | madtrapper | Kindle Developer's Corner | 8 | 01-04-2013 08:51 AM |
Touch No external JS? | rtmyers | Kobo Reader | 7 | 10-16-2012 11:24 PM |
External SD | 0bserver92 | Kobo Tablets | 4 | 03-17-2012 11:17 AM |
Need to re-boot | killjoy | Amazon Kindle | 2 | 07-20-2011 12:48 PM |
Opus cannot boot, stuck on boot screen | baloma | Bookeen | 35 | 11-13-2010 04:20 AM |