diff options
| author | Linus Torvalds <torvalds@linux-foundation.org> | 2023-10-31 18:42:56 -1000 | 
|---|---|---|
| committer | Linus Torvalds <torvalds@linux-foundation.org> | 2023-10-31 18:42:56 -1000 | 
| commit | fe4ae2fab00b4751265580c5865fdf23b62d80b3 (patch) | |
| tree | faeb8e5fb6d7f8165d1bfde357d22f0d96ea754e /drivers/clk/clk-gate_test.c | |
| parent | c52894359395ea0a562b3ed556848ed66fbfff86 (diff) | |
| parent | 0a6d7f8275f255eda823c0f0b61d024f6f5b483d (diff) | |
Merge tag 'clk-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/clk/linux
Pull clk driver updates from Stephen Boyd:
 "Herein lies a smallish collection of clk driver updates and some core
  clk framework changes for the merge window. The core framework changes
  are only improving the debugfs interface to allow phase adjustments
  and report which consumers of a clk there are. These are most likely
  only of interest to kernel developers.
  On the clk driver side, it's a ghastly amount of updates with only a
  handful of new clk drivers. We have a couple new clk drivers for
  Qualcomm, per usual, and a driver for Renesas, Amlogic, and TI
  respectively. The updates are spread throughout the clk drivers.
  Some highlights are fixing kunit tests for different configurations
  like lockdep and big-endian, avoiding integer overflow in rate
  settable clks, moving clk_hw_onecell_data to the end of allocations so
  that drivers don't corrupt their private data, and migrating clk
  drivers to the regmap maple tree. Otherwise it's the usual fixes to
  clk drivers that only come along with testing the drivers on real
  hardware.
  New Drivers:
   - Add clock driver for TWL6032
   - Initial support for the Qualcomm SM4450 Global Clock Controller and
     SM4450 RPMh clock controllers
   - Add Camera Clock Controller on Qualcomm SM8550
   - Add support for the Renesas RZ/G3S (R9A08G045) SoC
   - Add Amlogic s4 main clock controller support
Updates:
   - Make clk kunit tests work with lockdep
   - Fix clk gate kunit test for big-endian
   - Convert more than a handful of clk drivers to use regmap maple tree
   - Consider the CLK_FRAC_DIVIDER_ZERO_BASED in fractional divider clk
     implementation
   - Add consumer info to clk debugfs
   - Fix various clk drivers that have clk_hw_onecell_data not at the
     end of an allocation
   - Drop CLK_SET_RATE_PARENT for clocks with fixed-rate GPLLs across a
     variety of Qualcomm IPQ platforms
   - Add missing parent of APCS PLL on Qualcomm IPQ6018
   - Add I2C QUP6 clk on Qualcomm IPQ6018 but mark it critical to avoid
     problems with RPM
   - Implement safe source switching for a53pll and use on Qualcomm
     IPQ5332
   - Add support for Stromer Plus PLLs to Qualcomm clk driver
   - Switch Qualcomm SM8550 Video and GPU clock controllers to use OLE
     PLL configure method
   - Non critical fixes to halt bit checks in Qualcomm clk drivers
   - Add SMMU GDSC for Qualcomm MSM8998
   - Fix possible integer overflow in Qualcomm RCG frequency calculation
     code
   - Remove RPM managed clks from Qualcomm MSM8996 GCC driver
   - Add HFPLL configuration for the three HFPLLs in Qualcomm MSM8976
   - Switch Qualcomm MSM8996 CBF clock driver's remove function to
     return void
   - Fix missing dependency for s4 clock controllers
   - Select MXC_CLK when building in the CLK_IMX8QXP
   - Fixes for error handling paths in i.MX8 ACM driver
   - Move the clocks check in i.MX8 ACM driver in order to log any error
   - Drop the unused return value of clk_imx_acm_detach_pm_domains
   - Drop non-existant IMX8MP_CLK_AUDIOMIX_PDM_ROOT clock
   - Fix error handling in i.MX8MQ clock driver
   - Allow a different LCDIF1 clock parent if DT describes it for
     i.MX6SX
   - Keep the SCU resource table sorted in the i.MX8DXL rsrc driver
   - Move the elcdif PLL clock registration above lcd_clk, as it is its
     parent
   - Correct some ENET specific clocks for i.MX8DXL platform
   - Drop the VPU_UART and VPUCORE from i.MX8QM as latest HW revision
     doesn't have them
   - Remove "de-featured" MLB support from i.MX8QM/QXP/DXL platforms
   - Skip registering clocks owned by Cortex-A partition SCU-based
     platforms
   - Add CAN_1/2 to i.MX8QM and M4_0, PI_0_PWM_0 and PI_0_I2C_0 to
     i.MX8QXP resources"
