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

add missing error numbers for HermitOS #3858

Merged
merged 2 commits into from
Aug 21, 2024
Merged

Conversation

stlankes
Copy link
Contributor

@stlankes stlankes commented Aug 19, 2024

HermitOS is a unikernel and its interface to the kernel is provided by https://crates.io/crates/hermit-abi. In the meantime parts of the interface is stabilized and we want to integrated it into libc. Unstable version will be still provided by hermit-abi.

Error numbers are missing in the main branch.

@rustbot
Copy link
Collaborator

rustbot commented Aug 19, 2024

r? @JohnTitor

rustbot has assigned @JohnTitor.
They will have a look at your PR within the next two weeks and either review your PR or reassign to another reviewer.

Use r? to explicitly pick a reviewer

@stlankes
Copy link
Contributor Author

@rustbot label +stable-nominated

@rustbot rustbot added the stable-nominated This PR should be considered for cherry-pick to libc's stable release branch label Aug 19, 2024
@stlankes
Copy link
Contributor Author

See also #3766

@tgross35
Copy link
Contributor

tgross35 commented Aug 20, 2024

The numbers all looks correct to me. However, the linked source at https://github.com/hermit-os/hermit-rs/blob/5a4d7efe1ab5727cf4d5299943aa8deaa098a603/hermit-abi/src/errno.rs looks like it always uses i32, not c_int that is used in this PR. Probably better to just use i32 here as well?

Also, could you start a file libc-test/semver/hermit.txt and add these? This won't be checked in CI but just run the tests locally and make sure they pass.

@rustbot author

@stlankes
Copy link
Contributor Author

c_int is defined as i32 (https://github.com/rust-lang/libc/blob/main/src/hermit.rs#L15). Hm, it irritates a little. We thought that this easier to understand because all other OS are using c_int. We can change it, I am open for it.

Also, could you start a file libc-test/semver/hermit.txt and add these? This won't be checked in CI but just run the tests locally and make sure they pass.

I will do it

@tgross35
Copy link
Contributor

c_int is defined as i32 (https://github.com/rust-lang/libc/blob/main/src/hermit.rs#L15). Hm, it irritates a little. We thought that this easier to understand because all other OS are using c_int. We can change it, I am open for it.

Regardless of how the type aliases are defined, prefer being consistent with the relevant headers / source files over being consistent with other platforms. Doesn't really matter here since c_int is almost always i32, but it makes it easier to verify that we don't quietly introduce bugs.

Looks like this is already done elsewhere, e.g. SO_REUSEADDR is a c_int on most platforms but an i32 on Hermit.

@stlankes
Copy link
Contributor Author

stlankes commented Aug 20, 2024

Ok, I thought about it. I will change it to i32.

@tgross35
Copy link
Contributor

Thanks! Can you add libc-test/semver/hermit.txt?

@stlankes
Copy link
Contributor Author

I just added libc-test/semver/hermit.txt.

@tgross35
Copy link
Contributor

tgross35 commented Aug 20, 2024

I only meant to include the API added here, the rest could come later. But even better that you did it all now I suppose :)

Thanks!

@tgross35 tgross35 enabled auto-merge August 20, 2024 20:56
@tgross35 tgross35 added this pull request to the merge queue Aug 21, 2024
Merged via the queue into rust-lang:main with commit 1178c25 Aug 21, 2024
40 checks passed
@stlankes stlankes deleted the hermit branch August 21, 2024 06:38
tgross35 pushed a commit to tgross35/rust-libc that referenced this pull request Aug 28, 2024
(backport <rust-lang#3858>)
(cherry picked from commit d448050)
tgross35 pushed a commit to tgross35/rust-libc that referenced this pull request Aug 28, 2024
(backport <rust-lang#3858>)
(cherry picked from commit 982e041)
tgross35 pushed a commit to tgross35/rust-libc that referenced this pull request Aug 28, 2024
(backport <rust-lang#3858>)
(cherry picked from commit d448050)
tgross35 pushed a commit to tgross35/rust-libc that referenced this pull request Aug 28, 2024
(backport <rust-lang#3858>)
(cherry picked from commit 982e041)
tgross35 pushed a commit to tgross35/rust-libc that referenced this pull request Aug 28, 2024
(backport <rust-lang#3858>)
(cherry picked from commit d448050)
tgross35 pushed a commit to tgross35/rust-libc that referenced this pull request Aug 28, 2024
(backport <rust-lang#3858>)
(cherry picked from commit 982e041)
@tgross35 tgross35 added stable-applied This PR has been cherry-picked to libc's stable release branch and removed stable-nominated This PR should be considered for cherry-pick to libc's stable release branch labels Aug 29, 2024
# for free to join this conversation on GitHub. Already have an account? # to comment
Labels
S-waiting-on-author stable-applied This PR has been cherry-picked to libc's stable release branch
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants