tree: https://git.kernel.org/pub/scm/linux/kernel/git/tip/tip.git WIP.locking/core head: 5c587ed687faed2eb0afdd669ddd167d0d940236 commit: 2d6f2f61367455179ee140b3d4af6974d3e5d06d [25/29] locking/rwsem: Enable time-based spinning on reader-owned rwsem config: riscv-allyesconfig (attached as .config) compiler: riscv64-linux-gcc (GCC) 8.1.0 reproduce: wget https://raw.githubusercontent.com/intel/lkp-tests/master/sbin/make.cross -O ~/bin/make.cross chmod +x ~/bin/make.cross git checkout 2d6f2f61367455179ee140b3d4af6974d3e5d06d # save the attached .config to linux build tree GCC_VERSION=8.1.0 make.cross ARCH=riscv
All errors (new ones prefixed by >>): long owner = (long)READ_ONCE(sem->owner); ^~ include/linux/compiler.h:259:30: note: in definition of macro '__READ_ONCE' __read_once_size_nocheck(&(x), __u.__c, sizeof(x)); \ ^ kernel/locking/rwsem.h:203:21: note: in expansion of macro 'READ_ONCE' long owner = (long)READ_ONCE(sem->owner); ^~~~~~~~~ kernel/locking/rwsem.h:203:34: error: 'struct rw_semaphore' has no member named 'owner' long owner = (long)READ_ONCE(sem->owner); ^~ include/linux/compiler.h:259:50: note: in definition of macro '__READ_ONCE' __read_once_size_nocheck(&(x), __u.__c, sizeof(x)); \ ^ kernel/locking/rwsem.h:203:21: note: in expansion of macro 'READ_ONCE' long owner = (long)READ_ONCE(sem->owner); ^~~~~~~~~ In file included from kernel/locking/percpu-rwsem.c:10: kernel/locking/rwsem.h:205:9: error: implicit declaration of function 'is_rwsem_owner_reader' [-Werror=implicit-function-declaration] while (is_rwsem_owner_reader((struct task_struct *)owner)) { ^~~~~~~~~~~~~~~~~~~~~ kernel/locking/rwsem.h:206:8: error: implicit declaration of function 'is_rwsem_owner_spinnable'; did you mean 'rwsem_set_nonspinnable'? [-Werror=implicit-function-declaration] if (!is_rwsem_owner_spinnable((struct task_struct *)owner)) ^~~~~~~~~~~~~~~~~~~~~~~~ rwsem_set_nonspinnable In file included from arch/riscv/include/asm/atomic.h:23, from include/linux/atomic.h:7, from kernel/locking/percpu-rwsem.c:1: kernel/locking/rwsem.h:208:31: error: 'struct rw_semaphore' has no member named 'owner' owner = cmpxchg((long *)&sem->owner, owner, ^~ arch/riscv/include/asm/cmpxchg.h:350:15: note: in definition of macro 'cmpxchg' __typeof__(*(ptr)) _o_ = (o); \ ^~~ kernel/locking/rwsem.h:208:31: error: 'struct rw_semaphore' has no member named 'owner' owner = cmpxchg((long *)&sem->owner, owner, ^~ arch/riscv/include/asm/cmpxchg.h:351:15: note: in definition of macro 'cmpxchg' __typeof__(*(ptr)) _n_ = (n); \ ^~~ kernel/locking/rwsem.h:208:31: error: 'struct rw_semaphore' has no member named 'owner' owner = cmpxchg((long *)&sem->owner, owner, ^~ arch/riscv/include/asm/cmpxchg.h:352:16: note: in definition of macro 'cmpxchg' (__typeof__(*(ptr))) __cmpxchg((ptr), \ ^~~ kernel/locking/rwsem.h:208:31: error: 'struct rw_semaphore' has no member named 'owner' owner = cmpxchg((long *)&sem->owner, owner, ^~ arch/riscv/include/asm/cmpxchg.h:312:13: note: in definition of macro '__cmpxchg' __typeof__(ptr) __ptr = (ptr); \ ^~~ kernel/locking/rwsem.h:208:11: note: in expansion of macro 'cmpxchg' owner = cmpxchg((long *)&sem->owner, owner, ^~~~~~~ kernel/locking/rwsem.h:208:31: error: 'struct rw_semaphore' has no member named 'owner' owner = cmpxchg((long *)&sem->owner, owner, ^~ arch/riscv/include/asm/cmpxchg.h:312:27: note: in definition of macro '__cmpxchg' __typeof__(ptr) __ptr = (ptr); \ ^~~ kernel/locking/rwsem.h:208:11: note: in expansion of macro 'cmpxchg' owner = cmpxchg((long *)&sem->owner, owner, ^~~~~~~ kernel/locking/rwsem.h:208:31: error: 'struct rw_semaphore' has no member named 'owner' owner = cmpxchg((long *)&sem->owner, owner, ^~ arch/riscv/include/asm/cmpxchg.h:313:15: note: in definition of macro '__cmpxchg' __typeof__(*(ptr)) __old = (old); \ ^~~ kernel/locking/rwsem.h:208:11: note: in expansion of macro 'cmpxchg' owner = cmpxchg((long *)&sem->owner, owner, ^~~~~~~ kernel/locking/rwsem.h:208:31: error: 'struct rw_semaphore' has no member named 'owner' owner = cmpxchg((long *)&sem->owner, owner, ^~ arch/riscv/include/asm/cmpxchg.h:314:15: note: in definition of macro '__cmpxchg' __typeof__(*(ptr)) __new = (new); \ ^~~ kernel/locking/rwsem.h:208:11: note: in expansion of macro 'cmpxchg' owner = cmpxchg((long *)&sem->owner, owner, ^~~~~~~ kernel/locking/rwsem.h:208:31: error: 'struct rw_semaphore' has no member named 'owner' owner = cmpxchg((long *)&sem->owner, owner, ^~ arch/riscv/include/asm/cmpxchg.h:315:15: note: in definition of macro '__cmpxchg' __typeof__(*(ptr)) __ret; \ ^~~ kernel/locking/rwsem.h:208:11: note: in expansion of macro 'cmpxchg' owner = cmpxchg((long *)&sem->owner, owner, ^~~~~~~ kernel/locking/rwsem.h:208:31: error: 'struct rw_semaphore' has no member named 'owner' owner = cmpxchg((long *)&sem->owner, owner, ^~ arch/riscv/include/asm/cmpxchg.h:317:10: note: in definition of macro '__cmpxchg' switch (size) { \ ^~~~ kernel/locking/rwsem.h:208:11: note: in expansion of macro 'cmpxchg' owner = cmpxchg((long *)&sem->owner, owner, ^~~~~~~ >> arch/riscv/include/asm/cmpxchg.h:326:41: error: invalid type argument of >> unary '*' (have 'int') : "=&r" (__ret), "=&r" (__rc), "+A" (*__ptr) \ ^~~~~~ arch/riscv/include/asm/cmpxchg.h:352:23: note: in expansion of macro '__cmpxchg' (__typeof__(*(ptr))) __cmpxchg((ptr), \ ^~~~~~~~~ kernel/locking/rwsem.h:208:11: note: in expansion of macro 'cmpxchg' owner = cmpxchg((long *)&sem->owner, owner, ^~~~~~~ arch/riscv/include/asm/cmpxchg.h:338:41: error: invalid type argument of unary '*' (have 'int') : "=&r" (__ret), "=&r" (__rc), "+A" (*__ptr) \ ^~~~~~ arch/riscv/include/asm/cmpxchg.h:352:23: note: in expansion of macro '__cmpxchg' (__typeof__(*(ptr))) __cmpxchg((ptr), \ ^~~~~~~~~ kernel/locking/rwsem.h:208:11: note: in expansion of macro 'cmpxchg' owner = cmpxchg((long *)&sem->owner, owner, ^~~~~~~ cc1: some warnings being treated as errors -- long owner = (long)READ_ONCE(sem->owner); ^~ include/linux/compiler.h:259:30: note: in definition of macro '__READ_ONCE' __read_once_size_nocheck(&(x), __u.__c, sizeof(x)); \ ^ kernel//locking/rwsem.h:203:21: note: in expansion of macro 'READ_ONCE' long owner = (long)READ_ONCE(sem->owner); ^~~~~~~~~ kernel//locking/rwsem.h:203:34: error: 'struct rw_semaphore' has no member named 'owner' long owner = (long)READ_ONCE(sem->owner); ^~ include/linux/compiler.h:259:50: note: in definition of macro '__READ_ONCE' __read_once_size_nocheck(&(x), __u.__c, sizeof(x)); \ ^ kernel//locking/rwsem.h:203:21: note: in expansion of macro 'READ_ONCE' long owner = (long)READ_ONCE(sem->owner); ^~~~~~~~~ In file included from kernel//locking/percpu-rwsem.c:10: kernel//locking/rwsem.h:205:9: error: implicit declaration of function 'is_rwsem_owner_reader' [-Werror=implicit-function-declaration] while (is_rwsem_owner_reader((struct task_struct *)owner)) { ^~~~~~~~~~~~~~~~~~~~~ kernel//locking/rwsem.h:206:8: error: implicit declaration of function 'is_rwsem_owner_spinnable'; did you mean 'rwsem_set_nonspinnable'? [-Werror=implicit-function-declaration] if (!is_rwsem_owner_spinnable((struct task_struct *)owner)) ^~~~~~~~~~~~~~~~~~~~~~~~ rwsem_set_nonspinnable In file included from arch/riscv/include/asm/atomic.h:23, from include/linux/atomic.h:7, from kernel//locking/percpu-rwsem.c:1: kernel//locking/rwsem.h:208:31: error: 'struct rw_semaphore' has no member named 'owner' owner = cmpxchg((long *)&sem->owner, owner, ^~ arch/riscv/include/asm/cmpxchg.h:350:15: note: in definition of macro 'cmpxchg' __typeof__(*(ptr)) _o_ = (o); \ ^~~ kernel//locking/rwsem.h:208:31: error: 'struct rw_semaphore' has no member named 'owner' owner = cmpxchg((long *)&sem->owner, owner, ^~ arch/riscv/include/asm/cmpxchg.h:351:15: note: in definition of macro 'cmpxchg' __typeof__(*(ptr)) _n_ = (n); \ ^~~ kernel//locking/rwsem.h:208:31: error: 'struct rw_semaphore' has no member named 'owner' owner = cmpxchg((long *)&sem->owner, owner, ^~ arch/riscv/include/asm/cmpxchg.h:352:16: note: in definition of macro 'cmpxchg' (__typeof__(*(ptr))) __cmpxchg((ptr), \ ^~~ kernel//locking/rwsem.h:208:31: error: 'struct rw_semaphore' has no member named 'owner' owner = cmpxchg((long *)&sem->owner, owner, ^~ arch/riscv/include/asm/cmpxchg.h:312:13: note: in definition of macro '__cmpxchg' __typeof__(ptr) __ptr = (ptr); \ ^~~ kernel//locking/rwsem.h:208:11: note: in expansion of macro 'cmpxchg' owner = cmpxchg((long *)&sem->owner, owner, ^~~~~~~ kernel//locking/rwsem.h:208:31: error: 'struct rw_semaphore' has no member named 'owner' owner = cmpxchg((long *)&sem->owner, owner, ^~ arch/riscv/include/asm/cmpxchg.h:312:27: note: in definition of macro '__cmpxchg' __typeof__(ptr) __ptr = (ptr); \ ^~~ kernel//locking/rwsem.h:208:11: note: in expansion of macro 'cmpxchg' owner = cmpxchg((long *)&sem->owner, owner, ^~~~~~~ kernel//locking/rwsem.h:208:31: error: 'struct rw_semaphore' has no member named 'owner' owner = cmpxchg((long *)&sem->owner, owner, ^~ arch/riscv/include/asm/cmpxchg.h:313:15: note: in definition of macro '__cmpxchg' __typeof__(*(ptr)) __old = (old); \ ^~~ kernel//locking/rwsem.h:208:11: note: in expansion of macro 'cmpxchg' owner = cmpxchg((long *)&sem->owner, owner, ^~~~~~~ kernel//locking/rwsem.h:208:31: error: 'struct rw_semaphore' has no member named 'owner' owner = cmpxchg((long *)&sem->owner, owner, ^~ arch/riscv/include/asm/cmpxchg.h:314:15: note: in definition of macro '__cmpxchg' __typeof__(*(ptr)) __new = (new); \ ^~~ kernel//locking/rwsem.h:208:11: note: in expansion of macro 'cmpxchg' owner = cmpxchg((long *)&sem->owner, owner, ^~~~~~~ kernel//locking/rwsem.h:208:31: error: 'struct rw_semaphore' has no member named 'owner' owner = cmpxchg((long *)&sem->owner, owner, ^~ arch/riscv/include/asm/cmpxchg.h:315:15: note: in definition of macro '__cmpxchg' __typeof__(*(ptr)) __ret; \ ^~~ kernel//locking/rwsem.h:208:11: note: in expansion of macro 'cmpxchg' owner = cmpxchg((long *)&sem->owner, owner, ^~~~~~~ kernel//locking/rwsem.h:208:31: error: 'struct rw_semaphore' has no member named 'owner' owner = cmpxchg((long *)&sem->owner, owner, ^~ arch/riscv/include/asm/cmpxchg.h:317:10: note: in definition of macro '__cmpxchg' switch (size) { \ ^~~~ kernel//locking/rwsem.h:208:11: note: in expansion of macro 'cmpxchg' owner = cmpxchg((long *)&sem->owner, owner, ^~~~~~~ >> arch/riscv/include/asm/cmpxchg.h:326:41: error: invalid type argument of >> unary '*' (have 'int') : "=&r" (__ret), "=&r" (__rc), "+A" (*__ptr) \ ^~~~~~ arch/riscv/include/asm/cmpxchg.h:352:23: note: in expansion of macro '__cmpxchg' (__typeof__(*(ptr))) __cmpxchg((ptr), \ ^~~~~~~~~ kernel//locking/rwsem.h:208:11: note: in expansion of macro 'cmpxchg' owner = cmpxchg((long *)&sem->owner, owner, ^~~~~~~ arch/riscv/include/asm/cmpxchg.h:338:41: error: invalid type argument of unary '*' (have 'int') : "=&r" (__ret), "=&r" (__rc), "+A" (*__ptr) \ ^~~~~~ arch/riscv/include/asm/cmpxchg.h:352:23: note: in expansion of macro '__cmpxchg' (__typeof__(*(ptr))) __cmpxchg((ptr), \ ^~~~~~~~~ kernel//locking/rwsem.h:208:11: note: in expansion of macro 'cmpxchg' owner = cmpxchg((long *)&sem->owner, owner, ^~~~~~~ cc1: some warnings being treated as errors vim +326 arch/riscv/include/asm/cmpxchg.h 5ce6c1f3 Andrea Parri 2018-03-09 309 5ce6c1f3 Andrea Parri 2018-03-09 310 #define __cmpxchg(ptr, old, new, size) \ 5ce6c1f3 Andrea Parri 2018-03-09 311 ({ \ 5ce6c1f3 Andrea Parri 2018-03-09 312 __typeof__(ptr) __ptr = (ptr); \ 5ce6c1f3 Andrea Parri 2018-03-09 313 __typeof__(*(ptr)) __old = (old); \ 5ce6c1f3 Andrea Parri 2018-03-09 314 __typeof__(*(ptr)) __new = (new); \ 5ce6c1f3 Andrea Parri 2018-03-09 315 __typeof__(*(ptr)) __ret; \ 5ce6c1f3 Andrea Parri 2018-03-09 316 register unsigned int __rc; \ 5ce6c1f3 Andrea Parri 2018-03-09 @317 switch (size) { \ 5ce6c1f3 Andrea Parri 2018-03-09 318 case 4: \ 5ce6c1f3 Andrea Parri 2018-03-09 319 __asm__ __volatile__ ( \ 5ce6c1f3 Andrea Parri 2018-03-09 320 "0: lr.w %0, %2\n" \ 5ce6c1f3 Andrea Parri 2018-03-09 321 " bne %0, %z3, 1f\n" \ 5ce6c1f3 Andrea Parri 2018-03-09 322 " sc.w.rl %1, %z4, %2\n" \ 5ce6c1f3 Andrea Parri 2018-03-09 323 " bnez %1, 0b\n" \ 5ce6c1f3 Andrea Parri 2018-03-09 324 " fence rw, rw\n" \ 5ce6c1f3 Andrea Parri 2018-03-09 325 "1:\n" \ 5ce6c1f3 Andrea Parri 2018-03-09 @326 : "=&r" (__ret), "=&r" (__rc), "+A" (*__ptr) \ 5ce6c1f3 Andrea Parri 2018-03-09 327 : "rJ" (__old), "rJ" (__new) \ 5ce6c1f3 Andrea Parri 2018-03-09 328 : "memory"); \ 5ce6c1f3 Andrea Parri 2018-03-09 329 break; \ 5ce6c1f3 Andrea Parri 2018-03-09 330 case 8: \ 5ce6c1f3 Andrea Parri 2018-03-09 331 __asm__ __volatile__ ( \ 5ce6c1f3 Andrea Parri 2018-03-09 332 "0: lr.d %0, %2\n" \ 5ce6c1f3 Andrea Parri 2018-03-09 333 " bne %0, %z3, 1f\n" \ 5ce6c1f3 Andrea Parri 2018-03-09 334 " sc.d.rl %1, %z4, %2\n" \ 5ce6c1f3 Andrea Parri 2018-03-09 335 " bnez %1, 0b\n" \ 5ce6c1f3 Andrea Parri 2018-03-09 336 " fence rw, rw\n" \ 5ce6c1f3 Andrea Parri 2018-03-09 337 "1:\n" \ fab957c1 Palmer Dabbelt 2017-07-10 338 : "=&r" (__ret), "=&r" (__rc), "+A" (*__ptr) \ fab957c1 Palmer Dabbelt 2017-07-10 339 : "rJ" (__old), "rJ" (__new) \ fab957c1 Palmer Dabbelt 2017-07-10 340 : "memory"); \ fab957c1 Palmer Dabbelt 2017-07-10 341 break; \ fab957c1 Palmer Dabbelt 2017-07-10 342 default: \ fab957c1 Palmer Dabbelt 2017-07-10 343 BUILD_BUG(); \ fab957c1 Palmer Dabbelt 2017-07-10 344 } \ fab957c1 Palmer Dabbelt 2017-07-10 345 __ret; \ fab957c1 Palmer Dabbelt 2017-07-10 346 }) fab957c1 Palmer Dabbelt 2017-07-10 347 :::::: The code at line 326 was first introduced by commit :::::: 5ce6c1f3535fa8d2134468547377b7b737042834 riscv/atomic: Strengthen implementations with fences :::::: TO: Andrea Parri <parri.and...@gmail.com> :::::: CC: Palmer Dabbelt <pal...@sifive.com> --- 0-DAY kernel test infrastructure Open Source Technology Center https://lists.01.org/pipermail/kbuild-all Intel Corporation
.config.gz
Description: application/gzip