AMD Radeon PRO W7700 running on Raspberry Pi

Raspberry Pi 5 with AMD Radeon PRO W7700 graphics card

After years of work among a bunch of people in the Pi community (special callout to Coreforge!), we finally have multiple generations of AMD graphics cards working on the Raspberry Pi 5.

We recently got Polaris-era GPUs working (like the RX460), but in the past month we've gotten 6000 and 7000-series GPUs up and running. And many parts of the driver work at full performance—well, as much as can be had on the Raspberry Pi's single PCIe Gen 3 lane (8 GT/sec)!

I've been testing tons of modern AAA games, like Doom Eternal and Crysis Remastered, and can get 10-15 fps at 4K with Ray Tracing on, or 15-20 fps at 4K. Dropping down to 1080p is not enough to overcome the Pi's CPU bottleneck—only at resolutions under 720p does the Pi's CPU and the single PCIe lane not seem to get in the way quite as much.

Doom Eternal with RTX on Raspberry Pi 5

The screenshot above is showing some gameplay at 4K High settings, with ray tracing enabled. Not too shabby for a Raspberry Pi! Though the CPU and 8 GB of RAM holds back the GPU for modern AAA games.

Slightly older games like Portal 2 run at 4K 60fps with zero issues. Full acceleration, smooth gameplay, with only an occasional hiccup as an asset loads in.

I'll have more examples later, but first: I hate when someone shows you something cool, but doesn't show you how to do it yourself. So here's exactly how you can set up your own Pi 5 + AMD 7000-series graphics card:

How to use a Radeon 7000-series card with the Pi 5

  1. Clone the Raspberry Pi Linux kernel patching the default Raspberry Pi 6.6.y kernel tree with Coreforge's GPU-enablement patch (or just check out Coreforge's branch directly).
  2. Before compiling the kernel, run make menuconfig and select the options:
    1. Kernel Features > Page Size > 4 KB (for Box86 compatibility)
    2. Kernel Features > Kernel support for 32-bit EL0 > Fix up misaligned multi-word loads and stores in user space
    3. Kernel Features > Fix up misaligned loads and stores from userspace for 64bit code
    4. Device Drivers > Graphics support > AMD GPU (optionally SI/CIK support too)
    5. Device Drivers > Graphics support > Direct Rendering Manager (XFree86 4.1.0 and higher DRI support) > Force Architecture can write-combine memory
  3. Recompile the kernel following Raspberry Pi's instructions
  4. Install the AMD firmware (see note below)
  5. Reboot the Pi with the card attached using an appropriate PCIe riser and external ATX power supply.

AMD GPU Firmware for Pi OS 12 (Bookworm)

Because Pi OS 12 is based on Debian 12 Bookworm, and its firmware-amd-graphics package doesn't include the firmware for the latest-generation AMD cards, you have to install that package and download supplemental firmware files from the linux-firmware repo:

# Install the base AMD GPU firmware
sudo apt install -y firmware-amd-graphics

# Download supplemental firmware files for 7000-series cards
cd /usr/lib/firmware/amdgpu
sudo wget https://git.kernel.org/pub/scm/linux/kernel/git/firmware/linux-firmware.git/plain/amdgpu/psp_13_0_10_sos.bin & \
sudo wget https://git.kernel.org/pub/scm/linux/kernel/git/firmware/linux-firmware.git/plain/amdgpu/smu_13_0_10.bin & \
sudo wget https://git.kernel.org/pub/scm/linux/kernel/git/firmware/linux-firmware.git/plain/amdgpu/gc_11_0_3_pfp.bin & \
sudo wget https://git.kernel.org/pub/scm/linux/kernel/git/firmware/linux-firmware.git/plain/amdgpu/gc_11_0_3_mes_2.bin & \
sudo wget https://git.kernel.org/pub/scm/linux/kernel/git/firmware/linux-firmware.git/plain/amdgpu/gc_11_0_3_mes1.bin & \
sudo wget https://git.kernel.org/pub/scm/linux/kernel/git/firmware/linux-firmware.git/plain/amdgpu/psp_13_0_10_ta.bin & \
sudo wget https://git.kernel.org/pub/scm/linux/kernel/git/firmware/linux-firmware.git/plain/amdgpu/gc_11_0_3_me.bin & \
sudo wget https://git.kernel.org/pub/scm/linux/kernel/git/firmware/linux-firmware.git/plain/amdgpu/gc_11_0_3_rlc.bin & \
sudo wget https://git.kernel.org/pub/scm/linux/kernel/git/firmware/linux-firmware.git/plain/amdgpu/gc_11_0_3_mec.bin & \
sudo wget https://git.kernel.org/pub/scm/linux/kernel/git/firmware/linux-firmware.git/plain/amdgpu/gc_11_0_3_imu.bin & \
sudo wget https://git.kernel.org/pub/scm/linux/kernel/git/firmware/linux-firmware.git/plain/amdgpu/sdma_6_0_3.bin

