Skip to content

[PW_SID:967488] riscv: use generic MMIO accessors#455

Closed
linux-riscv-bot wants to merge 1 commit into
workflow__riscv__fixesfrom
pw967488
Closed

[PW_SID:967488] riscv: use generic MMIO accessors#455
linux-riscv-bot wants to merge 1 commit into
workflow__riscv__fixesfrom
pw967488

Conversation

@linux-riscv-bot
Copy link
Copy Markdown

PR for series 967488 applied to workflow__riscv__fixes

Name: riscv: use generic MMIO accessors
URL: https://patchwork.kernel.org/project/linux-riscv/list/?series=967488
Version: 1

RISC-V IO just reads/writes the memory location directly, so remove
those __raw_read/write* definitions and use the generic accessors
instead.
The __io_reads_ins and __io_writes_outs macros are updated accordingly,
as they don't have access to the generic accessors.
Simplifies the code with no functional change.

Signed-off-by: Qingfang Deng <dqfext@gmail.com>
Signed-off-by: Linux RISC-V bot <linux.riscv.bot@gmail.com>
@linux-riscv-bot
Copy link
Copy Markdown
Author

Patch 1: "riscv: use generic MMIO accessors"
build-rv32-defconfig
Desc: Builds riscv32 defconfig
Duration: 107.40 seconds
Result: PASS

@linux-riscv-bot
Copy link
Copy Markdown
Author

Patch 1: "riscv: use generic MMIO accessors"
build-rv64-clang-allmodconfig
Desc: Builds riscv64 allmodconfig with Clang, and checks for errors and added warnings
Duration: 1734.93 seconds
Result: ERROR
Output:

Redirect to /build/tmp.JKLDKLQlNK and /build/tmp.izvbFY9DMd
Tree base:
400e3f8e57626 ("Adding CI files")
Building the whole tree with the patch
Building the tree before the patch
Building the tree with the patch
New errors added:
--- /build/tmp.S9cVGm0nWb	2025-05-30 04:20:28.629045131 +0000
+++ /build/tmp.qImZK7VkQH	2025-05-30 04:20:28.634045093 +0000
@@ -182,0 +183,2 @@
+      1 /build/tmp_agz_37n/drivers/gpu/drm/omapdrm/dss/dispc.c:4720:27: warning: stack frame size (2304) exceeds limit (2048) in 'dispc_runtime_suspend' [-Wframe-larger-than]
+      1 /build/tmp_agz_37n/drivers/gpu/drm/omapdrm/dss/dispc.c:4735:27: warning: stack frame size (2416) exceeds limit (2048) in 'dispc_runtime_resume' [-Wframe-larger-than]
Per-file breakdown
error/warning file pre:
error/warning file post:
pre: 773 post: 775



real	13m41.600s
user	511m31.399s
sys	99m59.768s

real	12m16.059s
user	391m33.104s
sys	75m13.229s

real	2m47.456s
user	23m51.948s
sys	18m15.257s

@linux-riscv-bot
Copy link
Copy Markdown
Author

Patch 1: "riscv: use generic MMIO accessors"
build-rv64-gcc-allmodconfig
Desc: Builds riscv64 allmodconfig with GCC, and checks for errors and added warnings
Duration: 2198.19 seconds
Result: PASS

@linux-riscv-bot
Copy link
Copy Markdown
Author

Patch 1: "riscv: use generic MMIO accessors"
build-rv64-nommu-k210-defconfig
Desc: Builds riscv64 defconfig with NOMMU for K210
Duration: 9.55 seconds
Result: ERROR
Output:

