]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
minmax: make generic MIN() and MAX() macros available everywhere
authorLinus Torvalds <torvalds@linux-foundation.org>
Mon, 29 Sep 2025 17:17:22 +0000 (17:17 +0000)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Thu, 2 Oct 2025 11:42:55 +0000 (13:42 +0200)
[ Upstream commit 1a251f52cfdc417c84411a056bc142cbd77baef4 ]

This just standardizes the use of MIN() and MAX() macros, with the very
traditional semantics.  The goal is to use these for C constant
expressions and for top-level / static initializers, and so be able to
simplify the min()/max() macros.

These macro names were used by various kernel code - they are very
traditional, after all - and all such users have been fixed up, with a
few different approaches:

 - trivial duplicated macro definitions have been removed

   Note that 'trivial' here means that it's obviously kernel code that
   already included all the major kernel headers, and thus gets the new
   generic MIN/MAX macros automatically.

 - non-trivial duplicated macro definitions are guarded with #ifndef

   This is the "yes, they define their own versions, but no, the include
   situation is not entirely obvious, and maybe they don't get the
   generic version automatically" case.

 - strange use case #1

   A couple of drivers decided that the way they want to describe their
   versioning is with

#define MAJ 1
#define MIN 2
#define DRV_VERSION __stringify(MAJ) "." __stringify(MIN)

   which adds zero value and I just did my Alexander the Great
   impersonation, and rewrote that pointless Gordian knot as

#define DRV_VERSION "1.2"

   instead.

 - strange use case #2

   A couple of drivers thought that it's a good idea to have a random
   'MIN' or 'MAX' define for a value or index into a table, rather than
   the traditional macro that takes arguments.

   These values were re-written as C enum's instead. The new
   function-line macros only expand when followed by an open
   parenthesis, and thus don't clash with enum use.

Happily, there weren't really all that many of these cases, and a lot of
users already had the pattern of using '#ifndef' guarding (or in one
case just using '#undef MIN') before defining their own private version
that does the same thing. I left such cases alone.

Cc: David Laight <David.Laight@aculab.com>
Cc: Lorenzo Stoakes <lorenzo.stoakes@oracle.com>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Signed-off-by: Eliav Farber <farbere@amazon.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
23 files changed:
arch/um/drivers/mconsole_user.c
drivers/edac/skx_common.h
drivers/gpu/drm/amd/amdgpu/amdgpu.h
drivers/gpu/drm/amd/display/modules/hdcp/hdcp_ddc.c
drivers/gpu/drm/amd/pm/powerplay/hwmgr/ppevvmath.h
drivers/gpu/drm/amd/pm/swsmu/smu11/sienna_cichlid_ppt.c
drivers/gpu/drm/amd/pm/swsmu/smu13/smu_v13_0_0_ppt.c
drivers/gpu/drm/amd/pm/swsmu/smu13/smu_v13_0_7_ppt.c
drivers/gpu/drm/radeon/evergreen_cs.c
drivers/hwmon/adt7475.c
drivers/media/dvb-frontends/stv0367_priv.h
drivers/net/fjes/fjes_main.c
drivers/nfc/pn544/i2c.c
drivers/platform/x86/sony-laptop.c
drivers/scsi/isci/init.c
drivers/staging/media/atomisp/pci/hive_isp_css_include/math_support.h
include/linux/minmax.h
kernel/trace/preemptirq_delay_test.c
lib/btree.c
lib/decompress_unlzma.c
mm/zsmalloc.c
tools/testing/selftests/mm/mremap_test.c
tools/testing/selftests/seccomp/seccomp_bpf.c

index e24298a734befd9023f534080bb23680b1f99c7d..a04cd13c6315a2af5f28ad83724d63004e322335 100644 (file)
@@ -71,7 +71,9 @@ static struct mconsole_command *mconsole_parse(struct mc_request *req)
        return NULL;
 }
 
+#ifndef MIN
 #define MIN(a,b) ((a)<(b) ? (a):(b))
+#endif
 
 #define STRINGX(x) #x
 #define STRING(x) STRINGX(x)
index 2ea4d1d1fbef2616f34195776c6cd1510fa638b2..1fa31a6fdfcd5d506a5f4427c59c883b0fb6aa69 100644 (file)
@@ -45,7 +45,6 @@
 #define I10NM_NUM_CHANNELS     MAX(I10NM_NUM_DDR_CHANNELS, I10NM_NUM_HBM_CHANNELS)
 #define I10NM_NUM_DIMMS                MAX(I10NM_NUM_DDR_DIMMS, I10NM_NUM_HBM_DIMMS)
 
-#define MAX(a, b)      ((a) > (b) ? (a) : (b))
 #define NUM_IMC                MAX(SKX_NUM_IMC, I10NM_NUM_IMC)
 #define NUM_CHANNELS   MAX(SKX_NUM_CHANNELS, I10NM_NUM_CHANNELS)
 #define NUM_DIMMS      MAX(SKX_NUM_DIMMS, I10NM_NUM_DIMMS)
index c5d706a4c7b4a756585c43b4093d970347c2e22a..78426f8c5420db440a856a98d86b55670f6b2d14 100644 (file)
@@ -1285,7 +1285,9 @@ int emu_soc_asic_init(struct amdgpu_device *adev);
        for (i = ffs(inst_mask); i-- != 0; \
             i = ffs(inst_mask & BIT_MASK_UPPER(i + 1)))
 
+#ifndef MIN
 #define MIN(X, Y) ((X) < (Y) ? (X) : (Y))
+#endif
 
 /* Common functions */
 bool amdgpu_device_has_job_running(struct amdgpu_device *adev);
index 1b2df97226a3f2b72a3b37e061aeb6f082e2e8f2..40286e8dd4e1ab699fa86780586a0f21b5b8949e 100644 (file)
@@ -25,7 +25,9 @@
 
 #include "hdcp.h"
 
+#ifndef MIN
 #define MIN(a, b) ((a) < (b) ? (a) : (b))
+#endif
 #define HDCP_I2C_ADDR 0x3a     /* 0x74 >> 1*/
 #define KSV_READ_SIZE 0xf      /* 0x6803b - 0x6802c */
 #define HDCP_MAX_AUX_TRANSACTION_SIZE 16
index 6f54c410c2f9859392e78e15b1334d13b8713218..409aeec6baa92193db436878b1d0552b00c126b6 100644 (file)
  */
 #include <asm/div64.h>
 
-#define SHIFT_AMOUNT 16 /* We multiply all original integers with 2^SHIFT_AMOUNT to get the fInt representation */
+enum ppevvmath_constants {
+       /* We multiply all original integers with 2^SHIFT_AMOUNT to get the fInt representation */
+       SHIFT_AMOUNT    = 16,
 
-#define PRECISION 5 /* Change this value to change the number of decimal places in the final output - 5 is a good default */
+       /* Change this value to change the number of decimal places in the final output - 5 is a good default */
+       PRECISION       =  5,
 
-#define SHIFTED_2 (2 << SHIFT_AMOUNT)
-#define MAX (1 << (SHIFT_AMOUNT - 1)) - 1 /* 32767 - Might change in the future */
+       SHIFTED_2       = (2 << SHIFT_AMOUNT),
+
+       /* 32767 - Might change in the future */
+       MAX             = (1 << (SHIFT_AMOUNT - 1)) - 1,
+};
 
 /* -------------------------------------------------------------------------------
  * NEW TYPE - fINT
index a7f4f82d23b4b911abb02a15a90215ef53b35013..2fdb982e70ef7d59e2ce7e3570469541d529bd82 100644 (file)
@@ -2082,7 +2082,9 @@ static int sienna_cichlid_display_disable_memory_clock_switch(struct smu_context
        return ret;
 }
 
+#ifndef MAX
 #define MAX(a, b)      ((a) > (b) ? (a) : (b))
+#endif
 
 static int sienna_cichlid_update_pcie_parameters(struct smu_context *smu,
                                                 uint8_t pcie_gen_cap,
index 4022dd44ebb2b303460ba44e580b0f964c1b8413..fe6c42a736d08b6754bf0830098102d6cae67d1e 100644 (file)
@@ -1696,7 +1696,10 @@ static int smu_v13_0_0_get_thermal_temperature_range(struct smu_context *smu,
        return 0;
 }
 
+#ifndef MAX
 #define MAX(a, b)      ((a) > (b) ? (a) : (b))
+#endif
+
 static ssize_t smu_v13_0_0_get_gpu_metrics(struct smu_context *smu,
                                           void **table)
 {
index e1521d3a5e0ca1864f3a0f38beb3d51a02ba3e2b..df99d185cf8e03b16b980c26dc284b6a80eefdac 100644 (file)
@@ -1674,7 +1674,10 @@ static int smu_v13_0_7_get_thermal_temperature_range(struct smu_context *smu,
        return 0;
 }
 
+#ifndef MAX
 #define MAX(a, b)      ((a) > (b) ? (a) : (b))
+#endif
+
 static ssize_t smu_v13_0_7_get_gpu_metrics(struct smu_context *smu,
                                           void **table)
 {
index 820c2c3641d388a66dc2b6be258c9f64b16173fc..1311f10fad660c2b14d79ed45e8c25f7c2027e03 100644 (file)
 #include "evergreen_reg_safe.h"
 #include "cayman_reg_safe.h"
 
+#ifndef MIN
 #define MAX(a,b)                   (((a)>(b))?(a):(b))
 #define MIN(a,b)                   (((a)<(b))?(a):(b))
+#endif
 
 #define REG_SAFE_BM_SIZE ARRAY_SIZE(evergreen_reg_safe_bm)
 
index 14b2547adae8d30fc04b967ff7b10d5cc45a607d..ce0ab4e4e41a73ad60a443d0d2c139fdd06ef4b2 100644 (file)
 #include <linux/util_macros.h>
 
 /* Indexes for the sysfs hooks */
-
-#define INPUT          0
-#define MIN            1
-#define MAX            2
-#define CONTROL                3
-#define OFFSET         3
-#define AUTOMIN                4
-#define THERM          5
-#define HYSTERSIS      6
-
+enum adt_sysfs_id {
+       INPUT           = 0,
+       MIN             = 1,
+       MAX             = 2,
+       CONTROL         = 3,
+       OFFSET          = 3,    // Dup
+       AUTOMIN         = 4,
+       THERM           = 5,
+       HYSTERSIS       = 6,
 /*
  * These are unique identifiers for the sysfs functions - unlike the
  * numbers above, these are not also indexes into an array
  */
+       ALARM           = 9,
+       FAULT           = 10,
+};
 
-#define ALARM          9
-#define FAULT          10
 
 /* 7475 Common Registers */
 
index 617f605947b2c47e74d95eb3392d61d82ab9619b..7f056d1cce8228d97ce503905b3c673afdf153f8 100644 (file)
 #endif
 
 /* MACRO definitions */
+#ifndef MIN
 #define MAX(X, Y) ((X) >= (Y) ? (X) : (Y))
 #define MIN(X, Y) ((X) <= (Y) ? (X) : (Y))
+#endif
+
 #define INRANGE(X, Y, Z) \
        ((((X) <= (Y)) && ((Y) <= (Z))) || \
        (((Z) <= (Y)) && ((Y) <= (X))) ? 1 : 0)
index 2513be6d4e11d19ca1c1975b7e529d9d8e7ebe6c..cfcf0f7d9d903ede61ca288a7360fe4077236a36 100644 (file)
@@ -14,9 +14,7 @@
 #include "fjes.h"
 #include "fjes_trace.h"
 
-#define MAJ 1
-#define MIN 2
-#define DRV_VERSION __stringify(MAJ) "." __stringify(MIN)
+#define DRV_VERSION "1.2"
 #define DRV_NAME       "fjes"
 char fjes_driver_name[] = DRV_NAME;
 char fjes_driver_version[] = DRV_VERSION;