Confirm everything is working by plugging a monitor into the graphics card; then confirm the card's GPU is in use by running glxinfo -B (part of the mesa-utils package), for example:

$ DISPLAY=:0 glxinfo -B
name of display: :0
display: :0  screen: 0
direct rendering: Yes
Extended renderer info (GLX_MESA_query_renderer):
    Vendor: AMD (0x1002)
    Device: AMD Radeon Pro W7700 (gfx1101, LLVM 15.0.6, DRM 3.54, 6.6.60-v8-AMDGPU+) (0x7470)
    Version: 23.2.1
    Accelerated: yes
    Video memory: 15360MB
...

(Prepend DISPLAY=:0 if you're running these commands over SSH.)

Hardware video transcoding support

If you want to enable hardware transcoding, you need to install the Mesa VAAPI drivers:

sudo apt install mesa-va-drivers vainfo

Then you should be able to see the VAAPI info, and apps like OBS (sudo apt install obs-studio) should be able to use the hardware transcoding instead of x264 running on the Pi's CPU. Confirm it's working with vainfo:

pi@pi5-pcie:~ $ vainfo
libva info: VA-API version 1.17.0
libva info: Trying to open /usr/lib/aarch64-linux-gnu/dri/radeonsi_drv_video.so
libva info: Found init function __vaDriverInit_1_17
libva info: va_openDriver() returns 0
vainfo: VA-API version: 1.17 (libva 2.12.0)
vainfo: Driver version: Mesa Gallium driver 23.2.1-1~bpo12+rpt3 for AMD Radeon Pro W7700 (gfx1101, LLVM 15.0.6, DRM 3.54, 6.6.60-v8-AMDGPU+)
vainfo: Supported profile and entrypoints
      VAProfileH264ConstrainedBaseline: VAEntrypointVLD
      VAProfileH264ConstrainedBaseline: VAEntrypointEncSlice
      VAProfileH264Main               : VAEntrypointVLD
      VAProfileH264Main               : VAEntrypointEncSlice
      VAProfileH264High               : VAEntrypointVLD
      VAProfileH264High               : VAEntrypointEncSlice
      VAProfileHEVCMain               : VAEntrypointVLD
      VAProfileHEVCMain               : VAEntrypointEncSlice
      VAProfileHEVCMain10             : VAEntrypointVLD
      VAProfileHEVCMain10             : VAEntrypointEncSlice
      VAProfileJPEGBaseline           : VAEntrypointVLD
      VAProfileVP9Profile0            : VAEntrypointVLD
      VAProfileVP9Profile2            : VAEntrypointVLD
      VAProfileAV1Profile0            : VAEntrypointVLD
      VAProfileAV1Profile0            : VAEntrypointEncSlice
      VAProfileNone                   : VAEntrypointVideoProc

Hardware

The exact hardware I used is listed below. Some of the links are Amazon affiliate links, but you can just search the text if you want to avoid the links ;)

Here's a list of all the hardware I used for my setup (some links are affiliate links):

What works

Portal 2 at 4K Max settings on Raspberry Pi 5