Full log:
W: Support for running offline not available (unshare: unshare failed: Operation not permitted)
I: config: PASS in 0:00:03.523854
I: default: FAIL in 0:00:01.888097
I: kernel: SKIP in 0:00:00.000010
I: xipkernel: SKIP in 0:00:00.000004
I: modules: SKIP in 0:00:00.003575
I: dtbs: PASS in 0:00:00.942997
I: dtbs-legacy: SKIP in 0:00:00.004592
I: debugkernel: SKIP in 0:00:00.000005
I: headers: PASS in 0:00:01.161753
I: build output in /build/tmp.ZcTAEZToRA
tuxmake --download-all-korg-gcc-toolchains --target-arch=riscv --kconfig=nommu_k210_defconfig --toolchain=gcc --wrapper=ccache --environment=KBUILD_BUILD_TIMESTAMP=@1621270510 --environment=KBUILD_BUILD_USER=tuxmake --environment=KBUILD_BUILD_HOST=tuxmake --environment=KCFLAGS=-ffile-prefix-map=/build/tmp.ZcTAEZToRA/build/= --runtime=null --image=docker.io/tuxmake/riscv_gcc CROSS_COMPILE=riscv64-linux- config default kernel xipkernel modules dtbs dtbs-legacy debugkernel headers
make --silent --keep-going --jobs=48 O=/build/tmp.ZcTAEZToRA/build ARCH=riscv CROSS_COMPILE=riscv64-linux- 'CC=ccache riscv64-linux-gcc' 'HOSTCC=ccache gcc' nommu_k210_defconfig
make --silent --keep-going --jobs=48 O=/build/tmp.ZcTAEZToRA/build ARCH=riscv CROSS_COMPILE=riscv64-linux- 'CC=ccache riscv64-linux-gcc' 'HOSTCC=ccache gcc'
In file included from /build/tmp_agz_37n/include/linux/byteorder/little_endian.h:5,
                 from /build/tmp_agz_37n/arch/riscv/include/uapi/asm/byteorder.h:10,
                 from /build/tmp_agz_37n/include/asm-generic/qrwlock_types.h:6,
                 from /build/tmp_agz_37n/include/asm-generic/spinlock_types.h:7,
                 from ./arch/riscv/include/generated/asm/spinlock_types.h:1,
                 from /build/tmp_agz_37n/include/linux/spinlock_types_raw.h:7,
                 from /build/tmp_agz_37n/include/linux/ratelimit_types.h:7,
                 from /build/tmp_agz_37n/include/linux/printk.h:9,
                 from /build/tmp_agz_37n/include/asm-generic/bug.h:22,
                 from /build/tmp_agz_37n/arch/riscv/include/asm/bug.h:83,
                 from /build/tmp_agz_37n/include/linux/bug.h:5,
                 from /build/tmp_agz_37n/include/linux/mmdebug.h:5,
                 from /build/tmp_agz_37n/include/linux/mm.h:6,
                 from /build/tmp_agz_37n/arch/riscv/kernel/asm-offsets.c:8:
/build/tmp_agz_37n/arch/riscv/include/asm/timex.h: In function 'get_cycles':
/build/tmp_agz_37n/arch/riscv/include/asm/mmio.h:32:74: error: implicit declaration of function '__raw_readq' [-Wimplicit-function-declaration]
   32 | #define readq_cpu(c)            ({ u64 __r = le64_to_cpu((__force __le64)__raw_readq(c)); __r; })
      |                                                                          ^~~~~~~~~~~
/build/tmp_agz_37n/include/uapi/linux/byteorder/little_endian.h:33:51: note: in definition of macro '__le64_to_cpu'
   33 | #define __le64_to_cpu(x) ((__force __u64)(__le64)(x))
      |                                                   ^
/build/tmp_agz_37n/arch/riscv/include/asm/mmio.h:59:63: note: in expansion of macro 'readq_cpu'
   59 | #define readq_relaxed(c)        ({ u64 __v; __io_rbr(); __v = readq_cpu(c); __io_rar(); __v; })
      |                                                               ^~~~~~~~~
/build/tmp_agz_37n/arch/riscv/include/asm/timex.h:20:16: note: in expansion of macro 'readq_relaxed'
   20 |         return readq_relaxed(clint_time_val);
      |                ^~~~~~~~~~~~~
In file included from /build/tmp_agz_37n/arch/riscv/include/asm/io.h:136,
                 from /build/tmp_agz_37n/include/linux/io.h:12,
                 from /build/tmp_agz_37n/include/linux/irq.h:20,
                 from /build/tmp_agz_37n/include/asm-generic/hardirq.h:17,
                 from ./arch/riscv/include/generated/asm/hardirq.h:1,
                 from /build/tmp_agz_37n/include/linux/hardirq.h:11,
                 from /build/tmp_agz_37n/include/linux/interrupt.h:11,
                 from /build/tmp_agz_37n/include/linux/trace_recursion.h:5,
                 from /build/tmp_agz_37n/include/linux/ftrace.h:10,
                 from /build/tmp_agz_37n/arch/riscv/kernel/asm-offsets.c:10:
/build/tmp_agz_37n/include/asm-generic/io.h: At top level:
/build/tmp_agz_37n/include/asm-generic/io.h:139:21: error: conflicting types for '__raw_readq'; have 'u64(const volatile void *)' {aka 'long long unsigned int(const volatile void *)'}
  139 | #define __raw_readq __raw_readq
      |                     ^~~~~~~~~~~
