Difference between revisions of "Funtoo binfmt misc Qemu chroot Guide"

From Funtoo
Jump to navigation Jump to search
Line 14: Line 14:
###i## mount foo.local:/ /mnt/piroot
###i## mount foo.local:/ /mnt/piroot
###i## mount -t proc /proc /mnt/piroot/proc
###i## mount -t proc /proc /mnt/piroot/proc
###i## mount --rbind /sys /mnt/piroot/sys  
###i## mount --rbind /sys /mnt/piroot/{sys,dev}
###i## mount --make-rslave /mnt/piroot/sys  
###i## mount --make-rslave /mnt/piroot/{sys,dev}
###i## mount --rbind /dev /mnt/piroot/dev
###i## mount --make-rslave /mnt/piroot/dev  
###i## mount -t devpts none /mnt/piroot/dev/pts
###i## mount -t devpts none /mnt/piroot/dev/pts
}}
}}
Line 53: Line 51:
         return execve("/usr/local/bin/qemu-arm", newargv, envp);
         return execve("/usr/local/bin/qemu-arm", newargv, envp);
     }
     }
{{console|body=
###i## echo ":arm:M::\x7f\x45\x4c\x46\x01\x01\x01\x00\x00\x00\x00\x00\x00\x00\x00\x00\x02\x00\x28:\xff\xff\xff\xff\xff\xff\xff\xfc\xff\xff\xff\xff\xff\xff\xff\xff\xfe\xff\xff:/usr/local/bin/qemu-arm-wrapper:" > /proc/sys/fs/binfmt_misc/register


}}
}}
{{file|name=masky.py|lang=python|desc=masky|body=
{{file|name=masky.py|lang=python|desc=masky|body=
#!/usr/bin/python3
#!/usr/bin/python3
Line 73: Line 77:
         else:
         else:
             sys.stdout.write("\\x" + "{0:02x}".format(ord(ascii_value)))
             sys.stdout.write("\\x" + "{0:02x}".format(ord(ascii_value)))


chunk_as_hexstring = ""
chunk_as_hexstring = ""
Line 88: Line 91:
print_out_hexstring(mask_as_hexstring)
print_out_hexstring(mask_as_hexstring)
sys.stdout.write(":/usr/local/bin/qemu-arm-wrapper:\n")
sys.stdout.write(":/usr/local/bin/qemu-arm-wrapper:\n")
}}
}}

Revision as of 09:05, February 15, 2019

Funtoo binfmt_misc Qemu chroot Guide: aka (Frankenroot)

   /etc/exports - NFS file systems being exported
# /etc/exports: NFS file systems being exported.  See exports(5).
/ 
192.168.0.0/24(insecure,no_root_squash,nohide,rw,sync,no_subtree_check)
/boot/ 
192.168.0.0/24(insecure,no_root_squash,nohide,rw,sync,no_subtree_check)
/dev/ 
192.168.0.0/24(insecure,no_root_squash,nohide,rw,sync,no_subtree_check,fsid=77)
root # mount foo.local:/ /mnt/piroot
root # mount -t proc /proc /mnt/piroot/proc
root # mount --rbind /sys /mnt/piroot/{sys,dev} 
root # mount --make-rslave /mnt/piroot/{sys,dev} 
root # mount -t devpts none /mnt/piroot/dev/pts


   /etc/portage/make.conf - Portage make.conf file
# /etc/portage/make.conf:
QEMU_USER_TARGETS="aarch64 arm"
FEATURES="-sandbox -ipc-sandbox -usersandbox candy"

{{file|name=qemu-arm-wrapper.c|lang=C|desc=qemu arm wrapper|body=

   /*
    * Call QEMU binary with additional "-cpu cortex-a7" argument.
    *
    * Copyright (c) 2018 sakaki <sakaki@deciban.com>
    * License: GPL v3.0+
    *
    * Based on code from the Gentoo Embedded Handbook
    * ("General/Compiling_with_qemu_user_chroot")
    */
   #include <string.h>
   #include <unistd.h>
   int main(int argc, char **argv, char **envp) {
       char *newargv[argc + 3];
       newargv[0] = argv[0];
       newargv[1] = "-cpu";
       newargv[2] = "cortex-a7";
       memcpy(&newargv[3], &argv[1], sizeof(*argv) * (argc -1));
       newargv[argc + 2] = NULL;
       return execve("/usr/local/bin/qemu-arm", newargv, envp);
   }
root # echo ":arm:M::\x7f\x45\x4c\x46\x01\x01\x01\x00\x00\x00\x00\x00\x00\x00\x00\x00\x02\x00\x28:\xff\xff\xff\xff\xff\xff\xff\xfc\xff\xff\xff\xff\xff\xff\xff\xff\xfe\xff\xff:/usr/local/bin/qemu-arm-wrapper:" > /proc/sys/fs/binfmt_misc/register


   masky.py (python source code) - masky
#!/usr/bin/python3
import sys
import struct
import string
import codecs

printable_chars = set(string.printable)
printable_chars = set()
def print_out_hexstring(hexstring):
    to_process = hexstring
    while len(to_process):
        ascii_value = chr(int(to_process[:2], 16))
        to_process = to_process[2:]
        if ascii_value in printable_chars:
            sys.stdout.write(ascii_value)
        else:
            sys.stdout.write("\\x" + "{0:02x}".format(ord(ascii_value)))

chunk_as_hexstring = ""
with open(sys.argv[1], 'rb') as f:
    for x in range(0,19):
       chunk_as_hexstring += f.read(1).hex()
mask_as_hexstring = "fffffffffffffffcfffffffffffffffffeffff"
mask = int(mask_as_hexstring, 16)
chunk = int(chunk_as_hexstring, 16)
out_as_hexstring = hex(chunk & mask)[2:]
sys.stdout.write(":arm:M::")
print_out_hexstring(out_as_hexstring)
sys.stdout.write(":")
print_out_hexstring(mask_as_hexstring)
sys.stdout.write(":/usr/local/bin/qemu-arm-wrapper:\n")