Keeping Warthog Updated ========================== .. note:: If you are upgrading your Warthog from an older version of ROS, please refer to `our upgrade instructions here `_. Warthog is always being improved, both its own software and the many community ROS packages upon which it depends! You can use the apt package management system to receive new versions all software running on the platform. Getting New Packages -------------------- Each Warthog leaves the factory already configured to pull packages from http://packages.ros.org as well as http://packages.clearpathrobotics.com. To update your package and download new package versions make sure that Warthog is connected to the internet and run the following commands: .. code-block:: bash sudo apt-get update sudo apt-get dist-upgrade If you see any errors, please `get in touch`_ and we'll see if we can get you sorted out. .. _get in touch: https://support.clearpathrobotics.com/hc/en-us/requests/new MCU Firmware Update ------------------- .. warning:: Accessing Warthog's MCU requires access to several hard-to-get-to parts of the robot. Unless absolutely necessary, we do not recommend re-flashing the robot's MCU firmware. You need to use an external PC to update Warthog's MCU firmware. You cannot use Warthog's internal PC, as installing the firmware requires power-cycling the MCU. Warthog's MCU controls the power supply to the internal PC. These instructions assume the external PC is running some flavour of Linux with access to Clearpath's ROS packages. Follow the below procedure to flash the firmware to Warthog's MCU: 1. Place Warthog up on blocks and/or engage the emergency stop by pressing one of the red buttons located on each corner of the robot. Firmware loading does not usually result in unintended motion, but it's safest to ensure the robot cannot move accidentally. 2. Download the Warthog firmware package onto your PC: .. code-block:: bash sudo apt-get install ros-kinetic-warthog-firmware 3. Remove the top panel from the Warthog. We recommend opening the panel to the left, as there are cables that run into the lid which can be strained. .. image:: graphics/warthog_inside_lid.jpg :alt: The inside of Warthog's computer box 4. Warthog's MCU is located on the underside of the metal frame over the top of the PC. To access it you will need to disconnect all cables from the breakout on the sloped portion on the left and then undo 4 screws anchoring the frame: .. image:: graphics/warthog_inside.jpg :alt: The inside of Warthog's computer box .. image:: graphics/screws_left.jpg :alt: Screws on the left .. image:: graphics/screws_right.jpg :alt: Screws on the right Once the screws are removed, carefully lift the center panel and turn it over to expose the MCU's micro USB port and buttons. 5. While pressing ``BT0`` on the MCU, connect the external PC to Warthog's MCU using a USB cable. .. image:: graphics/mcu_buttons.jpg :alt: Warthog's MUC's buttons 6. After connecting the PC you should see a device with a name similar to ``Bus 001 Device 005: ID 0483:df11 STMicroelectronics STM Device in DFU Mode`` in the output of ``lsusb``. .. note:: If the MCU does not show up as a DFU device in the output of ``lsusb`` after completing the above procedure, press and hold BT0 on the MCU press the RST button while holding BT0 down. This will reset the MCU and force it into DFU mode. With the MCU in DFU mode, run the following command, replacing ``001/005`` with the value appropriate to the Bus and Device where Warthog's MCU is connected: .. code-block:: bash sudo chmod 666 /dev/bus/usb/001/005 Now run the following command to upload the firmware: .. code-block:: bash dfu-util -v -d 0483:df11 -a 0 -s 0x08000000 -D /opt/ros/kinetic/share/warthog_firmware/mcu.bin You should see about 20 seconds worth of lines output beginning with "Download from image ...". When this is complete you may disconnect the PC from the MCU and power-cycle the robot. .. _scratch: Starting From Scratch --------------------- If Warthog's computer has become inoperable, or for any reason you want to restore it to the factory state, you can reinstall the operating system to the PC. Warthog includes USB and ethernet breakouts located on the rear of the robot for easy access. However, to connect a monitor to the PC you will need to open up Warthog's body and access the HDMI port located on the sloped portion of the center frame. .. image:: graphics/hdmi_breakout.jpg :alt: Warthog's PC. 1. Download the latest operating system image for Warthog from https://packages.clearpathrobotics.com/stable/images/latest/kinetic-xenial/ 2. Use unetbootin__ or rufus__ (Windows only) to write the ISO image to a USB memory stick .. _unetbootin: https://unetbootin.github.io/linux_download.html __ unetbootin_ .. _rufus: https://rufus.ie/ __ rufus_ .. image:: graphics/unetbootin.png :alt: Unetbootin 3. Connect Warthog's PC to the internet with an ethernet cable. Also connect a monitor, mouse, and keyboard to the PC. 4. Connect Warthog to shore power to ensure it does not power down while the OS is installing. This is optional, but recommended. 5. Insert the USB drive into one of the Warthog's PC's USB ports and power-cycle the PC. You should see a purple Debian/Ubuntu installer. The installer will run by itself and power off the PC when finished. If you do 6. Remove the USB drive and power on the PC. 7. Log into Warthog. The username is ``administrator`` and the password is ``clearpath`` 8. Install Warthog's robot_upstart__ job, so that ROS will launch each time the robot starts: .. _robot_upstart: http://wiki.ros.org/robot_upstart __ robot_upstart_ .. code-block bash rosrun warthog_bringup install You can now configure Warthog to :doc:`connect to your wi-fi `.