2021-10-09 09:07:54 +02:00
|
|
|
{ config, lib, pkgs, ... }:
|
|
|
|
|
|
|
|
let
|
|
|
|
cfg = config.virtualisation.waydroid;
|
2023-09-24 15:00:07 +02:00
|
|
|
kCfg = config.lib.kernelConfig;
|
2021-10-09 09:07:54 +02:00
|
|
|
kernelPackages = config.boot.kernelPackages;
|
|
|
|
waydroidGbinderConf = pkgs.writeText "waydroid.conf" ''
|
|
|
|
[Protocol]
|
|
|
|
/dev/binder = aidl2
|
|
|
|
/dev/vndbinder = aidl2
|
|
|
|
/dev/hwbinder = hidl
|
|
|
|
|
|
|
|
[ServiceManager]
|
|
|
|
/dev/binder = aidl2
|
|
|
|
/dev/vndbinder = aidl2
|
|
|
|
/dev/hwbinder = hidl
|
|
|
|
'';
|
|
|
|
|
2021-11-25 14:48:06 +01:00
|
|
|
in
|
|
|
|
{
|
2021-10-09 09:07:54 +02:00
|
|
|
|
|
|
|
options.virtualisation.waydroid = {
|
2023-09-24 15:00:07 +02:00
|
|
|
enable = lib.mkEnableOption "Waydroid";
|
2021-10-09 09:07:54 +02:00
|
|
|
};
|
|
|
|
|
2023-09-24 15:00:07 +02:00
|
|
|
config = lib.mkIf cfg.enable {
|
|
|
|
assertions = lib.singleton {
|
|
|
|
assertion = lib.versionAtLeast (lib.getVersion config.boot.kernelPackages.kernel) "4.18";
|
2021-10-09 09:07:54 +02:00
|
|
|
message = "Waydroid needs user namespace support to work properly";
|
|
|
|
};
|
|
|
|
|
2023-09-24 15:00:07 +02:00
|
|
|
system.requiredKernelConfig = [
|
|
|
|
(kCfg.isEnabled "ANDROID_BINDER_IPC")
|
|
|
|
(kCfg.isEnabled "ANDROID_BINDERFS")
|
2023-09-24 16:46:51 +02:00
|
|
|
(kCfg.isEnabled "MEMFD_CREATE")
|
2021-10-09 09:07:54 +02:00
|
|
|
];
|
|
|
|
|
2021-11-25 14:48:06 +01:00
|
|
|
/* NOTE: we always enable this flag even if CONFIG_PSI_DEFAULT_DISABLED is not on
|
|
|
|
as reading the kernel config is not always possible and on kernels where it's
|
|
|
|
already on it will be no-op
|
|
|
|
*/
|
|
|
|
boot.kernelParams = [ "psi=1" ];
|
|
|
|
|
2021-10-09 09:07:54 +02:00
|
|
|
environment.etc."gbinder.d/waydroid.conf".source = waydroidGbinderConf;
|
|
|
|
|
|
|
|
environment.systemPackages = with pkgs; [ waydroid ];
|
|
|
|
|
|
|
|
networking.firewall.trustedInterfaces = [ "waydroid0" ];
|
|
|
|
|
|
|
|
virtualisation.lxc.enable = true;
|
|
|
|
|
|
|
|
systemd.services.waydroid-container = {
|
|
|
|
description = "Waydroid Container";
|
|
|
|
|
|
|
|
wantedBy = [ "multi-user.target" ];
|
|
|
|
|
|
|
|
serviceConfig = {
|
2024-08-20 03:54:20 +02:00
|
|
|
Type = "dbus";
|
|
|
|
UMask = "0022";
|
2023-01-03 17:43:06 +01:00
|
|
|
ExecStart = "${pkgs.waydroid}/bin/waydroid -w container start";
|
2024-08-20 03:54:20 +02:00
|
|
|
BusName = "id.waydro.Container";
|
2021-10-09 09:07:54 +02:00
|
|
|
};
|
|
|
|
};
|
2021-10-09 09:07:54 +02:00
|
|
|
|
|
|
|
systemd.tmpfiles.rules = [
|
|
|
|
"d /var/lib/misc 0755 root root -" # for dnsmasq.leases
|
|
|
|
];
|
2024-08-20 03:54:20 +02:00
|
|
|
|
|
|
|
services.dbus.packages = with pkgs; [ waydroid ];
|
2021-10-09 09:07:54 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
}
|