Claude-skill-registry hardware-integration
Camera, GPIO, and hardware integration for Raspberry Pi 5. Use for camera testing, hardware diagnostics, GPIO troubleshooting, and sensor issues.
install
source · Clone the upstream repo
git clone https://github.com/majiayu000/claude-skill-registry
Claude Code · Install into ~/.claude/skills/
T=$(mktemp -d) && git clone --depth=1 https://github.com/majiayu000/claude-skill-registry "$T" && mkdir -p ~/.claude/skills && cp -r "$T/skills/data/hardware-integration" ~/.claude/skills/majiayu000-claude-skill-registry-hardware-integration && rm -rf "$T"
manifest:
skills/data/hardware-integration/SKILL.mdsource content
Hardware Integration Skill
Complete reference for camera, GPIO, USB, and hardware integration on Raspberry Pi 5 for the PhotoBooth application.
Quick Reference
- Camera: iPad via getUserMedia (browser-based capture)
- Printer: Canon Selphy CP1500 via USB/CUPS
- Network: Wi-Fi AP mode (hostapd)
- Storage: 256GB microSD
Raspberry Pi 5 Specifications
| Component | Specification |
|---|---|
| CPU | Broadcom BCM2712, Quad-core Cortex-A76 @ 2.4GHz |
| RAM | 8GB LPDDR4X |
| USB | 2x USB 3.0, 2x USB 2.0 |
| GPIO | 40-pin header, 26 GPIO pins |
| Network | Gigabit Ethernet, Wi-Fi 5 (802.11ac), Bluetooth 5.0 |
Camera Integration
The PhotoBooth uses iPad Air as the camera device via browser's getUserMedia API.
Camera Constraints (Frontend)
const constraints: MediaStreamConstraints = { video: { facingMode: 'user', // Front camera for selfies width: { ideal: 1920 }, // Full HD height: { ideal: 1080 }, frameRate: { ideal: 30 } }, audio: false };
Camera Testing
# On iPad (Safari DevTools): # Check getUserMedia support navigator.mediaDevices.getUserMedia({ video: true }) .then(stream => console.log('Camera OK')) .catch(err => console.error('Camera Error:', err));
USB Device Management
List USB Devices
# List all USB devices lsusb # Detailed info lsusb -v | grep -A 10 "Canon" # Check USB device tree lsusb -t
USB Troubleshooting
# Check kernel messages for USB dmesg | grep -i usb | tail -20 # Reset USB bus (if device not responding) sudo usbreset /dev/bus/usb/001/002 # Replace with actual device
Network (Wi-Fi AP Mode)
Configuration Files
- AP configuration/etc/hostapd/hostapd.conf
- DHCP configuration/etc/dnsmasq.conf
- Static IP for wlan0/etc/dhcpcd.conf
hostapd Configuration
interface=wlan0 driver=nl80211 ssid=photobooth hw_mode=g channel=7 wmm_enabled=0 macaddr_acl=0 auth_algs=1 ignore_broadcast_ssid=0 wpa=2 wpa_passphrase=photobooth-1998 wpa_key_mgmt=WPA-PSK rsn_pairwise=CCMP
Network Testing
# Check Wi-Fi AP status sudo systemctl status hostapd # List connected clients iw dev wlan0 station dump # Check IP assignments cat /var/lib/misc/dnsmasq.leases
System Diagnostics
Temperature Monitoring
# CPU temperature vcgencmd measure_temp # Continuous monitoring watch -n 1 vcgencmd measure_temp
Memory and CPU
# Memory usage free -h # CPU usage top -bn1 | head -20 # Disk usage df -h
Service Status
# Check all PhotoBooth services sudo systemctl status hostapd sudo systemctl status dnsmasq sudo systemctl status cups sudo systemctl status photobooth-backend sudo systemctl status photobooth-frontend
Common Issues & Solutions
Issue: Camera not accessible from browser
Cause: HTTPS required for getUserMedia on non-localhost Solution:
- Use self-signed certificate for HTTPS
- Or add exception in Safari settings
- Or use localhost with port forwarding
Issue: USB device not detected
Cause: Power issues or driver problems Solution:
# Check USB power vcgencmd get_throttled # Reload USB driver sudo modprobe -r usb_storage && sudo modprobe usb_storage # Check dmesg for errors dmesg | tail -50
Issue: Wi-Fi AP not starting
Cause: Interface conflict or config error Solution:
# Check for conflicts sudo rfkill list # Unblock if blocked sudo rfkill unblock wifi # Restart hostapd sudo systemctl restart hostapd
Issue: High CPU temperature
Cause: Inadequate cooling or high load Solution:
# Check temperature vcgencmd measure_temp # If > 80°C, reduce CPU frequency temporarily echo 1500000 | sudo tee /sys/devices/system/cpu/cpu0/cpufreq/scaling_max_freq
Hardware Test Script
Create
/home/pi/scripts/test-hardware.sh:
#!/bin/bash echo "=== PhotoBooth Hardware Diagnostics ===" echo "" echo "CPU Temperature: $(vcgencmd measure_temp)" echo "Memory: $(free -h | grep Mem | awk '{print $3"/"$2}')" echo "Disk: $(df -h / | tail -1 | awk '{print $3"/"$2" ("$5" used)"}')" echo "" echo "=== USB Devices ===" lsusb | grep -v "hub" || echo "No non-hub USB devices" echo "" echo "=== Network ===" echo "Wi-Fi AP: $(systemctl is-active hostapd)" echo "DHCP: $(systemctl is-active dnsmasq)" echo "Connected clients: $(iw dev wlan0 station dump 2>/dev/null | grep Station | wc -l)" echo "" echo "=== Services ===" echo "CUPS: $(systemctl is-active cups)" echo "Backend: $(systemctl is-active photobooth-backend 2>/dev/null || echo 'not configured')" echo "" echo "=== Diagnostics Complete ==="
Related Documentation
- Full deployment guidedocs/DEPLOYMENT.md
- Hardware error codes (PRINTER_, STORAGE_)docs/ERROR_CODES.md
- Health monitoringdocs/use-cases/UC-205-health-check.md