You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
EmielleC 0cf532fa8b Tested v2 camera on raspberry pi 4 3 weeks ago
.github/workflows actions: also build for raspberrypi4 1 month ago
board linux-base.config: standardise unset options 1 month ago
configs raspberrypi4: support new device 1 month ago
package multi-gadget: enable serial if no camera detected 1 month ago
patches/linux-custom Enabling more video controls: Contrast, Hue, Sharpness, etc 5 months ago
rootfs rootfs: Move to root folder 4 months ago
.gitignore Remove extraneous enable-serial-debug from .gitignore 4 months ago add camera-control package 5 months ago
LICENSE Add LICENSE file - GPLv3 9 months ago Tested v2 camera on raspberry pi 4 3 weeks ago raspberrypi4: support new device 1 month ago
camera.txt.example Update README and example camera.txt 6 months ago
external.desc First commit - add raspberry0cam project 9 months ago First commit - add raspberry0cam project 9 months ago
smwc-expect Adapt to changed hostname and hence prompt 5 months ago

Show-me webcam: An open source, trustable and high quality webcam

Build/Release License Last Release Total Downloads Discord Chat

This firmware transforms your Raspberry Pi into a high quality webcam. It works reliably, boots quickly, and gets out of your way.

Wiki & Documentation | Discord Chat | Introduction video | Hackaday Project

Show-me webcam is proudly powered by peterbay's uvc-gadget.

What you need

  • Raspberry Pi Zero with or without Wifi
  • Raspberry Pi Zero Camera Adapter/Ribbon (The one that comes with the camera may not fit)
  • Raspberry Pi Camera or Raspberry Pi High-Quality Camera
  • A compatible lens if you use the HQ Camera sensor
  • Micro SD card (at least 64MB)
  • A case or mounting plate (optional)

What works and what doesn't

  • The camera is known to work on Linux, Windows 10 and Mac OS
  • The camera is known to work with Zoom, Teams, Jitsi, Firefox and Chrome
  • Here's a compatibility matrix as far as we could test. Let us know if you had the chance to test other variants:
Raspberry Pi \ Camera version v1 5MP v2 8MP High Quality 12MP
Pi Zero v1.3 (without Wifi)
Pi Zero W (with Wifi)
Pi 4+


  • Watch the introduction video
  • Assemble the camera with the Raspberry Pi
  • Download the latest release (see below)
  • Use Etcher or dd to write the image to the Micro SD card
  • Use the USB data port (the one in the middle of the Raspberry Pi, not the one on the edge) to connect to a computer
  • Smile & Enjoy!

Stable releases

We release new versions of this firmware regularly at the release tab:

LED indicator

After booting, the built-in LED will blink three times quickly to show you it's ready.

When the camera is in use the LED will be lit. In addition, GPIO 21 pin is set to HIGH, so an external LED or another payload can be triggered with this pin to indicate that the camera is in use.


For debugging, a 115200 baud serial interface is provided as a ttyACM device:

  • Use screen, minicom, picocom or the included smwc-expect script to connect to it
  • Use username: root, password root

Also, there is a serial interface on the 40-pin header:

Linux example:

$ ls -l /dev/ttyACM*
crw-rw---- 1 root dialout 166, 0 sep 25 14:03 /dev/ttyACM0
$ sudo screen /dev/ttyACM0 115200

Mac OS example:

$ ls -l /dev/tty.*
crw-rw-rw-  1 root  wheel    9,  18 Dec  7 13:14 /dev/tty.usbmodem13103
$ screen /dev/tty.usbmodem13103 115200

If the terminal is blank try pressing enter to see the login prompt. To exit the session, use Ctrl-A \ (screen) or Ctrl-A X (minicom & picocom).

Warning: This serial debug interface is automatically enabled and is controlled by the file called enable-serial-debug in the /boot folder. This is a potential security issue. For now, you should strongly consider disabling this feature by removing the file after you have finished customizing the webcam.

My camera doesn't show up on my host computer! What to do?

From version 1.80, on Linux, you can see what happens by watching dmesg before you plug in the webcam:

$ sudo dmesg -w

If you only see the ttyACM device show up, but not the webcam, it's likely you have not plugged in the camera cable correctly, or the camera cable has gone bad.

If you see nothing, maybe your USB cable is bad, or you have plugged in the cable to the wrong port.

Customizing camera settings


Log in to the debug interface and execute:


This tool will allow you to show and tweak all available camera parameters. Additionally it will save your settings to /boot/camera.txt if you choose to do so. This will handle remounting /boot automatically.


Overriding camera settings temporarily

Log in to the debug interface. Then list all tweakable parameters:

/usr/bin/v4l2-ctl -L | less

Then you can apply parameters on the fly, e.g.

/usr/bin/v4l2-ctl -c auto_exposure_bias=15
/usr/bin/v4l2-ctl -c contrast=3

Overriding camera settings permanently

Mount the SD card on your computer, edit a file called camera.txt in /boot and put all parameters you want overridden, e.g:

# Tweak the auto exposure bias
# Tweak the contrast

You can edit camera.txt on-target by remounting /boot read-write:

mount -o remount,rw /boot

Development & building

Clone or download this repository. Then inside it:

  • Download the latest Buildroot stable from
  • Extract it and rename it to buildroot
  • Run build command:
    • ./ raspberrypi0w to build Raspberry Pi Zero W (with Wifi) image.
    • ./ raspberrypi0 to build Raspberry Pi Zero (without Wifi) image.
    • ./ raspberrypi4 to build Raspberry Pi 4 image.
    • IMPORTANT: If you didn't rename your Buildroot directory to buildroot or if you put it somewhere else you need to set the Buildroot path manually, e.g. BUILDROOT_DIR=../buildroot ./ raspberrypi0
  • The resulting image sdcard.img will be in the output/$BOARDNAME/images folder
  • If you add a camera.txt file to the root of this repository, the contents will be automatically added to /boot/camera.txt