Google Chat: zj734465502@gmail.com
+86-0755-88291180
sales@spotpear.com
dragon_manager@163.com
tech-support@spotpear.com
zhoujie@spotpear.com
WhatsApp:13246739196
As the IO board of the Raspberry Pi Compute Module 5, CM5 PoE BASE A is a baseboard that can be used with the Raspberry Pi Compute Module 5, supporting POE power supply and Type C 5V 5A DC power supply. It comes with 2 USB3.2 Gen1 ports and 2 USB2.0 ports, making it convenient for users.
1. Do not plug or unplug any device other than USB and HDMI when the device is powered on
2. Type C is used as a USB SLAVE interface for burning images, and cannot be used as an OTG interface, it cannot provide power to external devices
3. Onboard default 2 USB 3.2 Gen1 ports
4. When using POE function, be sure to check if the switch supports the 802.3af/at network standard for PoE, and it must support a single port with 30W power
5. When you need to use POE, connect the POE jumper cap to the EN position
6. Supports 4 screens to display different contents, adds MIPI DSI driver, regardless of whether a screen is connected, the system will default to connect, the screen will display in split-screen mode (related to the system version)
7. The onboard PSW button is connected to BOOT, you can press the PSW button before powering on, and connect to the computer through Type C to let the device enter the burning mode
8. Do not connect other devices when using Type C to burn. Insufficient power supply for burning will cause the device to be unrecognized
9. The USB2.0 ports have a total maximum power output of 2A, and the USB3.0 ports have a total maximum power output of 2A



Choose one of the two
1. The onboard PSW button is connected to BOOT, you can press the PSW button before powering on, and connect to the computer through Type C to let the device enter the burning mode
2. Connect the jumper cap to BOOT
Click here for EMMC version
Click here for LITE version
If you need to use POE power supply, connect the POE jumper cap to the EN position
The 12V output is only present when powered by POE, and there is no output when powered by other methods
If a power supply limitation prompt appears
Add usb_max_current_enable=1 to /boot/firmware/config.txt
1. Enable PCIE interface
Add to /boot/firmware/config.txt: dtparam=pciex1
2. PCIE is gen2 by default, if you need to enable PCIE gen3, then add following to /boot/firmware/config.txt:
dtparam=pciex1_gen=3
3. After the modification, restart the PI5, and the device can be recognized.
As shown in the figure below, SM2263 is identified as my SSD solid state drives, and the other PI5 is the RPI chip
4. Partition, skip this step if you have partitioned and formatted on other platforms (Note: partitioning will delete all data on the SSD, proceed with caution)
Lsblk This command is executed to view the disk (if you want to see the details, run the sudo fdisk -l command)Partition: sudo fdisk /dev/nvme0n1 The device number is the total device number, do not add p1, that is just a partition How to use the partitioning tool fdisk: n New partition q Quit without saving p Print the partition table m Print the selection menu D Delete the partition w Save and exit t Modify the ID number Add the partition and execute n, then save and exit with w
5. Format
sudo mkfs. Execute the command and press Tab key, you will see a lot of different suffixes, and the different suffixes are the formats you need to formatIf I want to format it in ext4 file format, then execute the command: sudo mkfs.ext4 /dev/nvme0n1p1 Wait a moment, once all “done” appear as below, it indicates that the formatting is completed

6. Mount
Create a mount directory sudo mkdir toshiba Mount the device sudo mount /dev/nvme0n1p1 ./toshiba Check the disk status df -h
Enter the directory where the disk is mounted
cd toshiba
sudo sh -c "sync && echo 3 > /proc/sys/vm/drop_caches"
sudo dd if=/dev/zero of=./test_write count=2000 bs=1024k

sudo dd if=./test_write of=/dev/null count=2000 bs=1024k

Test shows there's no issue. If it's not required to be used as a system disk, but only for expanding the disk, set it to auto-mount
sudo nano /etc/fstab #Add at the end /dev/nvme0n1p1 /home/pi/toshiba ext4 defaults 0 0 #/dev/nvme0n1p1 is the device name, /home/pi/toshiba refers to mounting to a directory, ext4 is the file system type, defaults uses the default mount option #Make the changes take effect (reboot only after testing, otherwise it will fail to mount and boot) sudo mount -a #Then reboot Check the device with lsblk
Boot the Raspberry Pi with a TF card or EMMC first, mount and test it, and make sure the hardware can work properly
Choose one of the following methods
1. Run the following command:
sudo raspi-config
2. Reboot Raspberry Pi
If you find you can't modify it multiple times, please reconnect to the network and then try to modify it (wait for the network to self-calibrate), or modify the file after setting the correct time
3. Burn the system to NVME, then connect the NVME to the expansion board, remove the TF card and power it on again
1. Modify the BOOT_ORDER in the Raspberry Pi boot loader configuration:
sudo rpi-eeprom-config --edit Modify BOOT_ORDER=0xf41 to BOOT_ORDER=0xf416For more information, please refer to BOOT_ORDER
2. Reboot Raspberry Pi
If you find you can't modify it multiple times, please reconnect to the network and then try to modify it (wait for the network to self-calibrate), or modify the file after setting the correct time
3. Burn the system to NVME, then connect the NVME to the expansion board, remove the TF card and power it on again
The PI5 fan defaults to starting when the temperature reaches 50 degrees. If you want to control it at other temperatures, you can do so by adding specific content to /boot/firmware/config.txt, for example:
dtparam=fan_temp0=36000,fan_temp0_hyst=2000,fan_temp0_speed=90 dtparam=fan_temp1=40000,fan_temp1_hyst=3000,fan_temp1_speed=150 dtparam=fan_temp2=52000,fan_temp2_hyst=4000,fan_temp2_speed=200 dtparam=fan_temp3=58000,fan_temp3_hyst=5000,fan_temp3_speed=255
Among them:
fan_temp0/1/2/3 Indicates the temperature (36000 means 36℃)
fan_temp0/1/2/3_speed Indicates the corresponding rotational speed (value up to 255)
fan_temp0/1/2/3_hyst Indicates the hysteresis temperature
For more details, refer to here
Notice: There are only 4 temperatures, 0, 1, 2 and 3, and it's not possible to set other temperatures. The hysteresis temperature must not exceed the step range between two temperatures
Support dual MIPI, customers can freely choose CSI or DSI connections
The DSI screen is 800x480 resolution screen by default, please refer to the corresponding WIKI for other resolution screens
To use the MIPI1 interface, you need to connect a jumper cap

