Skip to content
New issue

Have a question about this project? # for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “#”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? # to your account

dmz: cloned binary: set +x permissions when creating regular tmpfile #4444

Merged
merged 1 commit into from
Oct 15, 2024

Conversation

lifubang
Copy link
Member

Though creates a classic temp file for runc binary is the last fallback method of CloneBinary, we should also fix the error of it.

Comment on lines 107 to 109
if err := file.Chmod(0o511); err != nil {
return nil, nil, fmt.Errorf("chmod classic tmpfile: %w", err)
}
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Isn't this already done in sealFile?

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Yes, but because of isExecutable check, we will get an error because we can't find any executable file after we traversed all the tmpDirs:

if !isExecutable(file) {
logrus.Debugf("tmpdir %s is noexec -- trying a different tmpdir", dir)
file.Close()
continue
}

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Hmm, okay so we should move the code from sealFile then rather than duplicating it. Also we should do this after we do os.Remove() so if there is an error we don't leak the temporary file.

Copy link
Member

@cyphar cyphar Oct 14, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

It would be nice to explain the issue in the commit message btw 😸, something like:

dmz: cloned binary: set +x permissions when creating regular tmpfile

While we did set +x when "sealing" regular temporary files, the "is
executable" checks were done before then and would thus fail, causing
the fallback to not work properly.

So just set +x after we create the file. We already have a O_RDWR handle
open when we do the chmod so we won't get permission issues when writing
to the file.

Fixes: e089db3b4a31 ("dmz: add fallbacks to handle noexec for O_TMPFILE and mktemp()")
Signed-off-by: lifubang <lifubang@acmcoder.com>

While we did set +x when "sealing" regular temporary files, the "is
executable" checks were done before then and would thus fail, causing
the fallback to not work properly.

So just set +x after we create the file. We already have a O_RDWR handle
open when we do the chmod so we won't get permission issues when writing
to the file.

Fixes: e089db3 ("dmz: add fallbacks to handle noexec for O_TMPFILE and mktemp()")

Signed-off-by: lifubang <lifubang@acmcoder.com>
@lifubang lifubang changed the title Should set exec bit for runc temp file dmz: cloned binary: set +x permissions when creating regular tmpfile Oct 14, 2024
Copy link
Contributor

@kolyshkin kolyshkin left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@lifubang how have you found this? Is this a very old kernel?

If yes, can you check what error otmpfile returns?

I'm thinking, if older kernels return EISDIR, we should not retry otmpfile with a different directory, but jump straight to mktemp fallback.

Of course, this is not really related to this PR and can be done separately.

@lifubang
Copy link
Member Author

how have you found this? Is this a very old kernel?

No, it's from code review. I find there may be an error, so I delete the memfd and otmpfile code to test it.

Copy link
Member

@cyphar cyphar left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM

@cyphar cyphar merged commit d82235c into opencontainers:main Oct 15, 2024
42 checks passed
@lifubang lifubang deleted the fix-mktemp-exec branch October 15, 2024 05:40
# for free to join this conversation on GitHub. Already have an account? # to comment
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants