__ __| | | /_) | ___| | |
| __ \ _ \ ' / | | / | _ \ __ \ | _` | __ \ __|
| | | | __/ . \ | < | | __/ | | | ( | | |\__ \
_| _| |_|\___| _|\_\_|_|\_\\____|\___|_| _| _____|\__,_|_.__/ ____/
This "bootstrap" implementation allows Akai MPCs / Force system customization at boot time as linux application launching, data rescue, backup settings,... You need to update your MPC/Force with a modded image that will launch the bootstrap from the internal filesystem, before the MPC application starts.
How to install :
-
Copy to the "tkgl_bootstrap_[ProjectData]" directory to the root of an sdcard/usb stick, preferably formatted with ext4 filesystem
Important : the directory MUST be named "tkgl_bootstrap_[ProjectData]" to be hidden and for the bootstrap to be launched on the sdcard. You should change permissions and ownership of binaries and scripts files as follow (locally or in a ssh root session) :
- cd /media/(your smartcard name)/tkgl_bootstrap_[ProjectData] - chmod 755 ./lib/* ./bin/* ./scripts/* - chown root:root ./lib/* ./bin/* ./scripts/*
-
Update as usual (usb procedure) with the last MPC / Force modded image to enable the bootstrap script :
https://github.com/TheKikGen/MPC-LiveXplore
Copy the image file to the root of a usb key. The launch script on the internal ssd will find the tkgl_bootstrap script automatically.
Concerning these images: very little has been changed. It is mainly about enabling SSH, a standard feature of Linux, and checking
if a script exists on a usb key at boot time. That's all. I use it everyday on my MPC Live and my MPC X. Upgrading your MPC or Force with one of these images will not brick your hardware. The update procedure is strictly the same as the one you use for the official images but of course, I can't be held responsible for any problem. You can update again to come back to an official image at any time. -
Create your module and adapt the /tkgl_bootstrap_[ProjectData]/scripts/tkgl_bootstrap script to your needs
Copy paste a script module example (for example the mod_telnetd) to create your own. Your module must be then added to the $DOER variable in the tkgl_bootstrap script.
# submodules launcher : add to the doer , separated by space
#
# install : setup some directories and permissions on the filesystem
# arp_overlay : create an overlay of Arp Patterns on the sdcard (if ext4)
# telnetd : launch a telnetd server (root access)
# nomoressh : stop the ssh temporarily for security reasons.
# You'll need to remove the usb key to reactivate ssh.
# etcovr_clean : clean passwords files and ssh config on the /etc overlay
# anyctrl : use any midi controller as MPC/Force control surface (full ports)
# anyctrl_lt : use any midi controller as MPC/Force control surface (private only)
# iamforcectrl : Force binary launcher on a MPC - Kikpad controller version proof of concept.
# iamforce : New Force binary launcher using mpcmpaaer.so
Have a look to the tkgl_mod_kgl_mod_arp_overlay.sh : it creates an overlay on the Arp Patterns/Progression directory to allow you to load your own patterns from the sdcard (check "Arp Patterns" and "Progressions" links at the root directory that will be created after a first boot).
A full root access to the system is granted within tkgl_bootstrap, however the file system is mounted read-only for security reasons. I do not recommend to install software to (and/or deeply customize) the internal file system. You will loose everything at the next update. Instead implement your custom app on the sdcard, to ensure isolation with the filesystem, and to preserve your work. It also allows you to return to normal operation of your MPC by simply removing the external sdcard/usb key.
-
Place any binary in the /tkgl_bootstrap/bin.
Important : binary exec permissions are not possible if stored on a FAT32 partition.
Use preferably an ext4 formated parition on your sdccard. -
Test locally via ssh before running in nominal mode
ssh root@(your MPC ip addr), then cd to /media(your sdcard name)/tkgl_bootstrap/scripts and run tkgl_bootstrap.
-
Reboot your MPC !
ssh root@(your MPC ip addr) reboot
if your MPC is stuck, remove the sdcard and reboot. You will find a log in the tkgl_bootstrap/logs.