/build/tmp_agz_37n/include/asm-generic/io.h:140:19: note: in expansion of macro '__raw_readq'
  140 | static inline u64 __raw_readq(const volatile void __iomem *addr)
      |                   ^~~~~~~~~~~
/build/tmp_agz_37n/arch/riscv/include/asm/mmio.h:32:74: note: previous implicit declaration of '__raw_readq' with type 'int()'
   32 | #define readq_cpu(c)            ({ u64 __r = le64_to_cpu((__force __le64)__raw_readq(c)); __r; })
      |                                                                          ^~~~~~~~~~~
/build/tmp_agz_37n/include/uapi/linux/byteorder/little_endian.h:33:51: note: in definition of macro '__le64_to_cpu'
   33 | #define __le64_to_cpu(x) ((__force __u64)(__le64)(x))
      |                                                   ^
/build/tmp_agz_37n/arch/riscv/include/asm/mmio.h:59:63: note: in expansion of macro 'readq_cpu'
   59 | #define readq_relaxed(c)        ({ u64 __v; __io_rbr(); __v = readq_cpu(c); __io_rar(); __v; })
      |                                                               ^~~~~~~~~
/build/tmp_agz_37n/arch/riscv/include/asm/timex.h:20:16: note: in expansion of macro 'readq_relaxed'
   20 |         return readq_relaxed(clint_time_val);
      |                ^~~~~~~~~~~~~
make[3]: *** [/build/tmp_agz_37n/scripts/Makefile.build:98: arch/riscv/kernel/asm-offsets.s] Error 1
make[3]: Target 'prepare' not remade because of errors.
make[2]: *** [/build/tmp_agz_37n/Makefile:1275: prepare0] Error 2
make[2]: Target '__all' not remade because of errors.
make[1]: *** [/build/tmp_agz_37n/Makefile:248: __sub-make] Error 2
make[1]: Target '__all' not remade because of errors.
make: *** [Makefile:248: __sub-make] Error 2
make: Target '__all' not remade because of errors.
make --silent --keep-going --jobs=48 O=/build/tmp.ZcTAEZToRA/build INSTALL_DTBS_PATH=/build/tmp.ZcTAEZToRA/build/dtbsinstall/dtbs ARCH=riscv CROSS_COMPILE=riscv64-linux- 'CC=ccache riscv64-linux-gcc' 'HOSTCC=ccache gcc' dtbs
rm -rf /build/tmp.ZcTAEZToRA/build/dtbsinstall
mkdir -p /build/tmp.ZcTAEZToRA/build/dtbsinstall/dtbs
make --silent --keep-going --jobs=48 O=/build/tmp.ZcTAEZToRA/build INSTALL_DTBS_PATH=/build/tmp.ZcTAEZToRA/build/dtbsinstall/dtbs ARCH=riscv CROSS_COMPILE=riscv64-linux- 'CC=ccache riscv64-linux-gcc' 'HOSTCC=ccache gcc' dtbs_install
tar --sort=name --owner=tuxmake:1000 --group=tuxmake:1000 --mtime=@1748576774 --clamp-mtime -caf /build/tmp.ZcTAEZToRA/build/dtbs.tar -C /build/tmp.ZcTAEZToRA/build/dtbsinstall dtbs
rm -rf /build/tmp.ZcTAEZToRA/build/install_hdr
make --silent --keep-going --jobs=48 O=/build/tmp.ZcTAEZToRA/build INSTALL_HDR_PATH=/build/tmp.ZcTAEZToRA/build/install_hdr/ ARCH=riscv CROSS_COMPILE=riscv64-linux- 'CC=ccache riscv64-linux-gcc' 'HOSTCC=ccache gcc' headers_install
tar --sort=name --owner=tuxmake:1000 --group=tuxmake:1000 --mtime=@1748576774 --clamp-mtime -caf /build/tmp.ZcTAEZToRA/build/headers.tar -C /build/tmp.ZcTAEZToRA/build/install_hdr .
warnings/errors:
/build/tmp_agz_37n/arch/riscv/include/asm/mmio.h:32:74: error: implicit declaration of function '__raw_readq' [-Wimplicit-function-declaration]
/build/tmp_agz_37n/include/asm-generic/io.h:139:21: error: conflicting types for '__raw_readq'; have 'u64(const volatile void *)' {aka 'long long unsigned int(const volatile void *)'}


@linux-riscv-bot
Copy link
Copy Markdown
Author

Patch 1: "riscv: use generic MMIO accessors"
build-rv64-nommu-k210-virt
Desc: Builds riscv64 defconfig with NOMMU for the virt platform
Duration: 9.75 seconds
Result: ERROR
Output:

Full log:
W: Support for running offline not available (unshare: unshare failed: Operation not permitted)
I: config: PASS in 0:00:03.572129
I: default: FAIL in 0:00:01.819172
I: kernel: SKIP in 0:00:00.000009
I: xipkernel: SKIP in 0:00:00.000004
I: modules: SKIP in 0:00:00.003082
I: dtbs: PASS in 0:00:00.947205
I: dtbs-legacy: SKIP in 0:00:00.004641
I: debugkernel: SKIP in 0:00:00.000005
I: headers: PASS in 0:00:01.084792
I: build output in /build/tmp.iFRgUZY4J8
tuxmake --download-all-korg-gcc-toolchains --target-arch=riscv --kconfig=nommu_virt_defconfig --toolchain=gcc --wrapper=ccache --environment=KBUILD_BUILD_TIMESTAMP=@1621270510 --environment=KBUILD_BUILD_USER=tuxmake --environment=KBUILD_BUILD_HOST=tuxmake --environment=KCFLAGS=-ffile-prefix-map=/build/tmp.iFRgUZY4J8/build/= --runtime=null --image=docker.io/tuxmake/riscv_gcc CROSS_COMPILE=riscv64-linux- config default kernel xipkernel modules dtbs dtbs-legacy debugkernel headers
make --silent --keep-going --jobs=48 O=/build/tmp.iFRgUZY4J8/build ARCH=riscv CROSS_COMPILE=riscv64-linux- 'CC=ccache riscv64-linux-gcc' 'HOSTCC=ccache gcc' nommu_virt_defconfig
make --silent --keep-going --jobs=48 O=/build/tmp.iFRgUZY4J8/build ARCH=riscv CROSS_COMPILE=riscv64-linux- 'CC=ccache riscv64-linux-gcc' 'HOSTCC=ccache gcc'
In file included from /build/tmp_agz_37n/include/linux/byteorder/little_endian.h:5,
                 from /build/tmp_agz_37n/arch/riscv/include/uapi/asm/byteorder.h:10,
                 from /build/tmp_agz_37n/include/asm-generic/qrwlock_types.h:6,
                 from /build/tmp_agz_37n/include/asm-generic/spinlock_types.h:7,
                 from ./arch/riscv/include/generated/asm/spinlock_types.h:1,
                 from /build/tmp_agz_37n/include/linux/spinlock_types_raw.h:7,
                 from /build/tmp_agz_37n/include/linux/ratelimit_types.h:7,
                 from /build/tmp_agz_37n/include/linux/printk.h:9,
                 from /build/tmp_agz_37n/include/asm-generic/bug.h:22,
                 from /build/tmp_agz_37n/arch/riscv/include/asm/bug.h:83,
                 from /build/tmp_agz_37n/include/linux/bug.h:5,
                 from /build/tmp_agz_37n/include/linux/mmdebug.h:5,
                 from /build/tmp_agz_37n/include/linux/mm.h:6,
                 from /build/tmp_agz_37n/arch/riscv/kernel/asm-offsets.c:8:
/build/tmp_agz_37n/arch/riscv/include/asm/timex.h: In function 'get_cycles':
/build/tmp_agz_37n/arch/riscv/include/asm/mmio.h:32:74: error: implicit declaration of function '__raw_readq' [-Wimplicit-function-declaration]
   32 | #define readq_cpu(c)            ({ u64 __r = le64_to_cpu((__force __le64)__raw_readq(c)); __r; })
      |                                                                          ^~~~~~~~~~~
/build/tmp_agz_37n/include/uapi/linux/byteorder/little_endian.h:33:51: note: in definition of macro '__le64_to_cpu'
   33 | #define __le64_to_cpu(x) ((__force __u64)(__le64)(x))
      |                                                   ^
/build/tmp_agz_37n/arch/riscv/include/asm/mmio.h:59:63: note: in expansion of macro 'readq_cpu'
   59 | #define readq_relaxed(c)        ({ u64 __v; __io_rbr(); __v = readq_cpu(c); __io_rar(); __v; })
      |                                                               ^~~~~~~~~
