cloud-init-dev team mailing list archive
-
cloud-init-dev team
-
Mailing list archive
-
Message #06521
Re: [Merge] ~chad.smith/cloud-init:bug/1840080-ubuntu-drivers-emit-latelink-v2 into cloud-init:master
Diff comments:
> diff --git a/cloudinit/config/cc_ubuntu_drivers.py b/cloudinit/config/cc_ubuntu_drivers.py
> index 4da34ee..44a2bfe 100644
> --- a/cloudinit/config/cc_ubuntu_drivers.py
> +++ b/cloudinit/config/cc_ubuntu_drivers.py
> @@ -65,6 +65,39 @@ OLD_UBUNTU_DRIVERS_STDERR_NEEDLE = (
> __doc__ = get_schema_doc(schema) # Supplement python help()
>
>
> +# debconf template to allow cloud-init pre-configure the global debconf
> +# variable linux/nvidia/latelink to true, allowing linux-restricted-modules
> +# to accept the NVIDIA EULA and automatically link drivers to the running
> +# kernel.
> +# EOL_XENIAL: can then drop this script and use python3-debconf which is only
> +# available in Bionic and later. Can't use python3-debconf currently as it
> +# isn't in Xenial and doesn't yet support X_LOADTEMPLATEFILE debconf command.
> +
> +NVIDIA_DRIVER_LATELINK_DEBCONF_TMPL = """\
done. Per your other comments, I've simplified the NVIDIA_DRIVER_LATELINK_DEBCONF_SCRIPT and we'll also write the separate NVIDIA_DEBCONF_CONTENT which can be passed to the script as $1
> +#/bin/sh
> +# Allow cloud-init to trigger EULA acceptance via registering a debconf
> +# template to set linux/nvidia/latelink true
> +
> +. /usr/share/debconf/confmodule
> +
> +SCRIPT=$(readlink -f "$0")
> +DIRNAME=$(dirname "$SCRIPT")
> +tmpfile=$(mktemp -p ${DIRNAME} -t "cloud-init-ubuntu-drivers-XXXXXX.template")
> +cat > "$tmpfile" << EOF
> +Template: linux/nvidia/latelink
> +Type: boolean
> +Default: true
> +Description: Late-link NVIDIA kernel modules?
> + Enable this to link the NVIDIA kernel modules in cloud-init and
> + make them available for use.
> +EOF
> +echo BEFORE $tmpfile
Good suggestion, done.
> +db_x_loadtemplatefile "$tmpfile" cloud-init
> +echo AFTER $tmpfile
> +rm "$tmpfile"
> +"""
> +
> +
> def install_drivers(cfg, pkg_install_func):
> if not isinstance(cfg, dict):
> raise TypeError(
> @@ -90,17 +123,22 @@ def install_drivers(cfg, pkg_install_func):
> if version_cfg:
> driver_arg += ':{}'.format(version_cfg)
>
> - LOG.debug("Installing NVIDIA drivers (%s=%s, version=%s)",
> + LOG.debug("Installing and activating NVIDIA drivers (%s=%s, version=%s)",
> cfgpath, nv_acc, version_cfg if version_cfg else 'latest')
>
> - # Setting NVIDIA latelink confirms acceptance of EULA for the package
> - # linux-restricted-modules
> - # Reference code defining debconf variable is here
> - # https://git.launchpad.net/~ubuntu-kernel/ubuntu/+source/
> - # linux-restricted-modules/+git/eoan/tree/debian/templates/
> - # nvidia.templates.in
> - selections = b'linux-restricted-modules linux/nvidia/latelink boolean true'
> - cc_apt_configure.debconf_set_selections(selections)
> + # Register and set debconf selection linux/nvidia/latelink = true
> + with temp_utils.ExtendedTemporaryFile(
> + suffix=".sh", needs_exe=True) as tmpf:
> + try:
> + tmpf.write(util.encode_text(NVIDIA_DRIVER_LATELINK_DEBCONF_TMPL))
> + tmpf.flush()
> + util.chmod(tmpf.name, 0o755)
Agreed. fixed.
> + util.subp([tmpf.name])
> + except Exception as e:
> + util.logexc(
> + LOG,
> + "Failed to register NVIDIA debconf template: %s", str(e))
> + raise
>
> try:
> util.subp(['ubuntu-drivers', 'install', '--gpgpu', driver_arg])
--
https://code.launchpad.net/~chad.smith/cloud-init/+git/cloud-init/+merge/371546
Your team cloud-init commiters is requested to review the proposed merge of ~chad.smith/cloud-init:bug/1840080-ubuntu-drivers-emit-latelink-v2 into cloud-init:master.
References