Merge pull request #3128 from cgwalters/hotfix-composefs

switchroot: use shared constant for unlock --hotfix
This commit is contained in:
Eric Curtin 2024-01-04 12:05:02 +00:00 committed by GitHub
commit 6a339ac6eb
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 11 additions and 3 deletions

View File

@ -60,6 +60,9 @@ GKeyFile *otcore_load_config (int rootfs, const char *filename, GError **error);
// The directory holding the root overlayfs // The directory holding the root overlayfs
#define OSTREE_DEPLOYMENT_ROOT_TRANSIENT_DIR "root-transient" #define OSTREE_DEPLOYMENT_ROOT_TRANSIENT_DIR "root-transient"
// Written by ostree admin unlock --hotfix, read by ostree-prepare-root
#define OTCORE_HOTFIX_USR_OVL_WORK ".usr-ovl-work"
// The name of the composefs metadata root // The name of the composefs metadata root
#define OSTREE_COMPOSEFS_NAME ".ostree.cfs" #define OSTREE_COMPOSEFS_NAME ".ostree.cfs"
// The temporary directory used for the EROFS mount; it's in the .private directory // The temporary directory used for the EROFS mount; it's in the .private directory

View File

@ -632,12 +632,17 @@ main (int argc, char *argv[])
} }
/* Prepare /usr. /* Prepare /usr.
* It may be either just a read-only bind-mount, or a persistent overlayfs. */ * It may be either just a read-only bind-mount, or a persistent overlayfs if set up
if (lstat (".usr-ovl-work", &stbuf) == 0) * with ostree admin unlock --hotfix.
* Note however that root.transient as handled above is effectively a generalization of unlock
* --hotfix.
*/
if (lstat (OTCORE_HOTFIX_USR_OVL_WORK, &stbuf) == 0)
{ {
/* Do we have a persistent overlayfs for /usr? If so, mount it now. */ /* Do we have a persistent overlayfs for /usr? If so, mount it now. */
const char usr_ovl_options[] const char usr_ovl_options[]
= "lowerdir=" TMP_SYSROOT "/usr,upperdir=.usr-ovl-upper,workdir=.usr-ovl-work"; = "lowerdir=" TMP_SYSROOT
"/usr,upperdir=.usr-ovl-upper,workdir=" OTCORE_HOTFIX_USR_OVL_WORK;
/* Except overlayfs barfs if we try to mount it on a read-only /* Except overlayfs barfs if we try to mount it on a read-only
* filesystem. For this use case I think admins are going to be * filesystem. For this use case I think admins are going to be