NixOS on ARM/Clockworkpi A06 uConsole: Difference between revisions

imported>Tarinaky
No edit summary
Pigs (talk | contribs)
m Add category
 
(6 intermediate revisions by 3 users not shown)
Line 1: Line 1:
{{ARM/breadcrumb}}


== Status ==
== Status ==
Panel/Display works. Broadcom wifi works. System boots. All other features untested.
Panel/Display works. Broadcom wifi works. System boots. All other features untested. These instructions are specific to the A06 version and will not work on the CM4. I don't have the version with the Qualcomm 4G extension board, so I cannot advise on how to get that running.
 
NB: Currently only works with Nixos-23.11 channel. System will not boot with 24.05 image. I haven't figured out why.


=== Modules / Drivers ===
=== Modules / Drivers ===
Line 7: Line 10:


== Kernel ==
== Kernel ==
The device tree patches to make the panel/display work are currently only available as kernel patches. The official patches only support kernel 5.x, however there is a community patchset for kernel 6.5 available at [[https://github.com/Autianic/clockworkpi-linux-kernel/tree/master/linux-clockworkpi-a06]]
The device tree patches to make the panel/display work are currently only available as kernel patches. The official patches only support kernel 5.x, however there is a community patchset for kernel 6.5/6.6 available at [[https://github.com/Autianic/clockworkpi-linux-kernel/tree/master/linux-clockworkpi-a06]]


These patches can be applied using the following nix snippet:
These patches can be applied using the following nix snippet:
```
   boot.kernelPackages = pkgs.linuxPackages_6_6;
   boot.kernelPackages = pkgs.linuxPackages_6_5;
   boot.kernelPatches = [
   boot.kernelPatches = [
     {
     {
Line 46: Line 48:
     }   
     }   
   ];
   ];
```
 
NB: At time of writing, ZFS is marked broken for Kernel 6.5, so you will have to disable zfs to build this kernel with the following snippet
  nixpkgs.overlays = [(final: super: {    zfs = super.zfs.overrideAttrs(_: {      meta.platforms = [];    });  })];
 
 


=== Bootloader ===
=== Bootloader ===
At present I am not sure where the bootloader images used by the official/vendor supplied distro can be obtained. The easiest way to make any generated image bootable is to copy them from the official image available here: [[http://dl.clockworkpi.com/uConsole_A06_v1.1e.img.7z]]
At present I am not sure where the bootloader images used by the official/vendor supplied distro can be obtained. The easiest way to make any generated image bootable is to copy them from the official image available here: [[http://dl.clockworkpi.com/uConsole_A06_v1.1e.img.7z]]


```
$ sfdisk --dump uConsole_A06_v1.1e.img
<...>
uConsoleA06_v1.1e.img1 : start = 32768, size = 14942208, type=83


$ sfdisk --dump your_nixos_image.img
  $ sfdisk --dump uConsole_A06_v1.1e.img
<...>
  <...>
your_nixos_image.img1 : start = 16384, size = 61440, type = b
  uConsoleA06_v1.1e.img1 : start = 32768, size = 14942208, type=83
your_nixos_image.img2 : start = 77824, size = 15322384, type = 83, bootable
 
 
  $ sfdisk --dump your_nixos_image.img
$ dd if=uConsole_A06_v1.1e.img of=nixos_a06.img count=32768
  <...>
$ dd if=your_nixos_image.img skip=32768 of=nixos_a06.img seek=77824
  your_nixos_image.img1 : start = 16384, size = 61440, type = b
```
  your_nixos_image.img2 : start = 77824, size = 15322384, type = 83, bootable
 
  $ dd if=uConsole_A06_v1.1e.img of=nixos_a06.img count=32768
  $ dd if=your_nixos_image.img skip=77824 of=nixos_a06.img seek=32768


The partition table for the resulting image will then be wrong, but we can fix that with fdisk by deleting our partition, and then recreating it.
The partition table for the resulting image will then be wrong, but we can fix that with fdisk by deleting our partition, and then recreating it.
```
fdisk ./nixos_a06.img
d
n
p
1
32768
<Default should now be to end of file>
Do you want to remove the signature? No
w


$ sfdisk --dump nixos_a06.img
  fdisk ./nixos_a06.img
<...>
  d
nixos_a06.img1 start = 32768, size = 15322384, type=83
  n
````
  p
  1
  32768
  <Default should now be to end of file>
  Do you want to remove the signature? No
  w
 
  $ sfdisk --dump nixos_a06.img
  <...>
  nixos_a06.img1 start = 32768, size = 15322384, type=83


Your image should now be bootable.
Your image should now be bootable.
[[Category:NixOS on ARM]]