[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-Id: <20251209100313.2867-10-david.laight.linux@gmail.com>
Date: Tue, 9 Dec 2025 10:03:13 +0000
From: david.laight.linux@...il.com
To: Yury Norov <yury.norov@...il.com>,
Rasmus Villemoes <linux@...musvillemoes.dk>,
linux-kernel@...r.kernel.org,
linux-usb@...r.kernel.org,
Geert Uytterhoeven <geert+renesas@...der.be>,
Alexandre Belloni <alexandre.belloni@...tlin.com>,
Jonathan Cameron <Jonathan.Cameron@...wei.com>,
Crt Mori <cmo@...exis.com>,
Richard Genoud <richard.genoud@...tlin.com>,
Andy Shevchenko <andriy.shevchenko@...el.com>,
Luo Jie <quic_luoj@...cinc.com>,
Peter Zijlstra <peterz@...radead.org>,
Jakub Kicinski <kuba@...nel.org>,
netdev@...r.kernel.org,
"David S . Miller" <davem@...emloft.net>,
Simon Horman <simon.horman@...ronome.com>,
Mika Westerberg <mika.westerberg@...ux.intel.com>,
Andreas Noever <andreas.noever@...il.com>,
Yehezkel Bernat <YehezkelShB@...il.com>,
Nicolas Frattaroli <nicolas.frattaroli@...labora.com>
Cc: David Laight <david.laight.linux@...il.com>
Subject: [PATCH 9/9] bitfield: Update comments for le/be functions
From: David Laight <david.laight.linux@...il.com>
Make it clear the the values are converted to host order before
being acted on.
Order the explantions with the simple functions first.
These still need converting to kerneldoc format.
Signed-off-by: David Laight <david.laight.linux@...il.com>
---
include/linux/bitfield.h | 38 ++++++++++++++++++--------------------
1 file changed, 18 insertions(+), 20 deletions(-)
diff --git a/include/linux/bitfield.h b/include/linux/bitfield.h
index 9feb489a8da3..dcc4809b4706 100644
--- a/include/linux/bitfield.h
+++ b/include/linux/bitfield.h
@@ -184,24 +184,24 @@ do { \
/*
* Primitives for manipulating bitfields both in host- and fixed-endian.
*
- * * u32 le32_get_bits(__le32 val, u32 field) extracts the contents of the
- * bitfield specified by @field in little-endian 32bit object @val and
- * converts it to host-endian.
*
- * * void le32p_replace_bits(__le32 *p, u32 v, u32 field) replaces
- * the contents of the bitfield specified by @field in little-endian
- * 32bit object pointed to by @p with the value of @v. New value is
- * given in host-endian and stored as little-endian.
+ * * u32 le32_get_bits(__le32 val, u32 field) converts the little-endian 32bit
+ * object @val to host-endian then extracts the contents of the bitfield
+ * specified by @field.
+ *
+ * * __le32 le32_encode_bits(u32 v, u32 field) encodes the value of @v into
+ * the bitfield specified by @field then converts the value to little-endian.
+ * All the bits outside that bitfield being zero.
*
- * * __le32 le32_replace_bits(__le32 old, u32 v, u32 field) is equivalent to
- * ({__le32 tmp = old; le32p_replace_bits(&tmp, v, field); tmp;})
- * In other words, instead of modifying an object in memory, it takes
- * the initial value and returns the modified one.
+ * * __le32 le32_replace_bits(__le32 old, u32 v, u32 field) converts the
+ * little-endian 32bit object @old to host order, replaces the contents
+ * of the bitfield specified by @field with @v, then returns the value
+ * converted back to little-endian.
*
- * * __le32 le32_encode_bits(u32 v, u32 field) is equivalent to
- * le32_replace_bits(0, v, field). In other words, it returns a little-endian
- * 32bit object with the bitfield specified by @field containing the
- * value of @v and all bits outside that bitfield being zero.
+ * * void le32p_replace_bits(__le32 *p, u32 v, u32 field) replaces
+ * the contents of the bitfield specified by @field in little-endian
+ * 32bit object pointed to by @p with the value of @v.
+ * Equivalent to *p = le32_replace_bits(*p, v, field).
*
* Such set of helpers is defined for each of little-, big- and host-endian
* types; e.g. u64_get_bits(val, field) will return the contents of the bitfield
@@ -210,15 +210,13 @@ do { \
*
* Fields to access are specified as GENMASK() values - an N-bit field
* starting at bit #M is encoded as GENMASK(M + N - 1, M). Note that
- * bit numbers refer to endianness of the object we are working with -
+ * bit numbers refer to the value after being converted to host order -
* e.g. GENMASK(11, 0) in __be16 refers to the second byte and the lower
* 4 bits of the first byte. In __le16 it would refer to the first byte
* and the lower 4 bits of the second byte, etc.
*
- * Field specification must be a constant; __builtin_constant_p() doesn't
- * have to be true for it, but compiler must be able to evaluate it at
- * build time. If it cannot or if the value does not encode any bitfield,
- * the build will fail.
+ * Field specification must be a non-zero constant, otherwise the build
+ * will fail.
*
* If the value being stored in a bitfield is a constant that does not fit
* into that bitfield, a warning will be generated at compile time.
--
2.39.5
Powered by blists - more mailing lists