The patches are still not complete, but are very stable (I've had my setup running continuously for a few days at a time, with no lockups). Not everything works, but many things do:

  • Steam games (emulated via Box86/Proton): Doom Eternal, Crysis Remastered, Doom 3, Halo MCC (Halo 3), Minecraft Bedrock Edition, Obduction, Portal 2, SuperTuxKart, and the list goes on...
  • Multiple Monitors: I tested up to 6 displays, and could even have my two 4K displays at 4K while the others were at 1080p... however Pi OS's resolution scaling works best if all your monitors are at similar scales, so it can be frustrating optimizing for either 4K or 1080p!
  • Hardware Transcoding: At least when you're not bandwidth-constrained on the Pi's PCIe bus! Trying to capture the screen is tricky because of the dance the Pi needs to do between the compositor, system RAM/CPU, and the GPU. Apps like VLC and ffmpeg may need to be compiled to work correctly with VAAPI on the Pi 5—at least for now. Transcoding isn't perfect though...
  • OBS/Live Streaming: I was able to game at 4K and capture the display smoothly at 720p. But higher resolutions like 1080p or 4K would cause a lot of frame dropping. The display output was smooth, but the OBS stream got choppy. Probably a bandwidth issue (see previous bullet point).

Things that don't work

  • Hardware Transcoding: It works but can have issues (and on some cards, artifacts in the encoded stream). I also haven't had a chance to test with Jellyfin or Plex yet, but I'm hopeful it will 'just work.'
  • GPU-accelerated LLMs that require ROCm (or CUDA): There are some efforts to accelerate frameworks like Ollama and LM Studio with Vulkan (which is running great on the Pi 5... but those efforts usually target x86 and not Arm! I'm hopeful we can make headway here.
  • Steam games: Any games requiring anti-cheat, and some games that have weird code/launchers, like Red Dead Redemption 2. I also couldn't get Forza Horizon 4 to launch due to a lack of RAM, and Tomb Raider (2013) and Halo: Reach wouldn't launch for unknown reasons.
  • Cryptocurrency mining: Even if it did work, I wouldn't test it. I don't touch crypto with a 10 ft. pole, for a variety of reasons. (So please stop asking in DMs!)
  • Blender: So far I haven't been able to get Blender to run on arm64; the only time I've been successful is when running the x86 version on Windows on Arm on the Ampere Workstation—but that's far from optimal, and relied on brute-force emulation with the 128 core Altra Max CPU!

Patch Notes / Current Status

We're still working on the patches; it's kind of a side hobby for everyone involved, and people dip in and dip out to test various aspects of the patches over time.

If you want to get involved, take a look at the existing graphics cards in the database over on the Raspberry Pi PCIe website!

Demo

For some example gameplay footage at 4K, along with demos of multi-display work and OBS hardware encoding, check out my video on YouTube:

Comments

Hi Jeff, excellent work again!
Could you please fix the link in "We recently got Polaris-era GPUs working (like the RX460)," it give a 404 error currently

Great work. Funny thing is that GPU has twice as much memory as the Pi itself :)
Wish they would have exposed two PCI-E lanes instead of one... From what I have read (correct me if I'm wrong), the Broadcom chip has a total of 6 PCI-E lanes with 4 being used by RP1. I wonder what's the reason for not exposing both unused lanes. PCB routing ? Stability ? Power issues ?

When you save a png with higher res than 2K all machines on the planet struggle. This is not a problem with any particular hardware, it's a problem of humans expecting eternal growth. Computers are peaking for eternity right now, in many ways we allready peaked and it's going downhill (longevity down and price up). Time to go back and adopt less demanding things and write better software. I use TWM and am trying to not install a browser. It's hard, but it needs to be done. C64 is another thing that is taking off when people try to preserve sanity.

Hello ! Is this possible with a nvidia or MSI graphics card ? (I just want to test with a GT710)
Thank you in advance for the response.

Hey Jeff, could you try running the game 'THE FINALS' (its a free one avaliable on Steam) as it has a version avaliable for Linux via Proton and it might work quite nicely for you. Anyway, would you be up for trying a few games in an upcoming video?

Now that Blender 4.3 released with Vulkan support, you should definitely try running it again.

hi,

would a zimaboard (on intel cpu) be a better option for the same setup? Perhaps with radeon rx 7600 xt? O should I wait until the Nvidia Jetson Nano super is "buyable"?

KUTGW
Mario

Note that Debian backports has the newer firmware you need

Hi Jeff,

First, thanks for all the geek stuff you do and publish, its super appreciated! :-) (Old geek here, started using linux with MCC interim distribution over 30 years ago ;-) )

I'm trying to make a similar setup work, without success yet... I'm using an 8GB RPI5 with the same riser as you, and an ASUS RADEON 6700XT. I can see the card with lspci but can't make the driver work.