#Add the following to the config.txt file:
sudo nano /boot/firmware/config.txt
#DSI0 
dtoverlay=vc4-kms-dsi-7inch,dsi0
#DSI1 
dtoverlay=vc4-kms-dsi-7inch,dsi1sudo nano /boot/firmware/config.txt
| Mode | CAM0 setup statement | CAM1 setup statement | 
|---|---|---|
| OV9281 | dtoverlay=ov9281,cam0 | dtoverlay=ov9281,cam1 | 
| IMX290/IMX327 | dtoverlay=imx290,clock-frequency=37125000,cam0 | dtoverlay=imx290,clock-frequency=37125000,cam1 | 
| IMX378 | dtoverlay=imx378,cam0 | dtoverlay=imx378,cam1 | 
| IMX219 | dtoverlay=imx219,cam0 | dtoverlay=imx219,cam1 | 
| IMX477 | dtoverlay=imx477,cam0 | dtoverlay=imx477,cam1 | 
| IMX296 | dtoverlay=imx296,cam0 | dtoverlay=imx296,cam1 | 
| IMX708 | dtoverlay=imx708,cam0 | dtoverlay=imx708,cam1 | 
Allow one connection to DSI and one connection to CSI, for example, use IMX219 to connect to MIPI1
For example, if you want to connect a DSI display to MIPI0, add the following to the config.txt file
dtoverlay=imx219,cam1 dtoverlay=vc4-kms-dsi-7inch,dsi0

sudo reboot
libcamera-hello --list-cameras

libcamera-hello -t 0
libcamera-jpeg -o test.jpg
libcamera-vid -t 10000 -o test.h264
Other commands
Check if the camera is detected
libcamera-hello --list-cameras
Open the corresponding camera
libcamera-hello --camera 1 libcamera-hello --camera 0
Take a photo
libcamera-jpeg -o test.jpg #You can add --camera to specify the camera
There is no battery by default, and an additional RTC battery is required
The default device is /dev/rtc0
Regarding time, by inputting "date" in the command line, you can see the current time. Connecting the Raspberry Pi system to the network will automatically synchronize the time. If the default RTC device is connected and functioning properly, the RTC time will be updated after the automatic network synchronization
sudo hwclock -r Read the RTC time, if there are multiple RTC devices, you can use -f to select the corresponding devices (for example: sudo hwclock -f /dev/rtc1 -r)
System clock -> Hardware clock (RTC)
sudo hwclock -w
Synchronize hardware clock (RTC) -> System clock
sudo hwclock  -s
 #Need to turn off the network, or disable network time synchronization, otherwise it will be changed backSet the hardware clock time (RTC):
sudo hwclock --set --date="9/8/2023 16:45:05"View the hardware clock (RTC)
sudo hwclock -r
Show version information
sudo hwclock --verbose
To support a low-power mode for wake-up alarms, add the configuration:
sudo -E rpi-eeprom-config --edit
#Add the following 2 lines
POWER_OFF_ON_HALT=1
WAKE_ON_GPIO=0
#Restart the device after adding (if you connect to the serial port log, you can see that there are update related logs)
sudo reboot
#You can use the following methods to test the function:
echo +600 | sudo tee /sys/class/rtc/rtc0/wakealarm
sudo halt  or  sudo poweroff
#10 minutes later, it will be awakened and restartedNote: Before adding this, make sure your RTC battery allows charging and check the maximum allowable voltage
sudo nano /boot/firmware/config.txt
#Add
dtparam=rtc_bbat_vchg=3000000
#Among these, 3,000,000 represents the maximum voltage. Charging will stop when it reaches 3V, and the charging will restart with a trickle charge when the voltage drops below 3VCM5 Core board datasheet
CM5 Core board 3D
CM5 Core introduction
CM5-PoE-BASE-A Schematic diagram
CM5 requires the latest version of Raspberry Pi OS Bookworm (2024-11-19 or later).
Monday-Friday (9:30-6:30) Saturday (9:30-5:30)
Email: services01@spotpear.com