-
Notifications
You must be signed in to change notification settings - Fork 9.3k
Update Modify openpilot
- Git Branches
- Why Would a User Switch Branches?
- How to Switch to master-ci (Non-Developers)
- How to Checkout a Specific Release
-
For Developers
- 1. SSH into your comma2/EON
- 2. Checkout your desired branch
- 3. (Optional) Monitor build process after reboot
- Developer Notes
Updating openpilot for most users is intended to be an automatic process, when it comes to official releases (i.e. versions that are listed here: https://github.com/commaai/openpilot/releases).
By switching away from the default release2
branch of Openpilot, you will lose the benefit of Comma's rigorous test and review process. All other branches can and likely do have bugs, some of which may cause undesirable behavior, you switch branches at your own risk.
See the Pro Git Book and specifically the chapter on Git Branches for an explanation of what a branch is. See the Openpilot Development Flow discussion on George's Medium post on Externalization for an explanation of the various Openpilot branches.
Switching branches is primarily the realm of developers. However, there are two reasons why a general user may want to switch to the master-ci
branch of Openpilot:
- Gaining access to a bug fix
- Gaining access to newly fingerprinted vehicles
- You will first need to gain access to your device using SSH, see the SSH instructions.
- Then you need to run the following command:
This command will replace whatever version of openpilot you are currently running with the master-ci
branch. Caution: this command will blow away the openpilot directory, so if you are a developer who has made changes to openpilot, this command is not for you.
cd /data && rm -rf openpilot && git clone -b master-ci https://github.com/commaai/openpilot && reboot
- Find and run "Uninstall Openpilot" in Settings or "Factory Reset" the device in recovery (C2: "Volume Up" + Power Button when plugging in cable).
- In place of the "openpilot.comma.ai" URL for Custom Software during installation, use "https://smiskol.com/fork/commaai/master-ci".
- You will first need to gain access to your device using SSH, see the SSH instructions.
- Then you need to run the following command:
This command will replace whatever version of openpilot you are currently running with the master-ci
branch. Caution: this command will blow away the openpilot directory, so if you are a developer who has made changes to openpilot, this command is not for you.
cd /data && rm -rf openpilot && git clone -b v0.7.6 https://github.com/commaai/openpilot && reboot
However, if you want to test out newer, unreleased version like 0.8.0, the easiest way is to git clone
openpilot directly onto your CommaTwo/EON and git checkout
the master branch (could potentially be unstable since changes are made daily). The steps below show how to ensure you are on the git branch that has the latest code changes.
The latest openpilot revisions come from the main repository: https://github.com/commaai/openpilot .
If you want to test out your own modified code, create a fork of the main repo and clone that one (branches should still be the same)
1. SSH into your comma2/EON
cd /data/
mv openpilot/ openpilot.backup
git clone https://github.com/commaai/openpilot.git
cd openpilot
-
release2
- latest official release with compiled binary. Does not need to be built on the devicegit checkout release2
-
master
- latest openpilot changes. The master branch has submodules, which need to be updated/initialized, otherwise once you reboot your build will fail. Needs to be built on the device.git checkout master
git submodule update --init --recursive
-
reboot
to start build
-
master-ci
- latest openpilot changes, with submodules already integrated. Needs to be built on the device.git checkout master-ci
-
reboot
to start build
devel
devel-staging
For branches that need to be built, you can monitoring the building process by SSH'ing into your comma right after reboot and typing tmux a
When switching between branches, if the version of cereal or some other submodule has changed between the branches, you may encounter errors including the "communication between processes" issue. To reinitialize the submodules after you checkout a new branch run the following commands:
git submodule deinit --all -f
git submodule init
git submodule update
Make driving chill. Buy a comma 3X with a car harness today! Our new price is $999