index 3f6d74832bac3b3d059fce0e8a489a35e2bce8da..be566ca7bae9473a9253b521299db187c6fd1a59 100644 (file)
@@ -126,8 +126,6 @@ struct pn544_i2c_fw_secure_blob {
 #define PN544_FW_CMD_RESULT_COMMAND_REJECTED 0xE0
 #define PN544_FW_CMD_RESULT_CHUNK_ERROR 0xE6
 
-#define MIN(X, Y) ((X) < (Y) ? (X) : (Y))
-
 #define PN544_FW_WRITE_BUFFER_MAX_LEN 0x9f7
 #define PN544_FW_I2C_MAX_PAYLOAD PN544_HCI_I2C_LLC_MAX_SIZE
 #define PN544_FW_I2C_WRITE_FRAME_HEADER_LEN 8
index 9569f11dec8c563c5b8f14d86ec44c9e1183edd3..bd7323cf9a97f8d1a5e00d957c3a89ecc1b30506 100644 (file)
@@ -757,7 +757,6 @@ static union acpi_object *__call_snc_method(acpi_handle handle, char *method,
        return result;
 }
 
-#define MIN(a, b)      (a > b ? b : a)
 static int sony_nc_buffer_call(acpi_handle handle, char *name, u64 *value,
                void *buffer, size_t buflen)
 {
index 6277162a028bb98378d66c34e7a9f47a20323027..6eefa7e5f4cf6a6add67fc05b829a674f286803c 100644 (file)
 #include "task.h"
 #include "probe_roms.h"
 
-#define MAJ 1
-#define MIN 2
-#define BUILD 0
-#define DRV_VERSION __stringify(MAJ) "." __stringify(MIN) "." \
-       __stringify(BUILD)
+#define DRV_VERSION "1.2.0"
 
 MODULE_VERSION(DRV_VERSION);
 
index a444ec14ff9d5b3c960a10e06bf8c649dee6d5f7..1c17a87a85720c17a68890e0758ccf52e2b5a2ea 100644 (file)
 /* A => B */
 #define IMPLIES(a, b)        (!(a) || (b))
 
-/* for preprocessor and array sizing use MIN and MAX
-   otherwise use min and max */
-#define MAX(a, b)            (((a) > (b)) ? (a) : (b))
-#define MIN(a, b)            (((a) < (b)) ? (a) : (b))
-
 #define ROUND_DIV(a, b)      (((b) != 0) ? ((a) + ((b) >> 1)) / (b) : 0)
 #define CEIL_DIV(a, b)       (((b) != 0) ? ((a) + (b) - 1) / (b) : 0)
 #define CEIL_MUL(a, b)       (CEIL_DIV(a, b) * (b))
index 9c2848abc80496de84a23e2805163550ecd84599..fc384714da4509ea0605adf8da2c6df6adfdee94 100644 (file)
@@ -277,6 +277,8 @@ static inline bool in_range32(u32 val, u32 start, u32 len)
  * Use these carefully: no type checking, and uses the arguments
  * multiple times. Use for obvious constants only.
  */
+#define MIN(a,b) __cmp(min,a,b)
+#define MAX(a,b) __cmp(max,a,b)
 #define MIN_T(type,a,b) __cmp(min,(type)(a),(type)(b))
 #define MAX_T(type,a,b) __cmp(max,(type)(a),(type)(b))
 
index 8af92dbe98f07bdf7ba15d903eab1cc78c364a0b..acb0c971a4082ad050c4362cd651b4bbbb8538b0 100644 (file)
@@ -34,8 +34,6 @@ MODULE_PARM_DESC(cpu_affinity, "Cpu num test is running on");
 
 static struct completion done;
 
-#define MIN(x, y) ((x) < (y) ? (x) : (y))
-
 static void busy_wait(ulong time)
 {
        u64 start, end;
index 49420cae3a8330ac650ff3114ee98cb2ed8e088a..bb81d3393ac5c52cd2a80e2712380e6dfe8b8e47 100644 (file)
@@ -43,7 +43,6 @@
 #include <linux/slab.h>
 #include <linux/module.h>
 
-#define MAX(a, b) ((a) > (b) ? (a) : (b))
 #define NODESIZE MAX(L1_CACHE_BYTES, 128)
 
 struct btree_geo {
index 20a858031f12b7600f906a90584d73aa21e2311e..9d34d35908daa89c74bf4e53864b49e4434e18c5 100644 (file)
@@ -37,7 +37,9 @@
 
 #include <linux/decompress/mm.h>
 
+#ifndef MIN
 #define        MIN(a, b) (((a) < (b)) ? (a) : (b))
+#endif
 
 static long long INIT read_int(unsigned char *ptr, int size)
 {
index c82070167d8aa8a1d304affbce7625dd0c851e24..14327fc34aa7137cf5fbf9e02e1f3b2d97bd9f8d 100644 (file)
 #define ISOLATED_BITS  5
 #define MAGIC_VAL_BITS 8
 
-#define MAX(a, b) ((a) >= (b) ? (a) : (b))
-
 #define ZS_MAX_PAGES_PER_ZSPAGE        (_AC(CONFIG_ZSMALLOC_CHAIN_SIZE, UL))
 
 /* ZS_MIN_ALLOC_SIZE must be multiple of ZS_ALIGN */
index 5c3773de9f0f78b1be7df121bdd9cc294037285e..944645f9d2b3d79b71b939ce14aca91e2bb3cd64 100644 (file)
@@ -22,7 +22,9 @@
 #define VALIDATION_DEFAULT_THRESHOLD 4 /* 4MB */
 #define VALIDATION_NO_THRESHOLD 0      /* Verify the entire region */
 
+#ifndef MIN
 #define MIN(X, Y) ((X) < (Y) ? (X) : (Y))
+#endif
 
 struct config {
        unsigned long long src_alignment;
index 15325ca35f1e2b26d1b1bd0cfca3661532f2d0be..4390965c84c42243bd87c6ff96926f9a643b9772 100644 (file)
@@ -60,7 +60,9 @@
 #define SKIP(s, ...)   XFAIL(s, ##__VA_ARGS__)
 #endif
 
+#ifndef MIN
 #define MIN(X, Y) ((X) < (Y) ? (X) : (Y))
+#endif
 
 #ifndef PR_SET_PTRACER
 # define PR_SET_PTRACER 0x59616d61