Merge branch 'early-kbd' into staging
This commit is contained in:
		
						commit
						d9aafc885f
					
				| @ -5,8 +5,21 @@ with lib; | |||||||
| let | let | ||||||
| 
 | 
 | ||||||
|   makeColor = n: value: "COLOR_${toString n}=${value}"; |   makeColor = n: value: "COLOR_${toString n}=${value}"; | ||||||
|  |   makeColorCS = | ||||||
|  |     let positions = [ "0" "1" "2" "3" "4" "5" "6" "7" "8" "9" "A" "B" "C" "D" "E" "F" ]; | ||||||
|  |     in n: value: "\033]P${elemAt position n}${value}"; | ||||||
|   colors = concatImapStringsSep "\n" makeColor config.i18n.consoleColors; |   colors = concatImapStringsSep "\n" makeColor config.i18n.consoleColors; | ||||||
| 
 | 
 | ||||||
|  |   isUnicode = hasSuffix "UTF-8" (toUpper config.i18n.defaultLocale); | ||||||
|  | 
 | ||||||
|  |   optimizedKeymap = pkgs.runCommand "keymap" { | ||||||
|  |     nativeBuildInputs = [ pkgs.kbd ]; | ||||||
|  |   } '' | ||||||
|  |     cd ${kbdEnv}/share/keymaps | ||||||
|  |     loadkeys -b ${optionalString isUnicode "-u"} "${config.i18n.consoleKeyMap}" > $out | ||||||
|  |   ''; | ||||||
|  | 
 | ||||||
|  |   # Sadly, systemd-vconsole-setup doesn't support binary keymaps. | ||||||
|   vconsoleConf = pkgs.writeText "vconsole.conf" '' |   vconsoleConf = pkgs.writeText "vconsole.conf" '' | ||||||
|     KEYMAP=${config.i18n.consoleKeyMap} |     KEYMAP=${config.i18n.consoleKeyMap} | ||||||
|     FONT=${config.i18n.consoleFont} |     FONT=${config.i18n.consoleFont} | ||||||
| @ -44,36 +57,75 @@ in | |||||||
|       ''; |       ''; | ||||||
|     }; |     }; | ||||||
| 
 | 
 | ||||||
|  |     boot.earlyVconsoleSetup = mkOption { | ||||||
|  |       default = false; | ||||||
|  |       type = types.bool; | ||||||
|  |       description = '' | ||||||
|  |         Enable setting font and keymap as early as possible (in initrd). | ||||||
|  |       ''; | ||||||
|  |     }; | ||||||
|  | 
 | ||||||
|   }; |   }; | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|   ###### implementation |   ###### implementation | ||||||
| 
 | 
 | ||||||
