-
Notifications
You must be signed in to change notification settings - Fork 363
Installation
If you're using a Raspberry Pi to run TeslaUSB, flashing the prebuilt image and then using the "one step setup" process is the easiest and recommended way of setting up TeslaUSB.
If you're not using a Raspberry Pi, or want to use one of the official Raspberry Pi images instead, the installation process involves a few additional manual steps:
- first, flash the image of your choice onto the device of your choice.
- If using a Raspberry Pi Zero 2W, 4B or 5, I recommend using the Raspberry Pi Imager to flash the "Raspberry Pi OS Lite" image: click "Choose OS", then "Raspberry Pi OS (other)", then "Raspberry Pi OS Lite (64-bit)". The 32-bit image will not work properly due to a Linux kernel bug. Since Raspberry Pi Zero W requires 32-bit, I recommend using the prebuilt TeslaUSB image for Raspberry Pi Zero W. You can preconfigure network settings and user info in the "advanced settings" menu of the Raspberry Pi Imager before flashing. If you do not preconfigure network settings, you will need to connect the Raspberry Pi to a keyboard and monitor to log in and configure it later.
- If using another device, using Armbian is recommended. You can still use Raspberry Pi Imager to flash the sd card.
- whichever device and flavor of linux you choose, it is recommended to use a non-desktop version of the OS to avoid the additional boot time and storage that a full desktop install requires. Look for "lite", "CLI", "server", "minimal" or similar names.
- boot the device and log in to it.
If you did not already configure network settings on the device, you should do so now, since TeslaUSB setup needs access to the internet to install. On Armbian, use the
nmtui
command to easily connect to wifi (choose 'Activate a connection', then select your wifi network).
Even if you'll be using ethernet during install, you should configure wifi before proceeding with installing TeslaUSB.
Once you're logged in to the device and the device has network access, run the following commands:
sudo -i
apt update
apt install curl
curl https://raw.githubusercontent.com/marcone/teslausb/main-dev/setup/generic/install.sh | bash
Note
Type the above lines exactly as you see them there. Do not add run
or other prefixes to them. Press the "enter" key after each line.
If you are going to configure TeslaUSB with a separate data drive, replace that last line with the following to skip shrinking the root partition of the SD card:
curl https://raw.githubusercontent.com/marcone/teslausb/main-dev/setup/generic/install.sh | bash -s norootshrink
This will run the "pre setup" script that gets things ready for the main setup process. The device may reboot multiple times. If the device and linux distribution you use support configurable LEDs, the pre setup script will attempt to flash all the LEDs that the device has (including LEDs on an attached keyboard) when it is ready for the next step. If the LEDs are continuously flashing rapidly, log in to the device again and continue with the next paragraph. If the LEDs are flashing intermittently, something went wrong and you should check the setup log for any errors.
If pre-setup was successful, it will have downloaded the default TeslaUSB config file to /teslausb/teslausb_setup_variables.conf. Open this file with your favorite editor, for example by typing nano /teslausb/teslausb_setup_variables.conf
followed by the enter key and fill in the required settings. Save the file, then type /etc/rc.local
followed by the enter key. The device may again reboot multiple times during setup. If the device reboots, you can log in again and follow setup progress by typing tail -f /teslausb/teslausb-headless-setup.log
followed by the enter key.
Once setup is complete, the setup log will show "All done." and the device will reboot. At this point it should be ready to be installed in the car. If you already had a USB drive connected to the car, either in the center console or in the glove box, remove it and replace it with the TeslaUSB device.