$ lspci
0000:00:00.0 PCI bridge: Broadcom Inc. and subsidiaries BCM2712 PCIe Bridge (rev 21)
0000:01:00.0 PCI bridge: Advanced Micro Devices, Inc. [AMD/ATI] Navi 10 XL Upstream Port of PCI Express Switch (rev c1)
0000:02:00.0 PCI bridge: Advanced Micro Devices, Inc. [AMD/ATI] Navi 10 XL Downstream Port of PCI Express Switch
0000:03:00.0 VGA compatible controller: Advanced Micro Devices, Inc. [AMD/ATI] Navi 22 [Radeon RX 6700/6700 XT/6750 XT / 6800M/6850M XT] (rev c1)
0000:03:00.1 Audio device: Advanced Micro Devices, Inc. [AMD/ATI] Navi 21/23 HDMI/DP Audio Controller
0001:00:00.0 PCI bridge: Broadcom Inc. and subsidiaries BCM2712 PCIe Bridge (rev 21)
0001:01:00.0 Ethernet controller: Raspberry Pi Ltd RP1 PCIe 2.0 South Bridge

Here's the problem from dmesg :

$ dmesg | grep amdgpu
[    2.757936] [drm] amdgpu kernel modesetting enabled.
[    2.758160] amdgpu 0000:03:00.0: enabling device (0000 -> 0002)
[    2.758301] [drm:amdgpu_discovery_set_ip_blocks [amdgpu]] *ERROR* amdgpu_discovery_init failed
[    2.767694] amdgpu 0000:03:00.0: amdgpu: Fatal error during GPU init
[    2.774085] amdgpu 0000:03:00.0: amdgpu: amdgpu: finishing device.
[    2.774101] amdgpu: probe of 0000:03:00.0 failed with error -22

I tried the 6.6.y-gpu branch, the 6.7.y-gpu, tried building as modules, directly in the kernel, on the PI, cross-compiled, played with a few different options, no luck.

There's one thing tho : I haven't been able to find two of the kernel options you're mentioning, either in menuconfig or in .config directly : - Kernel Features > Fix up misaligned loads and stores from userspace for 64bit code - Device Drivers > Graphics support > Direct Rendering Manager (XFree86 4.1.0 and higher DRI support) > Force Architecture can write-combine memory

Also, little detail : if someone follows these instructions blindly, when doing the step "build the kernel according to raspberry pi's instructions", the customized .config will be overwritten when running "make bcm2712_defconfig" ;-)

Thanks!

Ah, I think it's an order of operations thing then:

  1. Build the kernel according to Pi instructions up to and including make bcm2712_defconfig.
  2. Make your customizations with make menuconfig and save them.
  3. Finish building the kernel, then reboot.

And if you're not seeing those changes, are you sure you're using Coreforge's fork/branch of the kernel, and not the upstream raspberrypi/linux tree?

Thanks for the quick reply!

I did the operations in the right order as you suggest, no worry ;-) Just mentioned it in case someone else misses it.

I cloned the Coreforge repo, on the right branch (tried both 6.6.y-gpu and 6.7.y-gpu)

$ git clone --depth=1 --branch rpi-6.7.y-gpu  https://github.com/Coreforge/linux.git
stremblay:~/work/linux$ git branch
* rpi-6.7.y-gpu

Used a custom name for my kernel, confirmed it with uname -a, confirmed the modules are loaded with lsmod, unable to make it work. The card spins its fans, but I never get any display and dmesg confirms that the driver has an issue.

I also tried to rebuild memcpy.so as I found in some instructions I don't remember where

160  wget https://gist.githubusercontent.com/Coreforge/91da3d410ec7eb0ef5bc8dee24b91359/raw/b4848d1da9fff0cfcf7b601713efac1909e408e8/memcpy_unaligned.c
161  gcc -shared -fPIC -o memcpy.so memcpy_unaligned.c
162  sudo mv memcpy.so /usr/local/lib/memcpy.so
163  sudo vi /etc/ld.so.preload

nomatter what, always the same result:

stremblay@rpi5:~ $ dmesg | grep amdgpu
[    2.683839] [drm] amdgpu kernel modesetting enabled.
[    2.687791] amdgpu 0000:03:00.0: enabling device (0000 -> 0002)
[    2.688404] [drm:amdgpu_discovery_set_ip_blocks [amdgpu]] *ERROR* amdgpu_discovery_init failed
[    2.698837] amdgpu 0000:03:00.0: amdgpu: Fatal error during GPU init
[    2.706551] amdgpu 0000:03:00.0: amdgpu: amdgpu: finishing device.
[    2.707435] amdgpu: probe of 0000:03:00.0 failed with error -22

Really puzzled...!

Thanks,

Sylvain