Guides

Brian's Guides for BeagleY-AI (2025)

These guides will walk you through the steps needed to get up and running for each topic. If (when!) things go wrong, see the troubleshooting steps at the end of most sections before posting in Piazza. Suggested C style guide.

Guides for the first week - Getting up and running!

  • Case assembly guide: Coming soon
  • Quick-start guide: Coming soon
  • Networking guide: Coming soon
  • NFS guide: Coming soon
  • [Optional] Serial Guide: Using a Raspberry Pi Debug Probe to see output from Linux on the BeagleY-AI.
  • [Optional] WSL guide: Coming soon

BeagleBone Green Guides

These guides are for the BeagleBone Green, which was used in previous offerings of this course. The guides are left here for general ideas, plus reference by anyone using a BeagleBone!

See BeagleBone Green Guides...

Guides for the first week - Getting up and running!

  • Case Assembly Guide for AdaFruit plate: How to put together the BeagleBone, Zen, and Adafruit mounting plate
  • Quick-Start Guide: How to setup the build environment and download code to the BeagleBone
  • Networking Guide: How to get an Ethernet connection between the BeagleBone and the host PC
  • Reflash your BBG: How to wipe your board and install a new software image to your BBG (wiping everything). Only do this if you want to upgrade to a new version or wipe your board!
  • NFS Guide: How to setup the NFS server and connect to it from the target
  • [NEW] WSL Embedded Linux Guide: Brief steps on getting WSL2 setup for embedded Linux development. Combines steps from the Quick Start, Networking, and NFS guides.

Guides for Assignment 1

  • RFS Customization Guide: Guide to setting the message of the day, and running code on log in.
  • LED Guide: How to control the LEDs via the terminal and C
  • GPIO Guide: How to control read/write to GPIO pins via the file system and C
    • Sample C program for edge triggered GPIO; however, non-edge triggered GPIO (such as described in GPIO guide and assignment) may be easier to implement and debug; use this code only if you want edge-triggered.

Guides for Assignment 2

Guides for Assignment 3

  • Zen Cape Audio Guide covering the Zen cape, USB Audio, and PCM audio output via ALSA in C
    • ALSA Code Samples:
      • wave-player.c & Makefile: Sample C application for PCM audio output via ALSA.
      • audio_cmake.zip: The wave-player app built using CMake instead of a Makefile.
      • audioMixer_template.c/.h: Template of an audio mixer code for mixing real-time PCM sounds into one output stream.
    • Drum sounds suitable for creating a drum beat. From Freesound.org, by "menegass", used under Creative Commons license
    • Student created guide for using ALSA with Rust
  • Accelerometer: No guide is provided for using the specific parts on the Zen capes.
    • See I2C guide above for general commands and understanding.
    • See accelerometer data sheet for knowing what registers to read/write:
      Zen Cape Green: MMA8452Q datasheet by Freescale Semiconductor, I2C bus I2C_1 at address 0x1C.
      Zen Cape Red: LIS331DLH datasheet by ST Micro, I2C bus I2C_1 at address 0x18.

Guides for Assignment 4

Guides for Kernel Driver Exercise

  • Driver Creation Guide
    • Here is a previous guide which covers compiling and downloading a new kernel to the board. However, as of Feb 2023 the version of UBoot running on the board seems not to function with downloading the kernel (generates "data abort" errors). So, we are switching to building drivers for the currently installed kernel on the board, using the above (shorter!) guide.
  • LED Wiring Guide; covers configuring LED with the Linux kernel. (.dts file works with Bullseye kernel 5.10)

Old Guides (2023)

These guides have not been updated for this offering of the course; though, they are likely mostly accurate.

All 2021-Spring Guides

Here is a ZIP of all the guides, as of the end of the Spring 2021 semester.



Find guides created by previous student groups here.

Guides