/build/tmp_agz_37n/arch/riscv/include/asm/timex.h:20:16: note: in expansion of macro 'readq_relaxed'
   20 |         return readq_relaxed(clint_time_val);
      |                ^~~~~~~~~~~~~
In file included from /build/tmp_agz_37n/arch/riscv/include/asm/io.h:136,
                 from /build/tmp_agz_37n/include/linux/io.h:12,
                 from /build/tmp_agz_37n/include/linux/irq.h:20,
                 from /build/tmp_agz_37n/include/asm-generic/hardirq.h:17,
                 from ./arch/riscv/include/generated/asm/hardirq.h:1,
                 from /build/tmp_agz_37n/include/linux/hardirq.h:11,
                 from /build/tmp_agz_37n/include/linux/interrupt.h:11,
                 from /build/tmp_agz_37n/include/linux/trace_recursion.h:5,
                 from /build/tmp_agz_37n/include/linux/ftrace.h:10,
                 from /build/tmp_agz_37n/arch/riscv/kernel/asm-offsets.c:10:
/build/tmp_agz_37n/include/asm-generic/io.h: At top level:
/build/tmp_agz_37n/include/asm-generic/io.h:139:21: error: conflicting types for '__raw_readq'; have 'u64(const volatile void *)' {aka 'long long unsigned int(const volatile void *)'}
  139 | #define __raw_readq __raw_readq
      |                     ^~~~~~~~~~~
/build/tmp_agz_37n/include/asm-generic/io.h:140:19: note: in expansion of macro '__raw_readq'
  140 | static inline u64 __raw_readq(const volatile void __iomem *addr)
      |                   ^~~~~~~~~~~
/build/tmp_agz_37n/arch/riscv/include/asm/mmio.h:32:74: note: previous implicit declaration of '__raw_readq' with type 'int()'
   32 | #define readq_cpu(c)            ({ u64 __r = le64_to_cpu((__force __le64)__raw_readq(c)); __r; })
      |                                                                          ^~~~~~~~~~~
/build/tmp_agz_37n/include/uapi/linux/byteorder/little_endian.h:33:51: note: in definition of macro '__le64_to_cpu'
   33 | #define __le64_to_cpu(x) ((__force __u64)(__le64)(x))
      |                                                   ^
/build/tmp_agz_37n/arch/riscv/include/asm/mmio.h:59:63: note: in expansion of macro 'readq_cpu'
   59 | #define readq_relaxed(c)        ({ u64 __v; __io_rbr(); __v = readq_cpu(c); __io_rar(); __v; })
      |                                                               ^~~~~~~~~
/build/tmp_agz_37n/arch/riscv/include/asm/timex.h:20:16: note: in expansion of macro 'readq_relaxed'
   20 |         return readq_relaxed(clint_time_val);
      |                ^~~~~~~~~~~~~
make[3]: *** [/build/tmp_agz_37n/scripts/Makefile.build:98: arch/riscv/kernel/asm-offsets.s] Error 1
make[3]: Target 'prepare' not remade because of errors.
make[2]: *** [/build/tmp_agz_37n/Makefile:1275: prepare0] Error 2
make[2]: Target '__all' not remade because of errors.
make[1]: *** [/build/tmp_agz_37n/Makefile:248: __sub-make] Error 2
make[1]: Target '__all' not remade because of errors.
make: *** [Makefile:248: __sub-make] Error 2
make: Target '__all' not remade because of errors.
make --silent --keep-going --jobs=48 O=/build/tmp.iFRgUZY4J8/build INSTALL_DTBS_PATH=/build/tmp.iFRgUZY4J8/build/dtbsinstall/dtbs ARCH=riscv CROSS_COMPILE=riscv64-linux- 'CC=ccache riscv64-linux-gcc' 'HOSTCC=ccache gcc' dtbs
rm -rf /build/tmp.iFRgUZY4J8/build/dtbsinstall
mkdir -p /build/tmp.iFRgUZY4J8/build/dtbsinstall/dtbs
make --silent --keep-going --jobs=48 O=/build/tmp.iFRgUZY4J8/build INSTALL_DTBS_PATH=/build/tmp.iFRgUZY4J8/build/dtbsinstall/dtbs ARCH=riscv CROSS_COMPILE=riscv64-linux- 'CC=ccache riscv64-linux-gcc' 'HOSTCC=ccache gcc' dtbs_install
tar --sort=name --owner=tuxmake:1000 --group=tuxmake:1000 --mtime=@1748576774 --clamp-mtime -caf /build/tmp.iFRgUZY4J8/build/dtbs.tar -C /build/tmp.iFRgUZY4J8/build/dtbsinstall dtbs
rm -rf /build/tmp.iFRgUZY4J8/build/install_hdr
make --silent --keep-going --jobs=48 O=/build/tmp.iFRgUZY4J8/build INSTALL_HDR_PATH=/build/tmp.iFRgUZY4J8/build/install_hdr/ ARCH=riscv CROSS_COMPILE=riscv64-linux- 'CC=ccache riscv64-linux-gcc' 'HOSTCC=ccache gcc' headers_install
tar --sort=name --owner=tuxmake:1000 --group=tuxmake:1000 --mtime=@1748576774 --clamp-mtime -caf /build/tmp.iFRgUZY4J8/build/headers.tar -C /build/tmp.iFRgUZY4J8/build/install_hdr .
warnings/errors:
/build/tmp_agz_37n/arch/riscv/include/asm/mmio.h:32:74: error: implicit declaration of function '__raw_readq' [-Wimplicit-function-declaration]
/build/tmp_agz_37n/include/asm-generic/io.h:139:21: error: conflicting types for '__raw_readq'; have 'u64(const volatile void *)' {aka 'long long unsigned int(const volatile void *)'}


@linux-riscv-bot
Copy link
Copy Markdown
Author

Patch 1: "riscv: use generic MMIO accessors"
checkpatch
Desc: Runs checkpatch.pl on the patch
Duration: 1.59 seconds
Result: WARNING
Output:

WARNING: Use of volatile is usually wrong: see Documentation/process/volatile-considered-harmful.rst
#29: FILE: arch/riscv/include/asm/io.h:71:
+				ctype x = *(const volatile ctype __force *)addr;\

WARNING: Use of volatile is usually wrong: see Documentation/process/volatile-considered-harmful.rst
#38: FILE: arch/riscv/include/asm/io.h:88:
+				*(volatile ctype __force *)addr = *buf++;	\

total: 0 errors, 2 warnings, 0 checks, 87 lines checked

NOTE: For some of the reported defects, checkpatch may be able to
      mechanically convert to the typical style using --fix or --fix-inplace.

Commit 827f64699b0a ("riscv: use generic MMIO accessors") has style problems, please review.

NOTE: Ignored message types: ALLOC_SIZEOF_STRUCT CAMELCASE COMMIT_LOG_LONG_LINE GIT_COMMIT_ID MACRO_ARG_REUSE NO_AUTHOR_SIGN_OFF

NOTE: If any of the errors are false positives, please report
      them to the maintainer, see CHECKPATCH in MAINTAINERS.
total: 0 errors, 2 warnings, 0 checks, 87 lines checked
WARNING: Use of volatile is usually wrong: see Documentation/process/volatile-considered-harmful.rst


@linux-riscv-bot
Copy link
Copy Markdown
Author

Patch 1: "riscv: use generic MMIO accessors"
dtb-warn-rv64
Desc: Checks for Device Tree warnings/errors
Duration: 68.36 seconds
Result: PASS

@linux-riscv-bot
Copy link
Copy Markdown
Author

Patch 1: "riscv: use generic MMIO accessors"
header-inline
Desc: Detects static functions without inline keyword in header files
Duration: 0.23 seconds
Result: PASS

@linux-riscv-bot
Copy link
Copy Markdown
Author

Patch 1: "riscv: use generic MMIO accessors"
kdoc
Desc: Detects for kdoc errors
Duration: 0.91 seconds
Result: PASS

@linux-riscv-bot
Copy link
Copy Markdown
Author

Patch 1: "riscv: use generic MMIO accessors"
module-param
Desc: Detect module_param changes
Duration: 0.25 seconds
Result: PASS

@linux-riscv-bot
Copy link
Copy Markdown
Author

Patch 1: "riscv: use generic MMIO accessors"
verify-fixes
Desc: Verifies that the Fixes: tags exist
Duration: 0.22 seconds
Result: PASS

@linux-riscv-bot
Copy link
Copy Markdown
Author

Patch 1: "riscv: use generic MMIO accessors"
verify-signedoff
Desc: Verifies that Signed-off-by: tags are correct
Duration: 0.29 seconds
Result: PASS

@linux-riscv-bot linux-riscv-bot deleted the pw967488 branch June 7, 2025 01:04
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

2 participants