* tag 'clk-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/clk/linux: (128 commits)
  clk: Fix clk gate kunit test on big-endian CPUs
  clk: si521xx: Increase stack based print buffer size in probe
  clk: mediatek: fix double free in mtk_clk_register_pllfh()
  clk: socfpga: agilex: Add bounds-checking coverage for struct stratix10_clock_data
  clk: socfpga: Fix undefined behavior bug in struct stratix10_clock_data
  clk: sifive: Allow building the driver as a module
  clk: analogbits: Allow building the library as a module
  clk: sprd: Composite driver support offset config
  clk: Allow phase adjustment from debugfs
  clk: Show active consumers of clocks in debugfs
  clk: Use device_get_match_data()
  clk: visconti: Add bounds-checking coverage for struct visconti_pll_provider
  clk: visconti: Fix undefined behavior bug in struct visconti_pll_provider
  clk: cdce925: Extend match support for OF tables
  clk: si570: Simplify probe
  clk: si5351: Simplify probe
  clk: rs9: Use i2c_get_match_data() instead of device_get_match_data()
  clk: clk-si544: Simplify probe() and is_valid_frequency()
  clk: si521xx: Use i2c_get_match_data() instead of device_get_match_data()
  clk: meson: S4: select CONFIG_COMMON_CLK_MESON_CLKC_UTILS
  ...
