-
Notifications
You must be signed in to change notification settings - Fork 167
User Guide: FlyingPI Setup
Michael Corcoran edited this page Aug 9, 2017
·
14 revisions
WORK IN PROGRESS
- Fetch the hardware design files and documentation
- Get some PCBs manufactured (OSH Park is known to be good)
- Obtain all the components listed in the BoM
- A Raspberry Pi 2 or later (not zero, compute etc.)
- BMX055 requires care
- OSRAM LED markings are confusing, the little mark/arrow goes away from the line toward the cathode
- Test with current limited bench supply on battery pins, 12 V 100 mA or so, make sure no smoke, super-low current, check 5 V on 5 V pins
- Test with 3V3 on 3V3 pins, make sure super-low current/no smoke
- Press header onto Pi extension connector
- Requires dRonin build environment setup on your dev machine.
- Install arm toolchain:
sudo apt install gcc-arm-linux-gnueabihf
. Note: This will uninstallgcc-multilib
if you were using it previously for sim builds due to an upstream Ubuntu bug. Installlinux-libc-dev:i386
to get x86 sim build working again. PI_CROSS_SIM=yes make sim
make ef_flyingpio
- Obtain Raspbian image, lite is fine (2017-04-10 is known to work, newer versions currently don't work with RT kernel).
-
Unzip, write to your SD Card (
umount /dev/sdX1
etc.,dd bs=4M status=progress if=20xx-xx-xx-raspbian-jessie-lite.img -of /dev/sdX
) - Enable SSH on first boot (mount the SD card (reinsert on desktop distros), cd into boot partition,
touch ssh
) - Connect Ethernet and power up Pi
- Enable SSH (semi?)permanently, ssh into Pi and
sudo raspi-config
> Interfacing Options > SSH - Copy
flyingpi.cfg
,flyingpio.dts
,flyingpio_eeprom.txt
fromflight/targets/flyingpio
,sim.elf
frombuild/sim-pi
, andfw_flyingpio.hex
frombuild/flyingpio/
to home dir on pi (scp flight/targets/flyingpio/flyingpi* build/sim-pi/sim.elf build/fw_flyingpio/fw_flyingpio.hex pi@<pi address>:~
)
wget https://github.com/d-ronin/linux/releases/download/linux-4.4.47-pi-rt59/linux-image-4.4.47-rt59-v7._1.0_armhf.deb
sudo dpkg -i linux-image-4.4.47-rt59-v7._1.0_armhf.deb
cd /boot
sudo mv kernel7.img kernel7.img.old
sudo mv vmlinuz-4.4.47-rt59-v7+ kernel7.img
sudo reboot
uname -a
#------ this set of steps could be omitted if A) upstream had a good openocd, or B) we had an openocd package
sudo apt-get install links
links https://sourceforge.net/projects/openocd/files/latest/download
tar xjf openocd-0.10.0.tar.bz2
cd openocd-0.10.0
./configure --enable-sysfsgpio
make -j4
sudo make install
cd ..
#----- verify programming works
sudo openocd -f flyingpi.cfg
#----- provision the hat
dtc -I dts -O dtb flyingpio.dts -o flyingpio.dtbo
sudo apt-get install git
git clone https://github.com/raspberrypi/hats
cd hats/eepromutils/
make
./eepmake ../../flyingpio_eeprom.txt flyingpio.ee ../../flyingpio.dtbo
sudo dtparam i2c_vc=on
sudo ./eepflash.sh -w -t=24c32 -f=flyingpio.ee
sudo reboot
#---- check that we have spidevs
ls /dev/spid*
#--- pull flyingpio out of reset
sudo sh -c "echo 17 | tee /sys/class/gpio/export"
sudo sh -c "echo out | tee /sys/class/gpio/gpio17/direction"
sudo sh -c "echo 1 | tee /sys/class/gpio/gpio17/value"
#--- run the simulator by hand
sudo chrt -r -p 80 `pgrep spi0`
sudo ./sim.elf -r -s /dev/spidev0 -d ms5611:0:4 -d bmx055:0:1 -d bmm150:0:3 -d flyingpio:0:0
#---- connect with GCS over TCP