union: fix panic due to misalignment of struct field in 32 bit architectures

`FS.cacheExpiry` is accessed through sync/atomic.
According to the documentation, "On ARM, 386, and 32-bit MIPS, it is
the caller's responsibility to arrange for 64-bit alignment of 64-bit
words accessed atomically. The first word in a variable or in an
allocated struct, array, or slice can be relied upon to be 64-bit
aligned."
Before commit 1d2fe0d856 this field was
aligned, but then a new field was added to the structure, causing the
test suite to panic on linux/386.
No other field is used with sync/atomic, so `cacheExpiry` can just be
placed at the beginning of the stuct to ensure it is always aligned.
This commit is contained in:
r-ricci 2022-07-11 18:34:06 +01:00 committed by GitHub
parent b310490fa5
commit 67fd60275a
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23

View file

@ -24,6 +24,10 @@ var (
// Fs is a wrap of any fs and its configs // Fs is a wrap of any fs and its configs
type Fs struct { type Fs struct {
// In order to ensure memory alignment on 32-bit architectures
// when this field is accessed through sync/atomic functions,
// it must be the first entry in the struct
cacheExpiry int64 // usage cache expiry time
fs.Fs fs.Fs
RootFs fs.Fs RootFs fs.Fs
RootPath string RootPath string
@ -32,7 +36,6 @@ type Fs struct {
creatable bool creatable bool
usage *fs.Usage // Cache the usage usage *fs.Usage // Cache the usage
cacheTime time.Duration // cache duration cacheTime time.Duration // cache duration
cacheExpiry int64 // usage cache expiry time
cacheMutex sync.RWMutex cacheMutex sync.RWMutex
cacheOnce sync.Once cacheOnce sync.Once
cacheUpdate bool // if the cache is updating cacheUpdate bool // if the cache is updating