-
Notifications
You must be signed in to change notification settings - Fork 1.1k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Add new cfg gnu_file_offset_bits64 corresponding to _FILE_OFFSET_BITS=64 #4345
base: main
Are you sure you want to change the base?
Conversation
Less commands makes for a cleaner `set -x` log. And it is more efficient.
Variables set with `env` in the matrix never propagated into the environment. Add a step in test_tier1 and test_tier2 that reads the env context from the matrix and adds the variables to the environment used by later steps.
The `Create I artifacts` step is always run, whether earlier steps succeeds or not. But the upload step would only run if all preceeding steps wer successfull. Add a conditional to always run except if artifact creation failed.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I haven't checked the type changes in detail but this looks pretty good to me. Left a handful of comments mostly related to configuration.
Thank you so much for working on this!
Add new jobs for i686 in test_tier1 and arm and powerpc in test_tier2 where RUST_LIBC_UNSTABLE_GNU_FILE_OFFSET_BITS=64. Use artifact-tag to avoid artifact name collisions.
Set the basic types correctly for gnu_file_offset_bits64 (_FILE_OFFSET_BITS=64).
gnu_file_offset_bits64 means _FILE_OFFSET_BITS=64.
When _FILE_OFFSET_BITS=64, glibc redirects some function calls to 64 bit versions. These symbols are sometimes the public LFS variants, sometimes hidden variants.
Like mips, the stat struct will become different once support for gnu_file_offset_bits64 is added.
Like mips and powerpc, the stat struct will become different once support for gnu_file_offset_bits64 is added.
Change the __padX members in b32/mod.rs from short to uint even though they are actually unsigned short in C. Using unsigned int will give the same alignment, and make the struct equivalent to stat64 when gnu_file_offset_bits64 is set.
Struct stat and stat64 needs to match when gnu_file_offset_bits64 is set.
The __f_unused field should be the same in statvfs and statvfs64 (where it was already included) as can be seen in https://sourceware.org/git/?p=glibc.git;a=blob;f=sysdeps/unix/sysv/linux/bits/statvfs.h;h=1aed2f54aa86e43ac1c1d3a33197b3232be76580;hb=HEAD
aba1e20
to
cf9c316
Compare
@rustbot ready |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I left one nit and I think it needs a rebase, but overall this looks great to me.
set_cfg("gnu_file_offset_bits64"); | ||
} | ||
} | ||
_ => {} |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Could you add something like Ok(val) if val != "32" => panic!("RUST_LIBC_UNSTABLE_GNU_FILE_OFFSET_BITS may only be set to '32' or '64'),
?
Description
Add a new cfg
gnu_file_offset_bits64
corresponding to-D_FILE_OFFSET_BITS=64
.The cfg can also be enabled by setting the environment variable
RUST_LIBC_UNSTABLE_GNU_FILE_OFFSET_BITS64=1
.This is the second part of what was #3175 .
Sources
off_t
ino_t
blkcnt_t
fsblkcnt_t
fsfilcnt_t
rlim_t
F_GETLK
F_SETLK
andF_SETLKW
RLIM_INFINITY
getrlimit
,setrlimit
,prlimit
pread
,pwrite
,preadv2
,pwritev2
aio_read
,aio_write
,aio_error
,aio_return
,aio_cancel
,lio_listio
fallocate
,posix_fallocate
,posix_fadvise
,open
,creat
,fcntl
,lockf
,openat
glob
,globfree
mkstemps
,mkostemp
,mkostemps
,mkstemp
sendfile
statfs
,fstatfs
fopen
,freopen
,tmpfile
,fgetpos
,fsetpos
,fseeko
,ftello
stat
,fstat
,fstatat
,lstat
statfs
,fstatfs
readdir
,readdir_r
lseek
,pread
,pwrite
, truncate,ftruncate
mmap
struct statvfs
,struct fstatvfs
struct stat
,struct stat64
struct statfs
,struct statfs64
struct fpos_t
,struct fpos64_t
struct aiocb
struct flock
Checklist
libc-test/semver
have been updated*LAST
or*MAX
areincluded (see #3131)
cd libc-test && cargo test --target mytarget
);especially relevant for platforms that may not be checked in CI
I've tested this as widely as possible, but I have not been able to
run the sparc tests. mips and powerpc tests have been run on rust
1.85 using the yocto project, but it's not a fully compatible
environment for some reason.