Diffstat (limited to 'drivers/clk/clk-gate_test.c')
| -rw-r--r-- | drivers/clk/clk-gate_test.c | 30 | 
1 files changed, 15 insertions, 15 deletions
| diff --git a/drivers/clk/clk-gate_test.c b/drivers/clk/clk-gate_test.c index e136aaad48bf..c96d93b19ddf 100644 --- a/drivers/clk/clk-gate_test.c +++ b/drivers/clk/clk-gate_test.c @@ -131,7 +131,7 @@ struct clk_gate_test_context {  	void __iomem *fake_mem;  	struct clk_hw *hw;  	struct clk_hw *parent; -	u32 fake_reg; /* Keep at end, KASAN can detect out of bounds */ +	__le32 fake_reg; /* Keep at end, KASAN can detect out of bounds */  };  static struct clk_gate_test_context *clk_gate_test_alloc_ctx(struct kunit *test) @@ -166,7 +166,7 @@ static void clk_gate_test_enable(struct kunit *test)  	KUNIT_ASSERT_EQ(test, clk_prepare_enable(clk), 0); -	KUNIT_EXPECT_EQ(test, enable_val, ctx->fake_reg); +	KUNIT_EXPECT_EQ(test, enable_val, le32_to_cpu(ctx->fake_reg));  	KUNIT_EXPECT_TRUE(test, clk_hw_is_enabled(hw));  	KUNIT_EXPECT_TRUE(test, clk_hw_is_prepared(hw));  	KUNIT_EXPECT_TRUE(test, clk_hw_is_enabled(parent)); @@ -183,10 +183,10 @@ static void clk_gate_test_disable(struct kunit *test)  	u32 disable_val = 0;  	KUNIT_ASSERT_EQ(test, clk_prepare_enable(clk), 0); -	KUNIT_ASSERT_EQ(test, enable_val, ctx->fake_reg); +	KUNIT_ASSERT_EQ(test, enable_val, le32_to_cpu(ctx->fake_reg));  	clk_disable_unprepare(clk); -	KUNIT_EXPECT_EQ(test, disable_val, ctx->fake_reg); +	KUNIT_EXPECT_EQ(test, disable_val, le32_to_cpu(ctx->fake_reg));  	KUNIT_EXPECT_FALSE(test, clk_hw_is_enabled(hw));  	KUNIT_EXPECT_FALSE(test, clk_hw_is_prepared(hw));  	KUNIT_EXPECT_FALSE(test, clk_hw_is_enabled(parent)); @@ -246,7 +246,7 @@ static void clk_gate_test_invert_enable(struct kunit *test)  	KUNIT_ASSERT_EQ(test, clk_prepare_enable(clk), 0); -	KUNIT_EXPECT_EQ(test, enable_val, ctx->fake_reg); +	KUNIT_EXPECT_EQ(test, enable_val, le32_to_cpu(ctx->fake_reg));  	KUNIT_EXPECT_TRUE(test, clk_hw_is_enabled(hw));  	KUNIT_EXPECT_TRUE(test, clk_hw_is_prepared(hw));  	KUNIT_EXPECT_TRUE(test, clk_hw_is_enabled(parent)); @@ -263,10 +263,10 @@ static void clk_gate_test_invert_disable(struct kunit *test)  	u32 disable_val = BIT(15);  	KUNIT_ASSERT_EQ(test, clk_prepare_enable(clk), 0); -	KUNIT_ASSERT_EQ(test, enable_val, ctx->fake_reg); +	KUNIT_ASSERT_EQ(test, enable_val, le32_to_cpu(ctx->fake_reg));  	clk_disable_unprepare(clk); -	KUNIT_EXPECT_EQ(test, disable_val, ctx->fake_reg); +	KUNIT_EXPECT_EQ(test, disable_val, le32_to_cpu(ctx->fake_reg));  	KUNIT_EXPECT_FALSE(test, clk_hw_is_enabled(hw));  	KUNIT_EXPECT_FALSE(test, clk_hw_is_prepared(hw));  	KUNIT_EXPECT_FALSE(test, clk_hw_is_enabled(parent)); @@ -290,7 +290,7 @@ static int clk_gate_test_invert_init(struct kunit *test)  					    2000000);  	KUNIT_ASSERT_NOT_ERR_OR_NULL(test, parent); -	ctx->fake_reg = BIT(15); /* Default to off */ +	ctx->fake_reg = cpu_to_le32(BIT(15)); /* Default to off */  	hw = clk_hw_register_gate_parent_hw(NULL, "test_gate", parent, 0,  					    ctx->fake_mem, 15,  					    CLK_GATE_SET_TO_DISABLE, NULL); @@ -319,7 +319,7 @@ static void clk_gate_test_hiword_enable(struct kunit *test)  	KUNIT_ASSERT_EQ(test, clk_prepare_enable(clk), 0); -	KUNIT_EXPECT_EQ(test, enable_val, ctx->fake_reg); +	KUNIT_EXPECT_EQ(test, enable_val, le32_to_cpu(ctx->fake_reg));  	KUNIT_EXPECT_TRUE(test, clk_hw_is_enabled(hw));  	KUNIT_EXPECT_TRUE(test, clk_hw_is_prepared(hw));  	KUNIT_EXPECT_TRUE(test, clk_hw_is_enabled(parent)); @@ -336,10 +336,10 @@ static void clk_gate_test_hiword_disable(struct kunit *test)  	u32 disable_val = BIT(9 + 16);  	KUNIT_ASSERT_EQ(test, clk_prepare_enable(clk), 0); -	KUNIT_ASSERT_EQ(test, enable_val, ctx->fake_reg); +	KUNIT_ASSERT_EQ(test, enable_val, le32_to_cpu(ctx->fake_reg));  	clk_disable_unprepare(clk); -	KUNIT_EXPECT_EQ(test, disable_val, ctx->fake_reg); +	KUNIT_EXPECT_EQ(test, disable_val, le32_to_cpu(ctx->fake_reg));  	KUNIT_EXPECT_FALSE(test, clk_hw_is_enabled(hw));  	KUNIT_EXPECT_FALSE(test, clk_hw_is_prepared(hw));  	KUNIT_EXPECT_FALSE(test, clk_hw_is_enabled(parent)); @@ -387,7 +387,7 @@ static void clk_gate_test_is_enabled(struct kunit *test)  	struct clk_gate_test_context *ctx;  	ctx = clk_gate_test_alloc_ctx(test); -	ctx->fake_reg = BIT(7); +	ctx->fake_reg = cpu_to_le32(BIT(7));  	hw = clk_hw_register_gate(NULL, "test_gate", NULL, 0, ctx->fake_mem, 7,  				  0, NULL);  	KUNIT_ASSERT_NOT_ERR_OR_NULL(test, hw); @@ -402,7 +402,7 @@ static void clk_gate_test_is_disabled(struct kunit *test)  	struct clk_gate_test_context *ctx;  	ctx = clk_gate_test_alloc_ctx(test); -	ctx->fake_reg = BIT(4); +	ctx->fake_reg = cpu_to_le32(BIT(4));  	hw = clk_hw_register_gate(NULL, "test_gate", NULL, 0, ctx->fake_mem, 7,  				  0, NULL);  	KUNIT_ASSERT_NOT_ERR_OR_NULL(test, hw); @@ -417,7 +417,7 @@ static void clk_gate_test_is_enabled_inverted(struct kunit *test)  	struct clk_gate_test_context *ctx;  	ctx = clk_gate_test_alloc_ctx(test); -	ctx->fake_reg = BIT(31); +	ctx->fake_reg = cpu_to_le32(BIT(31));  	hw = clk_hw_register_gate(NULL, "test_gate", NULL, 0, ctx->fake_mem, 2,  				  CLK_GATE_SET_TO_DISABLE, NULL);  	KUNIT_ASSERT_NOT_ERR_OR_NULL(test, hw); @@ -432,7 +432,7 @@ static void clk_gate_test_is_disabled_inverted(struct kunit *test)  	struct clk_gate_test_context *ctx;  	ctx = clk_gate_test_alloc_ctx(test); -	ctx->fake_reg = BIT(29); +	ctx->fake_reg = cpu_to_le32(BIT(29));  	hw = clk_hw_register_gate(NULL, "test_gate", NULL, 0, ctx->fake_mem, 29,  				  CLK_GATE_SET_TO_DISABLE, NULL);  	KUNIT_ASSERT_NOT_ERR_OR_NULL(test, hw); | 
