About Social Code
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorLucas Fryzek <lucas.fryzek@fryzekconcepts.com>2024-07-02 08:49:23 +0100
committerLucas Fryzek <lucas.fryzek@fryzekconcepts.com>2024-07-02 08:49:23 +0100
commit56b2c6263189f5783aad0cd39aaf174088e04670 (patch)
tree1ff25ac05c3dc810c9387a476dc0035b667a175d
parent4487b7797f5a601ad68c8e81d5c7714f46abe0f8 (diff)
android_swrast: Publish note
-rw-r--r--html/feed.xml180
-rw-r--r--html/graphics_feed.xml168
-rw-r--r--html/index.html8
-rw-r--r--html/notes/android_swrast.html205
4 files changed, 543 insertions, 18 deletions
diff --git a/html/feed.xml b/html/feed.xml
index d1e1870..ef2698a 100644
--- a/html/feed.xml
+++ b/html/feed.xml
@@ -1,5 +1,5 @@
<?xml version='1.0' encoding='UTF-8'?>
-<rss xmlns:atom="http://www.w3.org/2005/Atom" version="2.0"><channel><title>Fryzek Concepts</title><atom:link href="https://fryzekconcepts.com/feed.xml" rel="self" type="application/rss+xml"/><link>https://fryzekconcepts.com</link><description>Lucas is a developer working on cool things</description><lastBuildDate>Wed, 14 Feb 2024 13:30:36 -0000</lastBuildDate><item><title>Generating Video</title><link>https://fryzekconcepts.com/notes/generating-video.html</link><description>&lt;p&gt;One thing I’m very interested in is computer graphics. This could be
+<rss xmlns:atom="http://www.w3.org/2005/Atom" version="2.0"><channel><title>Fryzek Concepts</title><atom:link href="https://fryzekconcepts.com/feed.xml" rel="self" type="application/rss+xml"/><link>https://fryzekconcepts.com</link><description>Lucas is a developer working on cool things</description><lastBuildDate>Tue, 02 Jul 2024 07:46:54 -0000</lastBuildDate><item><title>Generating Video</title><link>https://fryzekconcepts.com/notes/generating-video.html</link><description>&lt;p&gt;One thing I’m very interested in is computer graphics. This could be
complex 3D graphics or simple 2D graphics. The idea of getting a
computer to display visual data fascinates me. One fundamental part of
showing visual data is interfacing with a computer monitor. This can be
@@ -578,7 +578,7 @@ applied to any FPGA and any connector that uses a video signal like
this. For example you could wire up a DAC with a resistor ladder to
generate a VGA signal. The logic for the timings here would be exactly
the same if you wanted a 640x480@60 Hz VGA signal.&lt;/p&gt;
-</description><pubDate>Tue, 07 Apr 2020 04:00:00 -0000</pubDate><guid>https://fryzekconcepts.com/notes/generating-video.html</guid></item><item><title>N64Brew GameJam 2021</title><link>https://fryzekconcepts.com/notes/n64brew-gamejam-2021.html</link><description>&lt;p&gt;So this year, myself and two others decided to participate together
+</description><pubDate>Mon, 06 Apr 2020 23:00:00 -0000</pubDate><guid>https://fryzekconcepts.com/notes/generating-video.html</guid></item><item><title>N64Brew GameJam 2021</title><link>https://fryzekconcepts.com/notes/n64brew-gamejam-2021.html</link><description>&lt;p&gt;So this year, myself and two others decided to participate together
in the N64Brew homebrew GameJam, where we were supposed to build a
homebrew game that would run on a real Nintendo 64. The game jam took
place from October 8th until December 8th and was the second GameJam in
@@ -718,7 +718,7 @@ modern N64 Flashcarts for networking, allowing the N64 to have online
multiplayer through a computer connected over USB. I feel that projects
like this could really elevate the kind of content that is available on
the N64 and bring it into the modern era.&lt;/p&gt;
-</description><pubDate>Fri, 10 Dec 2021 05:00:00 -0000</pubDate><guid>https://fryzekconcepts.com/notes/n64brew-gamejam-2021.html</guid></item><item><title>Rasterizing Triangles</title><link>https://fryzekconcepts.com/notes/rasterizing-triangles.html</link><description>&lt;p&gt;Lately I’ve been trying to implement a software renderer &lt;a
+</description><pubDate>Fri, 10 Dec 2021 00:00:00 -0000</pubDate><guid>https://fryzekconcepts.com/notes/n64brew-gamejam-2021.html</guid></item><item><title>Rasterizing Triangles</title><link>https://fryzekconcepts.com/notes/rasterizing-triangles.html</link><description>&lt;p&gt;Lately I’ve been trying to implement a software renderer &lt;a
href="https://www.cs.drexel.edu/~david/Classes/Papers/comp175-06-pineda.pdf"&gt;following
the algorithm described by Juan Pineda in “A Parallel Algorithm for
Polygon Rasterization”&lt;/a&gt;. For those unfamiliar with the paper, it
@@ -887,7 +887,7 @@ point arithmetic, be careful to insure you have enough precision to
calculate all of these values with overflow or underflow. This was an
issue I ran into running out of precision when I did the divide by the
area.&lt;/p&gt;
-</description><pubDate>Sun, 03 Apr 2022 04:00:00 -0000</pubDate><guid>https://fryzekconcepts.com/notes/rasterizing-triangles.html</guid></item><item><title>Baremetal RISC-V</title><link>https://fryzekconcepts.com/notes/baremetal-risc-v.html</link><description>&lt;p&gt;After re-watching suckerpinch’s &lt;a
+</description><pubDate>Sat, 02 Apr 2022 23:00:00 -0000</pubDate><guid>https://fryzekconcepts.com/notes/rasterizing-triangles.html</guid></item><item><title>Baremetal RISC-V</title><link>https://fryzekconcepts.com/notes/baremetal-risc-v.html</link><description>&lt;p&gt;After re-watching suckerpinch’s &lt;a
href="https://www.youtube.com/watch?v=ar9WRwCiSr0"&gt;“Reverse
Emulation”&lt;/a&gt; video I got inspired to try and replicate what he did,
but instead do it on an N64. Now my idea here is not to preform reverse
@@ -1113,7 +1113,7 @@ emulating the N64 cartridge bus which will require me to get GPIO
working as well as interrupts on the GPIO lines. If you want to see the
current progress of my work you can check it out on github &lt;a
href="https://github.com/Hazematman/N64-Cart-Emulator"&gt;here&lt;/a&gt;.&lt;/p&gt;
-</description><pubDate>Thu, 09 Jun 2022 04:00:00 -0000</pubDate><guid>https://fryzekconcepts.com/notes/baremetal-risc-v.html</guid></item><item><title>Digital Garden</title><link>https://fryzekconcepts.com/notes/digital_garden.html</link><description>&lt;p&gt;After reading Maggie Appleton page on &lt;a
+</description><pubDate>Wed, 08 Jun 2022 23:00:00 -0000</pubDate><guid>https://fryzekconcepts.com/notes/baremetal-risc-v.html</guid></item><item><title>Digital Garden</title><link>https://fryzekconcepts.com/notes/digital_garden.html</link><description>&lt;p&gt;After reading Maggie Appleton page on &lt;a
href="https://maggieappleton.com/garden-history"&gt;digital gardens&lt;/a&gt; I
was inspired to convert my own website into a digital garden.&lt;/p&gt;
&lt;p&gt;I have many half baked ideas that I seem to be able to finish. Some
@@ -1134,7 +1134,7 @@ has not been totally developed yet and right now it just provides with a
convenient way to link to other notes or pages on this site.&lt;/p&gt;
&lt;p&gt;I hope to develop this section more and explain how I got various
features in pandoc to work as a static site generator.&lt;/p&gt;
-</description><pubDate>Sun, 30 Oct 2022 04:00:00 -0000</pubDate><guid>https://fryzekconcepts.com/notes/digital_garden.html</guid></item><item><title>2022 Graphics Team Contributions at Igalia</title><link>https://fryzekconcepts.com/notes/2022_igalia_graphics_team.html</link><description>&lt;p&gt;This year I started a new job working with &lt;a
+</description><pubDate>Sat, 29 Oct 2022 23:00:00 -0000</pubDate><guid>https://fryzekconcepts.com/notes/digital_garden.html</guid></item><item><title>2022 Graphics Team Contributions at Igalia</title><link>https://fryzekconcepts.com/notes/2022_igalia_graphics_team.html</link><description>&lt;p&gt;This year I started a new job working with &lt;a
href="https://www.igalia.com/technology/graphics"&gt;Igalia’s Graphics
Team&lt;/a&gt;. For those of you who don’t know &lt;a
href="https://www.igalia.com/"&gt;Igalia&lt;/a&gt; they are a &lt;a
@@ -1394,7 +1394,7 @@ Atlantic!&lt;/a&gt;&lt;/p&gt;
alt="Photo of A Coruña" /&gt;
&lt;figcaption aria-hidden="true"&gt;Photo of A Coruña&lt;/figcaption&gt;
&lt;/figure&gt;
-</description><pubDate>Thu, 02 Feb 2023 05:00:00 -0000</pubDate><guid>https://fryzekconcepts.com/notes/2022_igalia_graphics_team.html</guid></item><item><title>Global Game Jam 2023 - GI Jam</title><link>https://fryzekconcepts.com/notes/global_game_jam_2023.html</link><description>&lt;p&gt;At the beginning of this month I participated in the Games
+</description><pubDate>Thu, 02 Feb 2023 00:00:00 -0000</pubDate><guid>https://fryzekconcepts.com/notes/2022_igalia_graphics_team.html</guid></item><item><title>Global Game Jam 2023 - GI Jam</title><link>https://fryzekconcepts.com/notes/global_game_jam_2023.html</link><description>&lt;p&gt;At the beginning of this month I participated in the Games
Institutes’s Global Game Jam event. &lt;a
href="https://uwaterloo.ca/games-institute/"&gt;The Games Institute&lt;/a&gt; is
an organization at my local university (The University of Waterloo) that
@@ -1497,7 +1497,7 @@ of lack of personal motivation, poor team dynamics, and other factors,
none of those game jams panned out. This was the first game jam in a
while where I feel like I really connected with my team and I also feel
like we made a super polished and fun game in the end.&lt;/p&gt;
-</description><pubDate>Sat, 11 Feb 2023 05:00:00 -0000</pubDate><guid>https://fryzekconcepts.com/notes/global_game_jam_2023.html</guid></item><item><title>Journey Through Freedreno</title><link>https://fryzekconcepts.com/notes/freedreno_journey.html</link><description>&lt;figure&gt;
+</description><pubDate>Sat, 11 Feb 2023 00:00:00 -0000</pubDate><guid>https://fryzekconcepts.com/notes/global_game_jam_2023.html</guid></item><item><title>Journey Through Freedreno</title><link>https://fryzekconcepts.com/notes/freedreno_journey.html</link><description>&lt;figure&gt;
&lt;img src="/assets/freedreno/glinfo_freedreno.png"
alt="Android running Freedreno" /&gt;
&lt;figcaption aria-hidden="true"&gt;Android running Freedreno&lt;/figcaption&gt;
@@ -1707,7 +1707,7 @@ MR&lt;/a&gt;.&lt;/p&gt;
alt="Freedreno running 3d-mark" /&gt;
&lt;figcaption aria-hidden="true"&gt;Freedreno running 3d-mark&lt;/figcaption&gt;
&lt;/figure&gt;
-</description><pubDate>Tue, 28 Feb 2023 05:00:00 -0000</pubDate><guid>https://fryzekconcepts.com/notes/freedreno_journey.html</guid></item><item><title>Igalia’s Mesa 23.1 Contributions - Behind the Scenes</title><link>https://fryzekconcepts.com/notes/mesa_23_1_contributions_behind_the_scenes.html</link><description>&lt;p&gt;It’s an exciting time for Mesa as its next major release is unveiled
+</description><pubDate>Tue, 28 Feb 2023 00:00:00 -0000</pubDate><guid>https://fryzekconcepts.com/notes/freedreno_journey.html</guid></item><item><title>Igalia’s Mesa 23.1 Contributions - Behind the Scenes</title><link>https://fryzekconcepts.com/notes/mesa_23_1_contributions_behind_the_scenes.html</link><description>&lt;p&gt;It’s an exciting time for Mesa as its next major release is unveiled
this week. Igalia has played an important role in this milestone, with
Eric Engestrom managing the release and 11 other Igalians contributing
over 110 merge requests. A sample of these contributions are detailed
@@ -1790,7 +1790,7 @@ href="https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/21558"&gt;https:
&lt;li&gt;&lt;a
href="https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/20180"&gt;https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/20180&lt;/a&gt;&lt;/li&gt;
&lt;/ul&gt;
-</description><pubDate>Thu, 11 May 2023 04:00:00 -0000</pubDate><guid>https://fryzekconcepts.com/notes/mesa_23_1_contributions_behind_the_scenes.html</guid></item><item><title>Converting from 3D to 2D</title><link>https://fryzekconcepts.com/notes/converting_from_3d_to_2d.html</link><description>&lt;p&gt;Recently I’ve been working on a project where I needed to convert an
+</description><pubDate>Wed, 10 May 2023 23:00:00 -0000</pubDate><guid>https://fryzekconcepts.com/notes/mesa_23_1_contributions_behind_the_scenes.html</guid></item><item><title>Converting from 3D to 2D</title><link>https://fryzekconcepts.com/notes/converting_from_3d_to_2d.html</link><description>&lt;p&gt;Recently I’ve been working on a project where I needed to convert an
application written in OpenGL to a software renderer. The matrix
transformation code in OpenGL made use of the GLM library for matrix
math, and I needed to convert the 4x4 matrices to be 3x3 matrices to
@@ -1902,7 +1902,7 @@ application when moving from a “3D homogeneous space” to a “2D
homogeneous space”.&lt;/p&gt;
&lt;p&gt;Hopefully this explanation helps if you are every working on
converting 3D transformation code to 2D.&lt;/p&gt;
-</description><pubDate>Mon, 25 Sep 2023 04:00:00 -0000</pubDate><guid>https://fryzekconcepts.com/notes/converting_from_3d_to_2d.html</guid></item><item><title>A Dive into Vulkanised 2024</title><link>https://fryzekconcepts.com/notes/vulkanised_2024.html</link><description>&lt;figure&gt;
+</description><pubDate>Sun, 24 Sep 2023 23:00:00 -0000</pubDate><guid>https://fryzekconcepts.com/notes/converting_from_3d_to_2d.html</guid></item><item><title>A Dive into Vulkanised 2024</title><link>https://fryzekconcepts.com/notes/vulkanised_2024.html</link><description>&lt;figure&gt;
&lt;img src="/assets/vulkanised_2024/vulkanized_logo_web.jpg"
alt="Vulkanised sign at google’s office" /&gt;
&lt;figcaption aria-hidden="true"&gt;Vulkanised sign at google’s
@@ -2012,4 +2012,160 @@ Area!&lt;/p&gt;
alt="Great bay area food" /&gt;
&lt;figcaption aria-hidden="true"&gt;Great bay area food&lt;/figcaption&gt;
&lt;/figure&gt;
-</description><pubDate>Wed, 14 Feb 2024 05:00:00 -0000</pubDate><guid>https://fryzekconcepts.com/notes/vulkanised_2024.html</guid></item></channel></rss> \ No newline at end of file
+</description><pubDate>Wed, 14 Feb 2024 00:00:00 -0000</pubDate><guid>https://fryzekconcepts.com/notes/vulkanised_2024.html</guid></item><item><title>Software Rendering and Android</title><link>https://fryzekconcepts.com/notes/android_swrast.html</link><description>&lt;p&gt;My current project at Igalia has had me working on Mesa’s software
+renderers, llvmpipe and lavapipe. I’ve been working to get them running
+on Android, and I wanted to document the progress I’ve made, the
+challenges I’ve faced, and talk a little bit about the development
+process for a project like this. My work is not totally merged into
+upstream mesa yet, but you can see the MRs I made here:&lt;/p&gt;
+&lt;ul&gt;
+&lt;li&gt;&lt;a
+href="https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/29344"&gt;MR
+!29344&lt;/a&gt;&lt;/li&gt;
+&lt;li&gt;&lt;a
+href="https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/29785"&gt;MR
+!29785&lt;/a&gt;&lt;/li&gt;
+&lt;li&gt;&lt;a
+href="https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/27805"&gt;MR
+!27805&lt;/a&gt;&lt;/li&gt;
+&lt;li&gt;&lt;a
+href="https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/28735"&gt;MR
+!28735&lt;/a&gt;&lt;/li&gt;
+&lt;/ul&gt;
+&lt;h2 id="setting-up-an-android-development-environment"&gt;Setting up an
+Android development environment&lt;/h2&gt;
+&lt;p&gt;Getting system level software to build and run on Android is
+unfortunately not straightforward. Since we are doing software rendering
+we don’t need a physical device and instead we can make use of the
+Android emulator, and if you didn’t know Android has two emulators, the
+common one most people use is “goldfish” and the other lesser known is
+“cuttlefish”. For this project I did my work on the cuttlefish emulator
+as its meant for testing the Android OS itself instead of just Android
+apps and is more reflective of real hardware. The cuttlefish emulator
+takes a little bit more work to setup, and I’ve found that it only works
+properly in Debian based linux distros. I run Fedora, so I had to run
+the emulator in a debian VM.&lt;/p&gt;
+&lt;p&gt;Thankfully Google has good instructions for building and running
+cuttlefish, which you can find &lt;a
+href="https://source.android.com/docs/devices/cuttlefish/get-started"&gt;here&lt;/a&gt;.
+The instructions show you how to setup the emulator using nightly build
+images from Google. We’ll also need to setup our own Android OS images
+so after we’ve confirmed we can run the emulator, we need to start
+looking at building AOSP.&lt;/p&gt;
+&lt;p&gt;For building our own AOSP image, we can also follow the instructions
+from Google &lt;a
+href="https://source.android.com/docs/setup/build/building"&gt;here&lt;/a&gt;.
+For the target we’ll want
+&lt;code&gt;aosp_cf_x86_64_phone-trunk_staging-eng&lt;/code&gt;. At this point it’s
+a good idea to verify that you can build the image, which you can do by
+following the rest of the instructions on the page. Building AOSP from
+source does take a while though, so prepare to wait potentially an
+entire day for the image to build. Also if you get errors complaining
+that you’re out of memory, you can try to reduce the number of parallel
+builds. Google officially recommends to have 64GB of RAM, and I only had
+32GB so some packages had to be built with the parallel builds set to 1
+so I wouldn’t run out of RAM.&lt;/p&gt;
+&lt;p&gt;For running this custom-built image on Cuttlefish, you can just copy
+all the &lt;code&gt;*.img&lt;/code&gt; files from
+&lt;code&gt;out/target/product/vsoc_x86_64/&lt;/code&gt; to the root cuttlefish
+directory, and then launch cuttlefish. If everything worked successfully
+you should be able to see your custom built AOSP image running in the
+cuttlefish webui.&lt;/p&gt;
+&lt;h2 id="building-mesa-targeting-android"&gt;Building Mesa targeting
+Android&lt;/h2&gt;
+&lt;p&gt;Working from the changes in MR &lt;a
+href="https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/29344"&gt;!29344&lt;/a&gt;
+building llvmpipe or lavapipe targeting Android should just work™️. To
+get to that stage required a few changes. First llvmpipe actually
+already had some support on Android, as long as it was running on a
+device that supports a DRM display driver. In that case it could use the
+&lt;code&gt;dri&lt;/code&gt; window system integration which already works on
+Android. I wanted to get llvmpipe (and lavapipe) running without dri, so
+I had to add support for Android in the &lt;code&gt;drisw&lt;/code&gt; window system
+integration.&lt;/p&gt;
+&lt;p&gt;To support Android in &lt;code&gt;drisw&lt;/code&gt;, this mainly meant adding
+support for importing dmabuf as framebuffers. The Android windowing
+system will provide us with a “gralloc” buffer which inside has a dmabuf
+fd that represents the framebuffer. Adding support for importing dmabufs
+in drisw means we can import and begin drawing to these frame buffers.
+Most the changes to support that can be found in &lt;a
+href="https://gitlab.freedesktop.org/mesa/mesa/-/blob/9705df53408777d493eab19e5a58c432c1e75acb/src/gallium/frontends/dri/drisw.c#L405"&gt;&lt;code&gt;drisw_allocate_textures&lt;/code&gt;&lt;/a&gt;
+and the underlying changes to llvmpipe to support importing dmabufs in
+MR &lt;a
+href="https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/27805"&gt;!27805&lt;/a&gt;.
+The EGL Android platform code also needed some changes to use the
+&lt;code&gt;drisw&lt;/code&gt; window system code. Previously this code would only
+work with true dri drivers, but with some small tweaks it was possible
+to get to have it initialize the drisw window system and then using it
+for rendering if no hardware devices are available.&lt;/p&gt;
+&lt;p&gt;For lavapipe the changes were a lot simpler. The Android Vulkan
+loader requires your driver to have &lt;code&gt;HAL_MODULE_INFO_SYM&lt;/code&gt;
+symbol in the binary, so that got created and populated correctly,
+following other Vulkan drivers in Mesa like turnip. Then the image
+creation code had to be modified to support the
+&lt;code&gt;VK_ANDROID_native_buffer&lt;/code&gt; extension which allows the Android
+Vulkan loader to create images using Android native buffer handles.
+Under the hood this means getting the dmabuf fd from the native buffer
+handle. Thankfully mesa already has some common code to handle this, so
+I could just use that. Some other small changes were also necessary to
+address crashes and other failures that came up during testing.&lt;/p&gt;
+&lt;p&gt;With the changes out of of the way we can now start building Mesa on
+Android. For this project I had to update the Android documentation for
+Mesa to include steps for building LLVM for Android since the version
+Google ships with the NDK is missing libraries that llvmpipe/lavapipe
+need to function. You can see the updated documentation &lt;a
+href="https://gitlab.freedesktop.org/mesa/mesa/-/blob/9705df53408777d493eab19e5a58c432c1e75acb/docs/drivers/llvmpipe.rst"&gt;here&lt;/a&gt;
+and &lt;a
+href="https://gitlab.freedesktop.org/mesa/mesa/-/blob/9705df53408777d493eab19e5a58c432c1e75acb/docs/android.rst"&gt;here&lt;/a&gt;.
+After sorting out LLVM, building llvmpipe/lavapipe is the same as
+building any other Mesa driver for Android: we setup a cross file to
+tell meson how to cross compile and then we run meson. At this point you
+could manual modify the Android image and copy these files to the vm,
+but I also wanted to support building a new AOSP image directly
+including the driver. In order to do that you also have to rename the
+driver binaries to match Android’s naming convention, and make sure
+SO_NAME matches as well. If you check out &lt;a
+href="https://gitlab.freedesktop.org/mesa/mesa/-/blob/9705df53408777d493eab19e5a58c432c1e75acb/docs/android.rst?plain=1#L183"&gt;this&lt;/a&gt;
+section of the documentation I wrote, it covers how to do that.&lt;/p&gt;
+&lt;p&gt;If you followed all of that you should have built an version of
+llvmpipe and lavapipe that you can run on Android’s cuttlefish
+emulator.&lt;/p&gt;
+&lt;figure&gt;
+&lt;img src="/assets/2024-06-27-android-swrast/lavapipe.png"
+alt="Android running lavapipe" /&gt;
+&lt;figcaption aria-hidden="true"&gt;Android running lavapipe&lt;/figcaption&gt;
+&lt;/figure&gt;
+&lt;h2 id="references"&gt;References&lt;/h2&gt;
+&lt;ul&gt;
+&lt;li&gt;&lt;a
+href="https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/29344"
+class="uri"&gt;https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/29344&lt;/a&gt;
+&lt;ul&gt;
+&lt;li&gt;Main MR with Android changes&lt;/li&gt;
+&lt;/ul&gt;&lt;/li&gt;
+&lt;li&gt;&lt;a
+href="https://source.android.com/docs/devices/cuttlefish/get-started"
+class="uri"&gt;https://source.android.com/docs/devices/cuttlefish/get-started&lt;/a&gt;
+&lt;ul&gt;
+&lt;li&gt;Google’s official guide for getting started with the Cuttlefish
+emulator&lt;/li&gt;
+&lt;/ul&gt;&lt;/li&gt;
+&lt;li&gt;&lt;a href="https://source.android.com/docs/setup/build/building"
+class="uri"&gt;https://source.android.com/docs/setup/build/building&lt;/a&gt;
+&lt;ul&gt;
+&lt;li&gt;Google’s official guide for building AOSP images&lt;/li&gt;
+&lt;/ul&gt;&lt;/li&gt;
+&lt;li&gt;&lt;a
+href="https://gitlab.freedesktop.org/mesa/mesa/-/blob/9705df53408777d493eab19e5a58c432c1e75acb/docs/drivers/llvmpipe.rst"
+class="uri"&gt;https://gitlab.freedesktop.org/mesa/mesa/-/blob/9705df53408777d493eab19e5a58c432c1e75acb/docs/drivers/llvmpipe.rst&lt;/a&gt;
+&lt;ul&gt;
+&lt;li&gt;My updated documentation in MR for llvmpipe&lt;/li&gt;
+&lt;/ul&gt;&lt;/li&gt;
+&lt;li&gt;&lt;a
+href="https://gitlab.freedesktop.org/mesa/mesa/-/blob/9705df53408777d493eab19e5a58c432c1e75acb/docs/android.rst"
+class="uri"&gt;https://gitlab.freedesktop.org/mesa/mesa/-/blob/9705df53408777d493eab19e5a58c432c1e75acb/docs/android.rst&lt;/a&gt;
+&lt;ul&gt;
+&lt;li&gt;My updated documentation in MR for Android integration in mesa&lt;/li&gt;
+&lt;/ul&gt;&lt;/li&gt;
+&lt;/ul&gt;
+</description><pubDate>Wed, 26 Jun 2024 23:00:00 -0000</pubDate><guid>https://fryzekconcepts.com/notes/android_swrast.html</guid></item></channel></rss> \ No newline at end of file
diff --git a/html/graphics_feed.xml b/html/graphics_feed.xml
index 82dc7d9..c2c8ebf 100644
--- a/html/graphics_feed.xml
+++ b/html/graphics_feed.xml
@@ -1,5 +1,5 @@
<?xml version='1.0' encoding='UTF-8'?>
-<rss xmlns:atom="http://www.w3.org/2005/Atom" version="2.0"><channel><title>Fryzek Concepts</title><atom:link href="https://fryzekconcepts.com/feed.xml" rel="self" type="application/rss+xml"/><link>https://fryzekconcepts.com</link><description>Lucas is a developer working on cool things</description><lastBuildDate>Wed, 14 Feb 2024 13:30:37 -0000</lastBuildDate><item><title>2022 Graphics Team Contributions at Igalia</title><link>https://fryzekconcepts.com/notes/2022_igalia_graphics_team.html</link><description>&lt;p&gt;This year I started a new job working with &lt;a
+<rss xmlns:atom="http://www.w3.org/2005/Atom" version="2.0"><channel><title>Fryzek Concepts</title><atom:link href="https://fryzekconcepts.com/feed.xml" rel="self" type="application/rss+xml"/><link>https://fryzekconcepts.com</link><description>Lucas is a developer working on cool things</description><lastBuildDate>Tue, 02 Jul 2024 07:46:55 -0000</lastBuildDate><item><title>2022 Graphics Team Contributions at Igalia</title><link>https://fryzekconcepts.com/notes/2022_igalia_graphics_team.html</link><description>&lt;p&gt;This year I started a new job working with &lt;a
href="https://www.igalia.com/technology/graphics"&gt;Igalia’s Graphics
Team&lt;/a&gt;. For those of you who don’t know &lt;a
href="https://www.igalia.com/"&gt;Igalia&lt;/a&gt; they are a &lt;a
@@ -259,7 +259,7 @@ Atlantic!&lt;/a&gt;&lt;/p&gt;
alt="Photo of A Coruña" /&gt;
&lt;figcaption aria-hidden="true"&gt;Photo of A Coruña&lt;/figcaption&gt;
&lt;/figure&gt;
-</description><pubDate>Thu, 02 Feb 2023 05:00:00 -0000</pubDate><guid>https://fryzekconcepts.com/notes/2022_igalia_graphics_team.html</guid></item><item><title>Journey Through Freedreno</title><link>https://fryzekconcepts.com/notes/freedreno_journey.html</link><description>&lt;figure&gt;
+</description><pubDate>Thu, 02 Feb 2023 00:00:00 -0000</pubDate><guid>https://fryzekconcepts.com/notes/2022_igalia_graphics_team.html</guid></item><item><title>Journey Through Freedreno</title><link>https://fryzekconcepts.com/notes/freedreno_journey.html</link><description>&lt;figure&gt;
&lt;img src="/assets/freedreno/glinfo_freedreno.png"
alt="Android running Freedreno" /&gt;
&lt;figcaption aria-hidden="true"&gt;Android running Freedreno&lt;/figcaption&gt;
@@ -469,7 +469,7 @@ MR&lt;/a&gt;.&lt;/p&gt;
alt="Freedreno running 3d-mark" /&gt;
&lt;figcaption aria-hidden="true"&gt;Freedreno running 3d-mark&lt;/figcaption&gt;
&lt;/figure&gt;
-</description><pubDate>Tue, 28 Feb 2023 05:00:00 -0000</pubDate><guid>https://fryzekconcepts.com/notes/freedreno_journey.html</guid></item><item><title>Igalia’s Mesa 23.1 Contributions - Behind the Scenes</title><link>https://fryzekconcepts.com/notes/mesa_23_1_contributions_behind_the_scenes.html</link><description>&lt;p&gt;It’s an exciting time for Mesa as its next major release is unveiled
+</description><pubDate>Tue, 28 Feb 2023 00:00:00 -0000</pubDate><guid>https://fryzekconcepts.com/notes/freedreno_journey.html</guid></item><item><title>Igalia’s Mesa 23.1 Contributions - Behind the Scenes</title><link>https://fryzekconcepts.com/notes/mesa_23_1_contributions_behind_the_scenes.html</link><description>&lt;p&gt;It’s an exciting time for Mesa as its next major release is unveiled
this week. Igalia has played an important role in this milestone, with
Eric Engestrom managing the release and 11 other Igalians contributing
over 110 merge requests. A sample of these contributions are detailed
@@ -552,7 +552,7 @@ href="https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/21558"&gt;https:
&lt;li&gt;&lt;a
href="https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/20180"&gt;https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/20180&lt;/a&gt;&lt;/li&gt;
&lt;/ul&gt;
-</description><pubDate>Thu, 11 May 2023 04:00:00 -0000</pubDate><guid>https://fryzekconcepts.com/notes/mesa_23_1_contributions_behind_the_scenes.html</guid></item><item><title>Converting from 3D to 2D</title><link>https://fryzekconcepts.com/notes/converting_from_3d_to_2d.html</link><description>&lt;p&gt;Recently I’ve been working on a project where I needed to convert an
+</description><pubDate>Wed, 10 May 2023 23:00:00 -0000</pubDate><guid>https://fryzekconcepts.com/notes/mesa_23_1_contributions_behind_the_scenes.html</guid></item><item><title>Converting from 3D to 2D</title><link>https://fryzekconcepts.com/notes/converting_from_3d_to_2d.html</link><description>&lt;p&gt;Recently I’ve been working on a project where I needed to convert an
application written in OpenGL to a software renderer. The matrix
transformation code in OpenGL made use of the GLM library for matrix
math, and I needed to convert the 4x4 matrices to be 3x3 matrices to
@@ -664,7 +664,7 @@ application when moving from a “3D homogeneous space” to a “2D
homogeneous space”.&lt;/p&gt;
&lt;p&gt;Hopefully this explanation helps if you are every working on
converting 3D transformation code to 2D.&lt;/p&gt;
-</description><pubDate>Mon, 25 Sep 2023 04:00:00 -0000</pubDate><guid>https://fryzekconcepts.com/notes/converting_from_3d_to_2d.html</guid></item><item><title>A Dive into Vulkanised 2024</title><link>https://fryzekconcepts.com/notes/vulkanised_2024.html</link><description>&lt;figure&gt;
+</description><pubDate>Sun, 24 Sep 2023 23:00:00 -0000</pubDate><guid>https://fryzekconcepts.com/notes/converting_from_3d_to_2d.html</guid></item><item><title>A Dive into Vulkanised 2024</title><link>https://fryzekconcepts.com/notes/vulkanised_2024.html</link><description>&lt;figure&gt;
&lt;img src="/assets/vulkanised_2024/vulkanized_logo_web.jpg"
alt="Vulkanised sign at google’s office" /&gt;
&lt;figcaption aria-hidden="true"&gt;Vulkanised sign at google’s
@@ -774,4 +774,160 @@ Area!&lt;/p&gt;
alt="Great bay area food" /&gt;
&lt;figcaption aria-hidden="true"&gt;Great bay area food&lt;/figcaption&gt;
&lt;/figure&gt;
-</description><pubDate>Wed, 14 Feb 2024 05:00:00 -0000</pubDate><guid>https://fryzekconcepts.com/notes/vulkanised_2024.html</guid></item></channel></rss> \ No newline at end of file
+</description><pubDate>Wed, 14 Feb 2024 00:00:00 -0000</pubDate><guid>https://fryzekconcepts.com/notes/vulkanised_2024.html</guid></item><item><title>Software Rendering and Android</title><link>https://fryzekconcepts.com/notes/android_swrast.html</link><description>&lt;p&gt;My current project at Igalia has had me working on Mesa’s software
+renderers, llvmpipe and lavapipe. I’ve been working to get them running
+on Android, and I wanted to document the progress I’ve made, the
+challenges I’ve faced, and talk a little bit about the development
+process for a project like this. My work is not totally merged into
+upstream mesa yet, but you can see the MRs I made here:&lt;/p&gt;
+&lt;ul&gt;
+&lt;li&gt;&lt;a
+href="https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/29344"&gt;MR
+!29344&lt;/a&gt;&lt;/li&gt;
+&lt;li&gt;&lt;a
+href="https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/29785"&gt;MR
+!29785&lt;/a&gt;&lt;/li&gt;
+&lt;li&gt;&lt;a
+href="https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/27805"&gt;MR
+!27805&lt;/a&gt;&lt;/li&gt;
+&lt;li&gt;&lt;a
+href="https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/28735"&gt;MR
+!28735&lt;/a&gt;&lt;/li&gt;
+&lt;/ul&gt;
+&lt;h2 id="setting-up-an-android-development-environment"&gt;Setting up an
+Android development environment&lt;/h2&gt;
+&lt;p&gt;Getting system level software to build and run on Android is
+unfortunately not straightforward. Since we are doing software rendering
+we don’t need a physical device and instead we can make use of the
+Android emulator, and if you didn’t know Android has two emulators, the
+common one most people use is “goldfish” and the other lesser known is
+“cuttlefish”. For this project I did my work on the cuttlefish emulator
+as its meant for testing the Android OS itself instead of just Android
+apps and is more reflective of real hardware. The cuttlefish emulator
+takes a little bit more work to setup, and I’ve found that it only works
+properly in Debian based linux distros. I run Fedora, so I had to run
+the emulator in a debian VM.&lt;/p&gt;
+&lt;p&gt;Thankfully Google has good instructions for building and running
+cuttlefish, which you can find &lt;a
+href="https://source.android.com/docs/devices/cuttlefish/get-started"&gt;here&lt;/a&gt;.
+The instructions show you how to setup the emulator using nightly build
+images from Google. We’ll also need to setup our own Android OS images
+so after we’ve confirmed we can run the emulator, we need to start
+looking at building AOSP.&lt;/p&gt;
+&lt;p&gt;For building our own AOSP image, we can also follow the instructions
+from Google &lt;a
+href="https://source.android.com/docs/setup/build/building"&gt;here&lt;/a&gt;.
+For the target we’ll want
+&lt;code&gt;aosp_cf_x86_64_phone-trunk_staging-eng&lt;/code&gt;. At this point it’s
+a good idea to verify that you can build the image, which you can do by
+following the rest of the instructions on the page. Building AOSP from
+source does take a while though, so prepare to wait potentially an
+entire day for the image to build. Also if you get errors complaining
+that you’re out of memory, you can try to reduce the number of parallel
+builds. Google officially recommends to have 64GB of RAM, and I only had
+32GB so some packages had to be built with the parallel builds set to 1
+so I wouldn’t run out of RAM.&lt;/p&gt;
+&lt;p&gt;For running this custom-built image on Cuttlefish, you can just copy
+all the &lt;code&gt;*.img&lt;/code&gt; files from
+&lt;code&gt;out/target/product/vsoc_x86_64/&lt;/code&gt; to the root cuttlefish
+directory, and then launch cuttlefish. If everything worked successfully
+you should be able to see your custom built AOSP image running in the
+cuttlefish webui.&lt;/p&gt;
+&lt;h2 id="building-mesa-targeting-android"&gt;Building Mesa targeting
+Android&lt;/h2&gt;
+&lt;p&gt;Working from the changes in MR &lt;a
+href="https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/29344"&gt;!29344&lt;/a&gt;
+building llvmpipe or lavapipe targeting Android should just work™️. To
+get to that stage required a few changes. First llvmpipe actually
+already had some support on Android, as long as it was running on a
+device that supports a DRM display driver. In that case it could use the
+&lt;code&gt;dri&lt;/code&gt; window system integration which already works on
+Android. I wanted to get llvmpipe (and lavapipe) running without dri, so
+I had to add support for Android in the &lt;code&gt;drisw&lt;/code&gt; window system
+integration.&lt;/p&gt;
+&lt;p&gt;To support Android in &lt;code&gt;drisw&lt;/code&gt;, this mainly meant adding
+support for importing dmabuf as framebuffers. The Android windowing
+system will provide us with a “gralloc” buffer which inside has a dmabuf
+fd that represents the framebuffer. Adding support for importing dmabufs
+in drisw means we can import and begin drawing to these frame buffers.
+Most the changes to support that can be found in &lt;a
+href="https://gitlab.freedesktop.org/mesa/mesa/-/blob/9705df53408777d493eab19e5a58c432c1e75acb/src/gallium/frontends/dri/drisw.c#L405"&gt;&lt;code&gt;drisw_allocate_textures&lt;/code&gt;&lt;/a&gt;
+and the underlying changes to llvmpipe to support importing dmabufs in
+MR &lt;a
+href="https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/27805"&gt;!27805&lt;/a&gt;.
+The EGL Android platform code also needed some changes to use the
+&lt;code&gt;drisw&lt;/code&gt; window system code. Previously this code would only
+work with true dri drivers, but with some small tweaks it was possible
+to get to have it initialize the drisw window system and then using it
+for rendering if no hardware devices are available.&lt;/p&gt;
+&lt;p&gt;For lavapipe the changes were a lot simpler. The Android Vulkan
+loader requires your driver to have &lt;code&gt;HAL_MODULE_INFO_SYM&lt;/code&gt;
+symbol in the binary, so that got created and populated correctly,
+following other Vulkan drivers in Mesa like turnip. Then the image
+creation code had to be modified to support the
+&lt;code&gt;VK_ANDROID_native_buffer&lt;/code&gt; extension which allows the Android
+Vulkan loader to create images using Android native buffer handles.
+Under the hood this means getting the dmabuf fd from the native buffer
+handle. Thankfully mesa already has some common code to handle this, so
+I could just use that. Some other small changes were also necessary to
+address crashes and other failures that came up during testing.&lt;/p&gt;
+&lt;p&gt;With the changes out of of the way we can now start building Mesa on
+Android. For this project I had to update the Android documentation for
+Mesa to include steps for building LLVM for Android since the version
+Google ships with the NDK is missing libraries that llvmpipe/lavapipe
+need to function. You can see the updated documentation &lt;a
+href="https://gitlab.freedesktop.org/mesa/mesa/-/blob/9705df53408777d493eab19e5a58c432c1e75acb/docs/drivers/llvmpipe.rst"&gt;here&lt;/a&gt;
+and &lt;a
+href="https://gitlab.freedesktop.org/mesa/mesa/-/blob/9705df53408777d493eab19e5a58c432c1e75acb/docs/android.rst"&gt;here&lt;/a&gt;.
+After sorting out LLVM, building llvmpipe/lavapipe is the same as
+building any other Mesa driver for Android: we setup a cross file to
+tell meson how to cross compile and then we run meson. At this point you
+could manual modify the Android image and copy these files to the vm,
+but I also wanted to support building a new AOSP image directly
+including the driver. In order to do that you also have to rename the
+driver binaries to match Android’s naming convention, and make sure
+SO_NAME matches as well. If you check out &lt;a
+href="https://gitlab.freedesktop.org/mesa/mesa/-/blob/9705df53408777d493eab19e5a58c432c1e75acb/docs/android.rst?plain=1#L183"&gt;this&lt;/a&gt;
+section of the documentation I wrote, it covers how to do that.&lt;/p&gt;
+&lt;p&gt;If you followed all of that you should have built an version of
+llvmpipe and lavapipe that you can run on Android’s cuttlefish
+emulator.&lt;/p&gt;
+&lt;figure&gt;
+&lt;img src="/assets/2024-06-27-android-swrast/lavapipe.png"
+alt="Android running lavapipe" /&gt;
+&lt;figcaption aria-hidden="true"&gt;Android running lavapipe&lt;/figcaption&gt;
+&lt;/figure&gt;
+&lt;h2 id="references"&gt;References&lt;/h2&gt;
+&lt;ul&gt;
+&lt;li&gt;&lt;a
+href="https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/29344"
+class="uri"&gt;https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/29344&lt;/a&gt;
+&lt;ul&gt;
+&lt;li&gt;Main MR with Android changes&lt;/li&gt;
+&lt;/ul&gt;&lt;/li&gt;
+&lt;li&gt;&lt;a
+href="https://source.android.com/docs/devices/cuttlefish/get-started"
+class="uri"&gt;https://source.android.com/docs/devices/cuttlefish/get-started&lt;/a&gt;
+&lt;ul&gt;
+&lt;li&gt;Google’s official guide for getting started with the Cuttlefish
+emulator&lt;/li&gt;
+&lt;/ul&gt;&lt;/li&gt;
+&lt;li&gt;&lt;a href="https://source.android.com/docs/setup/build/building"
+class="uri"&gt;https://source.android.com/docs/setup/build/building&lt;/a&gt;
+&lt;ul&gt;
+&lt;li&gt;Google’s official guide for building AOSP images&lt;/li&gt;
+&lt;/ul&gt;&lt;/li&gt;
+&lt;li&gt;&lt;a
+href="https://gitlab.freedesktop.org/mesa/mesa/-/blob/9705df53408777d493eab19e5a58c432c1e75acb/docs/drivers/llvmpipe.rst"
+class="uri"&gt;https://gitlab.freedesktop.org/mesa/mesa/-/blob/9705df53408777d493eab19e5a58c432c1e75acb/docs/drivers/llvmpipe.rst&lt;/a&gt;
+&lt;ul&gt;
+&lt;li&gt;My updated documentation in MR for llvmpipe&lt;/li&gt;
+&lt;/ul&gt;&lt;/li&gt;
+&lt;li&gt;&lt;a
+href="https://gitlab.freedesktop.org/mesa/mesa/-/blob/9705df53408777d493eab19e5a58c432c1e75acb/docs/android.rst"
+class="uri"&gt;https://gitlab.freedesktop.org/mesa/mesa/-/blob/9705df53408777d493eab19e5a58c432c1e75acb/docs/android.rst&lt;/a&gt;
+&lt;ul&gt;
+&lt;li&gt;My updated documentation in MR for Android integration in mesa&lt;/li&gt;
+&lt;/ul&gt;&lt;/li&gt;
+&lt;/ul&gt;
+</description><pubDate>Wed, 26 Jun 2024 23:00:00 -0000</pubDate><guid>https://fryzekconcepts.com/notes/android_swrast.html</guid></item></channel></rss> \ No newline at end of file
diff --git a/html/index.html b/html/index.html
index aa6c498..a12cf29 100644
--- a/html/index.html
+++ b/html/index.html
@@ -45,6 +45,14 @@
</a>
</h2>
<div class="notes-container">
+ <a href="/notes/android_swrast.html" class="note-link">
+ <div class="note-box">
+ <img src="/assets/2024-06-27-android-swrast/lavapipe_thumbnail.png">
+ <h2>Software Rendering and Android</h2>
+ <p>My current project at Igalia has had me working on Mesa’s
+ software renderers, llvmpipe and been ...</p>
+ </div>
+ </a>
<a href="/notes/vulkanised_2024.html" class="note-link">
<div class="note-box">
<img src="/assets/vulkanised_2024/vulkanized_logo_web.jpg">
diff --git a/html/notes/android_swrast.html b/html/notes/android_swrast.html
new file mode 100644
index 0000000..0f688ef
--- /dev/null
+++ b/html/notes/android_swrast.html
@@ -0,0 +1,205 @@
+<!doctype html>
+
+<html class="html-note-page" lang="en">
+<head>
+ <meta charset="utf-8">
+ <meta name="viewport" content="width=device-width, initial-scale=1">
+
+ <title>Software Rendering and Android</title>
+ <meta name="dcterms.date" content="2024-06-27" />
+
+ <link rel="stylesheet" href="/assets/style.css">
+ <link rel="icon" type="image/x-icon" href="/assets/favicon.svg">
+ <link rel="alternate" type="application/atom+xml" title="Fryzek Concepts" href="/feed.xml">
+</head>
+
+<body>
+ <div class="header-bar">
+ <a href="/index.html">
+ <img src="/assets/favicon.svg" alt="frycon logo">
+ </a>
+ <div class="header-links">
+ <a href="/now.html" class="header-link">Now</a>
+ <a href="/about.html" class="header-link">About</a>
+ <a rel="me" href="https://mastodon.social/@hazematman">Social</a>
+ </div>
+ </div>
+ <main>
+<div class="page-title-header-container">
+ <h1 class="page-title-header">Software Rendering and Android</h1>
+ <div class="page-info-container">
+ <div class="plant-status">
+ <img src="/assets/evergreen.svg">
+ <div class="plant-status-text">
+ <p>evergreen</p>
+ </div>
+ </div>
+ <div class="page-info-date-container">
+ <p class="page-info-date">Published: 2024-06-27</p>
+ <p class="page-info-date">Last Edited: 2024-06-27</p>
+ </div>
+ </div>
+ </div>
+<div class="note-divider"></div>
+<div class="main-container">
+ <div class="note-body">
+<p>My current project at Igalia has had me working on Mesa’s software
+renderers, llvmpipe and lavapipe. I’ve been working to get them running
+on Android, and I wanted to document the progress I’ve made, the
+challenges I’ve faced, and talk a little bit about the development
+process for a project like this. My work is not totally merged into
+upstream mesa yet, but you can see the MRs I made here:</p>
+<ul>
+<li><a
+href="https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/29344">MR
+!29344</a></li>
+<li><a
+href="https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/29785">MR
+!29785</a></li>
+<li><a
+href="https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/27805">MR
+!27805</a></li>
+<li><a
+href="https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/28735">MR
+!28735</a></li>
+</ul>
+<h2 id="setting-up-an-android-development-environment">Setting up an
+Android development environment</h2>
+<p>Getting system level software to build and run on Android is
+unfortunately not straightforward. Since we are doing software rendering
+we don’t need a physical device and instead we can make use of the
+Android emulator, and if you didn’t know Android has two emulators, the
+common one most people use is “goldfish” and the other lesser known is
+“cuttlefish”. For this project I did my work on the cuttlefish emulator
+as its meant for testing the Android OS itself instead of just Android
+apps and is more reflective of real hardware. The cuttlefish emulator
+takes a little bit more work to setup, and I’ve found that it only works
+properly in Debian based linux distros. I run Fedora, so I had to run
+the emulator in a debian VM.</p>
+<p>Thankfully Google has good instructions for building and running
+cuttlefish, which you can find <a
+href="https://source.android.com/docs/devices/cuttlefish/get-started">here</a>.
+The instructions show you how to setup the emulator using nightly build
+images from Google. We’ll also need to setup our own Android OS images
+so after we’ve confirmed we can run the emulator, we need to start
+looking at building AOSP.</p>
+<p>For building our own AOSP image, we can also follow the instructions
+from Google <a
+href="https://source.android.com/docs/setup/build/building">here</a>.
+For the target we’ll want
+<code>aosp_cf_x86_64_phone-trunk_staging-eng</code>. At this point it’s
+a good idea to verify that you can build the image, which you can do by
+following the rest of the instructions on the page. Building AOSP from
+source does take a while though, so prepare to wait potentially an
+entire day for the image to build. Also if you get errors complaining
+that you’re out of memory, you can try to reduce the number of parallel
+builds. Google officially recommends to have 64GB of RAM, and I only had
+32GB so some packages had to be built with the parallel builds set to 1
+so I wouldn’t run out of RAM.</p>
+<p>For running this custom-built image on Cuttlefish, you can just copy
+all the <code>*.img</code> files from
+<code>out/target/product/vsoc_x86_64/</code> to the root cuttlefish
+directory, and then launch cuttlefish. If everything worked successfully
+you should be able to see your custom built AOSP image running in the
+cuttlefish webui.</p>
+<h2 id="building-mesa-targeting-android">Building Mesa targeting
+Android</h2>
+<p>Working from the changes in MR <a
+href="https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/29344">!29344</a>
+building llvmpipe or lavapipe targeting Android should just work™️. To
+get to that stage required a few changes. First llvmpipe actually
+already had some support on Android, as long as it was running on a
+device that supports a DRM display driver. In that case it could use the
+<code>dri</code> window system integration which already works on
+Android. I wanted to get llvmpipe (and lavapipe) running without dri, so
+I had to add support for Android in the <code>drisw</code> window system
+integration.</p>
+<p>To support Android in <code>drisw</code>, this mainly meant adding
+support for importing dmabuf as framebuffers. The Android windowing
+system will provide us with a “gralloc” buffer which inside has a dmabuf
+fd that represents the framebuffer. Adding support for importing dmabufs
+in drisw means we can import and begin drawing to these frame buffers.
+Most the changes to support that can be found in <a
+href="https://gitlab.freedesktop.org/mesa/mesa/-/blob/9705df53408777d493eab19e5a58c432c1e75acb/src/gallium/frontends/dri/drisw.c#L405"><code>drisw_allocate_textures</code></a>
+and the underlying changes to llvmpipe to support importing dmabufs in
+MR <a
+href="https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/27805">!27805</a>.
+The EGL Android platform code also needed some changes to use the
+<code>drisw</code> window system code. Previously this code would only
+work with true dri drivers, but with some small tweaks it was possible
+to get to have it initialize the drisw window system and then using it
+for rendering if no hardware devices are available.</p>
+<p>For lavapipe the changes were a lot simpler. The Android Vulkan
+loader requires your driver to have <code>HAL_MODULE_INFO_SYM</code>
+symbol in the binary, so that got created and populated correctly,
+following other Vulkan drivers in Mesa like turnip. Then the image
+creation code had to be modified to support the
+<code>VK_ANDROID_native_buffer</code> extension which allows the Android
+Vulkan loader to create images using Android native buffer handles.
+Under the hood this means getting the dmabuf fd from the native buffer
+handle. Thankfully mesa already has some common code to handle this, so
+I could just use that. Some other small changes were also necessary to
+address crashes and other failures that came up during testing.</p>
+<p>With the changes out of of the way we can now start building Mesa on
+Android. For this project I had to update the Android documentation for
+Mesa to include steps for building LLVM for Android since the version
+Google ships with the NDK is missing libraries that llvmpipe/lavapipe
+need to function. You can see the updated documentation <a
+href="https://gitlab.freedesktop.org/mesa/mesa/-/blob/9705df53408777d493eab19e5a58c432c1e75acb/docs/drivers/llvmpipe.rst">here</a>
+and <a
+href="https://gitlab.freedesktop.org/mesa/mesa/-/blob/9705df53408777d493eab19e5a58c432c1e75acb/docs/android.rst">here</a>.
+After sorting out LLVM, building llvmpipe/lavapipe is the same as
+building any other Mesa driver for Android: we setup a cross file to
+tell meson how to cross compile and then we run meson. At this point you
+could manual modify the Android image and copy these files to the vm,
+but I also wanted to support building a new AOSP image directly
+including the driver. In order to do that you also have to rename the
+driver binaries to match Android’s naming convention, and make sure
+SO_NAME matches as well. If you check out <a
+href="https://gitlab.freedesktop.org/mesa/mesa/-/blob/9705df53408777d493eab19e5a58c432c1e75acb/docs/android.rst?plain=1#L183">this</a>
+section of the documentation I wrote, it covers how to do that.</p>
+<p>If you followed all of that you should have built an version of
+llvmpipe and lavapipe that you can run on Android’s cuttlefish
+emulator.</p>
+<figure>
+<img src="/assets/2024-06-27-android-swrast/lavapipe.png"
+alt="Android running lavapipe" />
+<figcaption aria-hidden="true">Android running lavapipe</figcaption>
+</figure>
+<h2 id="references">References</h2>
+<ul>
+<li><a
+href="https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/29344"
+class="uri">https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/29344</a>
+<ul>
+<li>Main MR with Android changes</li>
+</ul></li>
+<li><a
+href="https://source.android.com/docs/devices/cuttlefish/get-started"
+class="uri">https://source.android.com/docs/devices/cuttlefish/get-started</a>
+<ul>
+<li>Google’s official guide for getting started with the Cuttlefish
+emulator</li>
+</ul></li>
+<li><a href="https://source.android.com/docs/setup/build/building"
+class="uri">https://source.android.com/docs/setup/build/building</a>
+<ul>
+<li>Google’s official guide for building AOSP images</li>
+</ul></li>
+<li><a
+href="https://gitlab.freedesktop.org/mesa/mesa/-/blob/9705df53408777d493eab19e5a58c432c1e75acb/docs/drivers/llvmpipe.rst"
+class="uri">https://gitlab.freedesktop.org/mesa/mesa/-/blob/9705df53408777d493eab19e5a58c432c1e75acb/docs/drivers/llvmpipe.rst</a>
+<ul>
+<li>My updated documentation in MR for llvmpipe</li>
+</ul></li>
+<li><a
+href="https://gitlab.freedesktop.org/mesa/mesa/-/blob/9705df53408777d493eab19e5a58c432c1e75acb/docs/android.rst"
+class="uri">https://gitlab.freedesktop.org/mesa/mesa/-/blob/9705df53408777d493eab19e5a58c432c1e75acb/docs/android.rst</a>
+<ul>
+<li>My updated documentation in MR for Android integration in mesa</li>
+</ul></li>
+</ul>
+ </div>
+</div> </main>
+</body>
+</html>