|   config = mkMerge [ |   config = mkMerge [ | ||||||
|     (mkIf (!setVconsole) { |     (mkIf (!setVconsole || (setVconsole && config.boot.earlyVconsoleSetup)) { | ||||||
|       systemd.services."systemd-vconsole-setup".enable = false; |       systemd.services."systemd-vconsole-setup".enable = false; | ||||||
|     }) |     }) | ||||||
| 
 | 
 | ||||||
|     (mkIf setVconsole { |     (mkIf setVconsole (mkMerge [ | ||||||
|       environment.systemPackages = [ pkgs.kbd ]; |       { environment.systemPackages = [ pkgs.kbd ]; | ||||||
| 
 | 
 | ||||||
|       # Let systemd-vconsole-setup.service do the work of setting up the |         # Let systemd-vconsole-setup.service do the work of setting up the | ||||||
|       # virtual consoles. |         # virtual consoles. | ||||||
|       environment.etc."vconsole.conf".source = vconsoleConf; |         environment.etc."vconsole.conf".source = vconsoleConf; | ||||||
|       # Provide kbd with additional packages. |         # Provide kbd with additional packages. | ||||||
|       environment.etc."kbd".source = "${kbdEnv}/share"; |         environment.etc."kbd".source = "${kbdEnv}/share"; | ||||||
|  |       } | ||||||
| 
 | 
 | ||||||
|       # This is identical to the systemd-vconsole-setup.service unit |       (mkIf (!config.boot.earlyVconsoleSetup) { | ||||||
|       # shipped with systemd, except that it uses /dev/tty1 instead of |         # This is identical to the systemd-vconsole-setup.service unit | ||||||
|       # /dev/tty0 to prevent putting the X server in non-raw mode, and |         # shipped with systemd, except that it uses /dev/tty1 instead of | ||||||
|       # it has a restart trigger. |         # /dev/tty0 to prevent putting the X server in non-raw mode, and | ||||||
|       systemd.services."systemd-vconsole-setup" = |         # it has a restart trigger. | ||||||
|         { wantedBy = [ "multi-user.target" ]; |         systemd.services."systemd-vconsole-setup" = | ||||||
|           before = [ "display-manager.service" ]; |           { wantedBy = [ "sysinit.target" ]; | ||||||
|           after = [ "systemd-udev-settle.service" ]; |             before = [ "display-manager.service" ]; | ||||||
|           restartTriggers = [ vconsoleConf kbdEnv ]; |             after = [ "systemd-udev-settle.service" ]; | ||||||
|         }; |             restartTriggers = [ vconsoleConf kbdEnv ]; | ||||||
|     }) |           }; | ||||||
|  |       }) | ||||||
|  | 
 | ||||||
|  |       (mkIf config.boot.earlyVconsoleSetup { | ||||||
|  |         boot.initrd.extraUtilsCommands = '' | ||||||
|  |           mkdir -p $out/share/consolefonts | ||||||
|  |           ${if substring 0 1 config.i18n.consoleFont == "/" then '' | ||||||
|  |             font="${config.i18n.consoleFont}" | ||||||
|  |           '' else '' | ||||||
|  |             font="$(echo ${kbdEnv}/share/consolefonts/${config.i18n.consoleFont}.*)" | ||||||
|  |           ''} | ||||||
|  |           if [[ $font == *.gz ]]; then | ||||||
|  |             gzip -cd $font > $out/share/consolefonts/font.psf | ||||||
|  |           else | ||||||
|  |             cp -L $font $out/share/consolefonts/font.psf | ||||||
|  |           fi | ||||||
|  |         ''; | ||||||
|  | 
 | ||||||
|  |         boot.initrd.preLVMCommands = mkBefore '' | ||||||
|  |           kbd_mode ${if isUnicode then "-u" else "-a"} -C /dev/console | ||||||
|  |           printf "\033%%${if isUnicode then "G" else "@"}" >> /dev/console | ||||||
|  |           loadkmap < ${optimizedKeymap} | ||||||
|  | 
 | ||||||
|  |           setfont -C /dev/console $extraUtils/share/consolefonts/font.psf | ||||||
|  | 
 | ||||||
|  |           ${concatImapStringsSep "\n" (n: color: '' | ||||||
|  |             printf "${makeColorCS n color}" >> /dev/console | ||||||
|  |           '') config.i18n.consoleColors} | ||||||
|  |         ''; | ||||||
|  |       }) | ||||||
|  |     ])) | ||||||
|   ]; |   ]; | ||||||
| 
 | 
 | ||||||
| } | } | ||||||
|  | |||||||
| @ -56,6 +56,9 @@ stdenv.mkDerivation rec { | |||||||
|     CONFIG_FEATURE_MOUNT_CIFS n |     CONFIG_FEATURE_MOUNT_CIFS n | ||||||
|     CONFIG_FEATURE_MOUNT_HELPERS y |     CONFIG_FEATURE_MOUNT_HELPERS y | ||||||
| 
 | 
 | ||||||
|  |     # Set paths for console fonts. | ||||||
|  |     CONFIG_DEFAULT_SETFONT_DIR "/etc/kbd" | ||||||
|  | 
 | ||||||
|     ${extraConfig} |     ${extraConfig} | ||||||
|     $extraCrossConfig |     $extraCrossConfig | ||||||
|     EOF |     EOF | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 Nikolay Amiantov
						Nikolay Amiantov