Commit 160d7b9f authored by Stephen Boyd's avatar Stephen Boyd

Merge branches 'clk-stm', 'clk-cleanup', 'clk-kunit' and 'clk-mediatek' into clk-next

 - Add reset support to Airoha EN7581 clk driver
 - Add module description to mediatek clk drivers

* clk-stm:
  clk: stm32mp25: add security clocks
  clk: stm32mp2: use of STM32 access controller

* clk-cleanup:
  clk: mxs: Use clamp() in clk_ref_round_rate() and clk_ref_set_rate()
  clk: lpc32xx: Constify struct regmap_config
  clk: xilinx: Constify struct regmap_config
  dt-bindings: clock: sprd,sc9860-clk: convert to YAML
  dt-bindings: clock: qoriq-clock: convert to yaml format
  clk: vexpress-osc: add missing MODULE_DESCRIPTION() macro
  clk: sifive: prci: fix module autoloading
  dt-bindings: clock: milbeaut: Drop providers and consumers from example
  clk: sprd: add missing MODULE_DESCRIPTION() macro
  clk: sophgo: add missing MODULE_DESCRIPTION() macro

* clk-kunit:
  clk: disable clk gate tests for s390
  clk: test: add missing MODULE_DESCRIPTION() macros

* clk-mediatek:
  clk: en7523: fix rate divider for slic and spi clocks
  clk: en7523: Remove PCIe reset open drain configuration for EN7581
  clk: en7523: Remove pcie prepare/unpreare callbacks for EN7581 SoC
  clk: en7523: Add reset-controller support for EN7581 SoC
  dt-bindings: clock: airoha: Add reset support to EN7581 clock binding
  dt-bindings: clock: mediatek: Document reset cells for MT8188 sys
  clk: mediatek: mt8173-infracfg: Handle unallocated infracfg when module
  dt-bindings: clock: mediatek: add syscon compatible for mt7622 pciesys
  clk: mediatek: Add a module description where missing
...@@ -35,7 +35,7 @@ properties: ...@@ -35,7 +35,7 @@ properties:
reg: reg:
minItems: 2 minItems: 2
maxItems: 3 maxItems: 4
"#clock-cells": "#clock-cells":
description: description:
...@@ -43,6 +43,10 @@ properties: ...@@ -43,6 +43,10 @@ properties:
clocks. clocks.
const: 1 const: 1
'#reset-cells':
description: ID of the controller reset line
const: 1
required: required:
- compatible - compatible
- reg - reg
...@@ -60,6 +64,8 @@ allOf: ...@@ -60,6 +64,8 @@ allOf:
- description: scu base address - description: scu base address
- description: misc scu base address - description: misc scu base address
'#reset-cells': false
- if: - if:
properties: properties:
compatible: compatible:
...@@ -70,6 +76,7 @@ allOf: ...@@ -70,6 +76,7 @@ allOf:
items: items:
- description: scu base address - description: scu base address
- description: misc scu base address - description: misc scu base address
- description: reset base address
- description: pb scu base address - description: pb scu base address
additionalProperties: false additionalProperties: false
...@@ -83,3 +90,19 @@ examples: ...@@ -83,3 +90,19 @@ examples:
<0x1fb00000 0x1000>; <0x1fb00000 0x1000>;
#clock-cells = <1>; #clock-cells = <1>;
}; };
- |
soc {
#address-cells = <2>;
#size-cells = <2>;
scuclk: clock-controller@1fa20000 {
compatible = "airoha,en7581-scu";
reg = <0x0 0x1fa20000 0x0 0x400>,
<0x0 0x1fb00000 0x0 0x90>,
<0x0 0x1fb00830 0x0 0x8>,
<0x0 0x1fbe3400 0x0 0xfc>;
#clock-cells = <1>;
#reset-cells = <1>;
};
};
# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause)
%YAML 1.2
---
$id: http://devicetree.org/schemas/clock/fsl,qoriq-clock-legacy.yaml#
$schema: http://devicetree.org/meta-schemas/core.yaml#
title: Legacy Clock Block on Freescale QorIQ Platforms
maintainers:
- Frank Li <Frank.Li@nxp.com>
description: |
These nodes are deprecated. Kernels should continue to support
device trees with these nodes, but new device trees should not use them.
Most of the bindings are from the common clock binding[1].
[1] Documentation/devicetree/bindings/clock/clock-bindings.txt
properties:
compatible:
enum:
- fsl,qoriq-core-pll-1.0
- fsl,qoriq-core-pll-2.0
- fsl,qoriq-core-mux-1.0
- fsl,qoriq-core-mux-2.0
- fsl,qoriq-sysclk-1.0
- fsl,qoriq-sysclk-2.0
- fsl,qoriq-platform-pll-1.0
- fsl,qoriq-platform-pll-2.0
reg:
maxItems: 1
clocks:
minItems: 1
maxItems: 4
clock-names:
minItems: 1
maxItems: 4
clock-output-names:
minItems: 1
maxItems: 8
'#clock-cells':
minimum: 0
maximum: 1
required:
- compatible
- '#clock-cells'
additionalProperties: false
allOf:
- if:
properties:
compatible:
contains:
enum:
- fsl,qoriq-sysclk-1.0
- fsl,qoriq-sysclk-2.0
then:
properties:
'#clock-cells':
const: 0
- if:
properties:
compatible:
contains:
enum:
- fsl,qoriq-core-pll-1.0
- fsl,qoriq-core-pll-2.0
then:
properties:
'#clock-cells':
const: 1
description: |
* 0 - equal to the PLL frequency
* 1 - equal to the PLL frequency divided by 2
* 2 - equal to the PLL frequency divided by 4
# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause)
%YAML 1.2
---
$id: http://devicetree.org/schemas/clock/fsl,qoriq-clock.yaml#
$schema: http://devicetree.org/meta-schemas/core.yaml#
title: Clock Block on Freescale QorIQ Platforms
maintainers:
- Frank Li <Frank.Li@nxp.com>
description: |
Freescale QorIQ chips take primary clocking input from the external
SYSCLK signal. The SYSCLK input (frequency) is multiplied using
multiple phase locked loops (PLL) to create a variety of frequencies
which can then be passed to a variety of internal logic, including
cores and peripheral IP blocks.
Please refer to the Reference Manual for details.
All references to "1.0" and "2.0" refer to the QorIQ chassis version to
which the chip complies.
Chassis Version Example Chips
--------------- -------------
1.0 p4080, p5020, p5040
2.0 t4240
Clock Provider
The clockgen node should act as a clock provider, though in older device
trees the children of the clockgen node are the clock providers.
properties:
compatible:
oneOf:
- items:
- enum:
- fsl,p2041-clockgen
- fsl,p3041-clockgen
- fsl,p4080-clockgen
- fsl,p5020-clockgen
- fsl,p5040-clockgen
- const: fsl,qoriq-clockgen-1.0
- items:
- enum:
- fsl,t1023-clockgen
- fsl,t1024-clockgen
- fsl,t1040-clockgen
- fsl,t1042-clockgen
- fsl,t2080-clockgen
- fsl,t2081-clockgen
- fsl,t4240-clockgen
- const: fsl,qoriq-clockgen-2.0
- items:
- enum:
- fsl,b4420-clockgen
- fsl,b4860-clockgen
- const: fsl,b4-clockgen
- items:
- enum:
- fsl,ls1012a-clockgen
- fsl,ls1021a-clockgen
- fsl,ls1028a-clockgen
- fsl,ls1043a-clockgen
- fsl,ls1046a-clockgen
- fsl,ls1088a-clockgen
- fsl,ls2080a-clockgen
- fsl,lx2160a-clockgen
reg:
maxItems: 1
ranges: true
'#address-cells':
const: 1
'#size-cells':
const: 1
'#clock-cells':
const: 2
description: |
The first cell of the clock specifier is the clock type, and the
second cell is the clock index for the specified type.
Type# Name Index Cell
0 sysclk must be 0
1 cmux index (n in CLKCnCSR)
2 hwaccel index (n in CLKCGnHWACSR)
3 fman 0 for fm1, 1 for fm2
4 platform pll n=pll/(n+1). For example, when n=1,
that means output_freq=PLL_freq/2.
5 coreclk must be 0
clock-frequency:
description: Input system clock frequency (SYSCLK)
clocks:
items:
- description:
sysclk may be provided as an input clock. Either clock-frequency
or clocks must be provided.
- description:
A second input clock, called "coreclk", may be provided if
core PLLs are based on a different input clock from the
platform PLL.
minItems: 1
clock-names:
items:
- const: sysclk
- const: coreclk
patternProperties:
'^mux[0-9]@[a-f0-9]+$':
deprecated: true
$ref: fsl,qoriq-clock-legacy.yaml
'^sysclk(-[a-z0-9]+)?$':
deprecated: true
$ref: fsl,qoriq-clock-legacy.yaml
'^pll[0-9]@[a-f0-9]+$':
deprecated: true
$ref: fsl,qoriq-clock-legacy.yaml
'^platform\-pll@[a-f0-9]+$':
deprecated: true
$ref: fsl,qoriq-clock-legacy.yaml
required:
- compatible
- reg
- '#clock-cells'
additionalProperties: false
examples:
- |
/* clock provider example */
global-utilities@e1000 {
compatible = "fsl,p5020-clockgen", "fsl,qoriq-clockgen-1.0";
reg = <0xe1000 0x1000>;
clock-frequency = <133333333>;
#clock-cells = <2>;
};
- |
/* Legacy example */
global-utilities@e1000 {
compatible = "fsl,p5020-clockgen", "fsl,qoriq-clockgen-1.0";
reg = <0xe1000 0x1000>;
ranges = <0x0 0xe1000 0x1000>;
clock-frequency = <133333333>;
#address-cells = <1>;
#size-cells = <1>;
#clock-cells = <2>;
sysclk: sysclk {
compatible = "fsl,qoriq-sysclk-1.0";
clock-output-names = "sysclk";
#clock-cells = <0>;
};
pll0: pll0@800 {
compatible = "fsl,qoriq-core-pll-1.0";
reg = <0x800 0x4>;
#clock-cells = <1>;
clocks = <&sysclk>;
clock-output-names = "pll0", "pll0-div2";
};
pll1: pll1@820 {
compatible = "fsl,qoriq-core-pll-1.0";
reg = <0x820 0x4>;
#clock-cells = <1>;
clocks = <&sysclk>;
clock-output-names = "pll1", "pll1-div2";
};
mux0: mux0@0 {
compatible = "fsl,qoriq-core-mux-1.0";
reg = <0x0 0x4>;
#clock-cells = <0>;
clocks = <&pll0 0>, <&pll0 1>, <&pll1 0>, <&pll1 1>;
clock-names = "pll0", "pll0-div2", "pll1", "pll1-div2";
clock-output-names = "cmux0";
};
mux1: mux1@20 {
compatible = "fsl,qoriq-core-mux-1.0";
reg = <0x20 0x4>;
#clock-cells = <0>;
clocks = <&pll0 0>, <&pll0 1>, <&pll1 0>, <&pll1 1>;
clock-names = "pll0", "pll0-div2", "pll1", "pll1-div2";
clock-output-names = "cmux1";
};
platform-pll@c00 {
#clock-cells = <1>;
reg = <0xc00 0x4>;
compatible = "fsl,qoriq-platform-pll-1.0";
clocks = <&sysclk>;
clock-output-names = "platform-pll", "platform-pll-div2";
};
};
...@@ -14,9 +14,11 @@ maintainers: ...@@ -14,9 +14,11 @@ maintainers:
properties: properties:
compatible: compatible:
enum: oneOf:
- mediatek,mt7622-pciesys - items:
- mediatek,mt7629-pciesys - const: mediatek,mt7622-pciesys
- const: syscon
- const: mediatek,mt7629-pciesys
reg: reg:
maxItems: 1 maxItems: 1
...@@ -38,7 +40,7 @@ additionalProperties: false ...@@ -38,7 +40,7 @@ additionalProperties: false
examples: examples:
- | - |
clock-controller@1a100800 { clock-controller@1a100800 {
compatible = "mediatek,mt7622-pciesys"; compatible = "mediatek,mt7622-pciesys", "syscon";
reg = <0x1a100800 0x1000>; reg = <0x1a100800 0x1000>;
#clock-cells = <1>; #clock-cells = <1>;
#reset-cells = <1>; #reset-cells = <1>;
......
...@@ -39,6 +39,9 @@ properties: ...@@ -39,6 +39,9 @@ properties:
'#clock-cells': '#clock-cells':
const: 1 const: 1
'#reset-cells':
const: 1
required: required:
- compatible - compatible
- reg - reg
......
...@@ -40,38 +40,11 @@ required: ...@@ -40,38 +40,11 @@ required:
additionalProperties: false additionalProperties: false
examples: examples:
# Clock controller node:
- | - |
m10v-clk-ctrl@1d021000 { clock-controller@1d021000 {
compatible = "socionext,milbeaut-m10v-ccu"; compatible = "socionext,milbeaut-m10v-ccu";
reg = <0x1d021000 0x4000>; reg = <0x1d021000 0x4000>;
#clock-cells = <1>; #clock-cells = <1>;
clocks = <&clki40mhz>; clocks = <&clki40mhz>;
}; };
# Required an external clock for Clock controller node:
- |
clocks {
clki40mhz: clki40mhz {
compatible = "fixed-clock";
#clock-cells = <0>;
clock-frequency = <40000000>;
};
/* other clocks */
};
# The clock consumer shall specify the desired clock-output of the clock
# controller as below by specifying output-id in its "clk" phandle cell.
# 2: uart
# 4: 32-bit timer
# 7: UHS-I/II
- |
serial@1e700010 {
compatible = "socionext,milbeaut-usio-uart";
reg = <0x1e700010 0x10>;
interrupts = <0 141 0x4>, <0 149 0x4>;
interrupt-names = "rx", "tx";
clocks = <&clk 2>;
};
... ...
* Clock Block on Freescale QorIQ Platforms
Freescale QorIQ chips take primary clocking input from the external
SYSCLK signal. The SYSCLK input (frequency) is multiplied using
multiple phase locked loops (PLL) to create a variety of frequencies
which can then be passed to a variety of internal logic, including
cores and peripheral IP blocks.
Please refer to the Reference Manual for details.
All references to "1.0" and "2.0" refer to the QorIQ chassis version to
which the chip complies.
Chassis Version Example Chips
--------------- -------------
1.0 p4080, p5020, p5040
2.0 t4240, b4860
1. Clock Block Binding
Required properties:
- compatible: Should contain a chip-specific clock block compatible
string and (if applicable) may contain a chassis-version clock
compatible string.
Chip-specific strings are of the form "fsl,<chip>-clockgen", such as:
* "fsl,p2041-clockgen"
* "fsl,p3041-clockgen"
* "fsl,p4080-clockgen"
* "fsl,p5020-clockgen"
* "fsl,p5040-clockgen"
* "fsl,t1023-clockgen"
* "fsl,t1024-clockgen"
* "fsl,t1040-clockgen"
* "fsl,t1042-clockgen"
* "fsl,t2080-clockgen"
* "fsl,t2081-clockgen"
* "fsl,t4240-clockgen"
* "fsl,b4420-clockgen"
* "fsl,b4860-clockgen"
* "fsl,ls1012a-clockgen"
* "fsl,ls1021a-clockgen"
* "fsl,ls1028a-clockgen"
* "fsl,ls1043a-clockgen"
* "fsl,ls1046a-clockgen"
* "fsl,ls1088a-clockgen"
* "fsl,ls2080a-clockgen"
* "fsl,lx2160a-clockgen"
Chassis-version clock strings include:
* "fsl,qoriq-clockgen-1.0": for chassis 1.0 clocks
* "fsl,qoriq-clockgen-2.0": for chassis 2.0 clocks
- reg: Describes the address of the device's resources within the
address space defined by its parent bus, and resource zero
represents the clock register set
Optional properties:
- ranges: Allows valid translation between child's address space and
parent's. Must be present if the device has sub-nodes.
- #address-cells: Specifies the number of cells used to represent
physical base addresses. Must be present if the device has
sub-nodes and set to 1 if present
- #size-cells: Specifies the number of cells used to represent
the size of an address. Must be present if the device has
sub-nodes and set to 1 if present
- clock-frequency: Input system clock frequency (SYSCLK)
- clocks: If clock-frequency is not specified, sysclk may be provided
as an input clock. Either clock-frequency or clocks must be
provided.
A second input clock, called "coreclk", may be provided if
core PLLs are based on a different input clock from the
platform PLL.
- clock-names: Required if a coreclk is present. Valid names are
"sysclk" and "coreclk".
2. Clock Provider
The clockgen node should act as a clock provider, though in older device
trees the children of the clockgen node are the clock providers.
When the clockgen node is a clock provider, #clock-cells = <2>.
The first cell of the clock specifier is the clock type, and the
second cell is the clock index for the specified type.
Type# Name Index Cell
0 sysclk must be 0
1 cmux index (n in CLKCnCSR)
2 hwaccel index (n in CLKCGnHWACSR)
3 fman 0 for fm1, 1 for fm2
4 platform pll n=pll/(n+1). For example, when n=1,
that means output_freq=PLL_freq/2.
5 coreclk must be 0
3. Example
clockgen: global-utilities@e1000 {
compatible = "fsl,p5020-clockgen", "fsl,qoriq-clockgen-1.0";
clock-frequency = <133333333>;
reg = <0xe1000 0x1000>;
#clock-cells = <2>;
};
fman@400000 {
...
clocks = <&clockgen 3 0>;
...
};
}
4. Legacy Child Nodes
NOTE: These nodes are deprecated. Kernels should continue to support
device trees with these nodes, but new device trees should not use them.
Most of the bindings are from the common clock binding[1].
[1] Documentation/devicetree/bindings/clock/clock-bindings.txt
Required properties:
- compatible : Should include one of the following:
* "fsl,qoriq-core-pll-1.0" for core PLL clocks (v1.0)
* "fsl,qoriq-core-pll-2.0" for core PLL clocks (v2.0)
* "fsl,qoriq-core-mux-1.0" for core mux clocks (v1.0)
* "fsl,qoriq-core-mux-2.0" for core mux clocks (v2.0)
* "fsl,qoriq-sysclk-1.0": for input system clock (v1.0).
It takes parent's clock-frequency as its clock.
* "fsl,qoriq-sysclk-2.0": for input system clock (v2.0).
It takes parent's clock-frequency as its clock.
* "fsl,qoriq-platform-pll-1.0" for the platform PLL clock (v1.0)
* "fsl,qoriq-platform-pll-2.0" for the platform PLL clock (v2.0)
- #clock-cells: From common clock binding. The number of cells in a
clock-specifier. Should be <0> for "fsl,qoriq-sysclk-[1,2].0"
clocks, or <1> for "fsl,qoriq-core-pll-[1,2].0" clocks.
For "fsl,qoriq-core-pll-[1,2].0" clocks, the single
clock-specifier cell may take the following values:
* 0 - equal to the PLL frequency
* 1 - equal to the PLL frequency divided by 2
* 2 - equal to the PLL frequency divided by 4
Recommended properties:
- clocks: Should be the phandle of input parent clock
- clock-names: From common clock binding, indicates the clock name
- clock-output-names: From common clock binding, indicates the names of
output clocks
- reg: Should be the offset and length of clock block base address.
The length should be 4.
Legacy Example:
/ {
clockgen: global-utilities@e1000 {
compatible = "fsl,p5020-clockgen", "fsl,qoriq-clockgen-1.0";
ranges = <0x0 0xe1000 0x1000>;
clock-frequency = <133333333>;
reg = <0xe1000 0x1000>;
#address-cells = <1>;
#size-cells = <1>;
sysclk: sysclk {
#clock-cells = <0>;
compatible = "fsl,qoriq-sysclk-1.0";
clock-output-names = "sysclk";
};
pll0: pll0@800 {
#clock-cells = <1>;
reg = <0x800 0x4>;
compatible = "fsl,qoriq-core-pll-1.0";
clocks = <&sysclk>;
clock-output-names = "pll0", "pll0-div2";
};
pll1: pll1@820 {
#clock-cells = <1>;
reg = <0x820 0x4>;
compatible = "fsl,qoriq-core-pll-1.0";
clocks = <&sysclk>;
clock-output-names = "pll1", "pll1-div2";
};
mux0: mux0@0 {
#clock-cells = <0>;
reg = <0x0 0x4>;
compatible = "fsl,qoriq-core-mux-1.0";
clocks = <&pll0 0>, <&pll0 1>, <&pll1 0>, <&pll1 1>;
clock-names = "pll0", "pll0-div2", "pll1", "pll1-div2";
clock-output-names = "cmux0";
};
mux1: mux1@20 {
#clock-cells = <0>;
reg = <0x20 0x4>;
compatible = "fsl,qoriq-core-mux-1.0";
clocks = <&pll0 0>, <&pll0 1>, <&pll1 0>, <&pll1 1>;
clock-names = "pll0", "pll0-div2", "pll1", "pll1-div2";
clock-output-names = "cmux1";
};
platform-pll: platform-pll@c00 {
#clock-cells = <1>;
reg = <0xc00 0x4>;
compatible = "fsl,qoriq-platform-pll-1.0";
clocks = <&sysclk>;
clock-output-names = "platform-pll", "platform-pll-div2";
};
};
};
Example for legacy clock consumer:
/ {
cpu0: PowerPC,e5500@0 {
...
clocks = <&mux0>;
...
};
};
Spreadtrum SC9860 Clock Binding
------------------------
Required properties:
- compatible: should contain the following compatible strings:
- "sprd,sc9860-pmu-gate"
- "sprd,sc9860-pll"
- "sprd,sc9860-ap-clk"
- "sprd,sc9860-aon-prediv"
- "sprd,sc9860-apahb-gate"
- "sprd,sc9860-aon-gate"
- "sprd,sc9860-aonsecure-clk"
- "sprd,sc9860-agcp-gate"
- "sprd,sc9860-gpu-clk"
- "sprd,sc9860-vsp-clk"
- "sprd,sc9860-vsp-gate"
- "sprd,sc9860-cam-clk"
- "sprd,sc9860-cam-gate"
- "sprd,sc9860-disp-clk"
- "sprd,sc9860-disp-gate"
- "sprd,sc9860-apapb-gate"
- #clock-cells: must be 1
- clocks : Should be the input parent clock(s) phandle for the clock, this
property here just simply shows which clock group the clocks'
parents are in, since each clk node would represent many clocks
which are defined in the driver. The detailed dependency
relationship (i.e. how many parents and which are the parents)
are implemented in driver code.
Optional properties:
- reg: Contain the registers base address and length. It must be configured
only if no 'sprd,syscon' under the node.
- sprd,syscon: phandle to the syscon which is in the same address area with
the clock, and so we can get regmap for the clocks from the
syscon device.
Example:
pmu_gate: pmu-gate {
compatible = "sprd,sc9860-pmu-gate";
sprd,syscon = <&pmu_regs>;
clocks = <&ext_26m>;
#clock-cells = <1>;
};
pll: pll {
compatible = "sprd,sc9860-pll";
sprd,syscon = <&ana_regs>;
clocks = <&pmu_gate 0>;
#clock-cells = <1>;
};
ap_clk: clock-controller@20000000 {
compatible = "sprd,sc9860-ap-clk";
reg = <0 0x20000000 0 0x400>;
clocks = <&ext_26m>, <&pll 0>,
<&pmu_gate 0>;
#clock-cells = <1>;
};
# SPDX-License-Identifier: GPL-2.0-only OR BSD-2-Clause
%YAML 1.2
---
$id: http://devicetree.org/schemas/clock/sprd,sc9860-clk.yaml#
$schema: http://devicetree.org/meta-schemas/core.yaml#
title: Spreadtrum SC9860 clock
maintainers:
- Orson Zhai <orsonzhai@gmail.com>
- Baolin Wang <baolin.wang7@gmail.com>
- Chunyan Zhang <zhang.lyra@gmail.com>
properties:
compatible:
enum:
- sprd,sc9860-agcp-gate
- sprd,sc9860-aonsecure-clk
- sprd,sc9860-aon-gate
- sprd,sc9860-aon-prediv
- sprd,sc9860-apahb-gate
- sprd,sc9860-apapb-gate
- sprd,sc9860-ap-clk
- sprd,sc9860-cam-clk
- sprd,sc9860-cam-gate
- sprd,sc9860-disp-clk
- sprd,sc9860-disp-gate
- sprd,sc9860-gpu-clk
- sprd,sc9860-pll
- sprd,sc9860-pmu-gate
- sprd,sc9860-vsp-clk
- sprd,sc9860-vsp-gate
reg:
maxItems: 1
clocks:
minItems: 1
maxItems: 3
'#clock-cells':
const: 1
sprd,syscon:
$ref: /schemas/types.yaml#/definitions/phandle
description:
phandle to the syscon which is in the same address area with the
clock, and so we can get regmap for the clocks from the syscon device
required:
- compatible
- clocks
- '#clock-cells'
allOf:
- if:
properties:
compatible:
contains:
enum:
- sprd,sc9860-agcp-gate
- sprd,sc9860-aon-gate
- sprd,sc9860-apahb-gate
- sprd,sc9860-apapb-gate
- sprd,sc9860-cam-gate
- sprd,sc9860-disp-gate
- sprd,sc9860-gpu-clk
- sprd,sc9860-pll
- sprd,sc9860-pmu-gate
- sprd,sc9860-vsp-gate
then:
properties:
clocks:
maxItems: 1
- if:
properties:
compatible:
contains:
enum:
- sprd,sc9860-aonsecure-clk
- sprd,sc9860-cam-clk
- sprd,sc9860-disp-clk
- sprd,sc9860-vsp-clk
then:
properties:
clocks:
minItems: 2
maxItems: 2
- if:
properties:
compatible:
contains:
enum:
- sprd,sc9860-aon-prediv
- sprd,sc9860-ap-clk
then:
properties:
clocks:
minItems: 3
- if:
properties:
compatible:
contains:
enum:
- sprd,sc9860-aonsecure-clk
- sprd,sc9860-aon-prediv
- sprd,sc9860-ap-clk
- sprd,sc9860-cam-clk
- sprd,sc9860-disp-clk
- sprd,sc9860-gpu-clk
- sprd,sc9860-vsp-clk
then:
required:
- reg
properties:
sprd,syscon: false
- if:
properties:
compatible:
contains:
enum:
- sprd,sc9860-agcp-gate
- sprd,sc9860-aon-gate
- sprd,sc9860-apahb-gate
- sprd,sc9860-apapb-gate
- sprd,sc9860-cam-gate
- sprd,sc9860-disp-gate
- sprd,sc9860-pll
- sprd,sc9860-pmu-gate
- sprd,sc9860-vsp-gate
then:
required:
- sprd,syscon
properties:
reg: false
additionalProperties: false
examples:
- |
soc {
#address-cells = <2>;
#size-cells = <2>;
pmu-gate {
compatible = "sprd,sc9860-pmu-gate";
clocks = <&ext_26m>;
#clock-cells = <1>;
sprd,syscon = <&pmu_regs>;
};
clock-controller@20000000 {
compatible = "sprd,sc9860-ap-clk";
reg = <0 0x20000000 0 0x400>;
clocks = <&ext_26m>, <&pll 0>, <&pmu_gate 0>;
#clock-cells = <1>;
};
};
...
...@@ -514,6 +514,7 @@ config CLK_KUNIT_TEST ...@@ -514,6 +514,7 @@ config CLK_KUNIT_TEST
config CLK_GATE_KUNIT_TEST config CLK_GATE_KUNIT_TEST
tristate "Basic gate type Kunit test" if !KUNIT_ALL_TESTS tristate "Basic gate type Kunit test" if !KUNIT_ALL_TESTS
depends on KUNIT depends on KUNIT
depends on !S390
default KUNIT_ALL_TESTS default KUNIT_ALL_TESTS
help help
Kunit test for the basic clk gate type. Kunit test for the basic clk gate type.
......
This diff is collapsed.
// SPDX-License-Identifier: GPL-2.0 // SPDX-License-Identifier: GPL-2.0
/* /*
* Kunit test for clock fractional divider * Kunit tests for clk fractional divider
*/ */
#include <linux/clk-provider.h> #include <linux/clk-provider.h>
#include <kunit/test.h> #include <kunit/test.h>
...@@ -144,4 +144,5 @@ static struct kunit_suite clk_fd_approximation_suite = { ...@@ -144,4 +144,5 @@ static struct kunit_suite clk_fd_approximation_suite = {
kunit_test_suites( kunit_test_suites(
&clk_fd_approximation_suite &clk_fd_approximation_suite
); );
MODULE_DESCRIPTION("Kunit tests for clk fractional divider");
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
// SPDX-License-Identifier: GPL-2.0 // SPDX-License-Identifier: GPL-2.0
/* /*
* Kunit test for clk gate basic type * Kunit tests for clk gate
*/ */
#include <linux/clk.h> #include <linux/clk.h>
#include <linux/clk-provider.h> #include <linux/clk-provider.h>
...@@ -461,4 +461,5 @@ kunit_test_suites( ...@@ -461,4 +461,5 @@ kunit_test_suites(
&clk_gate_test_hiword_suite, &clk_gate_test_hiword_suite,
&clk_gate_test_enabled_suite &clk_gate_test_enabled_suite
); );
MODULE_DESCRIPTION("Kunit tests for clk gate");
MODULE_LICENSE("GPL v2"); MODULE_LICENSE("GPL v2");
// SPDX-License-Identifier: GPL-2.0 // SPDX-License-Identifier: GPL-2.0
/* /*
* Kunit test for clk rate management * Kunit tests for clk framework
*/ */
#include <linux/clk.h> #include <linux/clk.h>
#include <linux/clk-provider.h> #include <linux/clk-provider.h>
...@@ -2674,4 +2674,5 @@ kunit_test_suites( ...@@ -2674,4 +2674,5 @@ kunit_test_suites(
&clk_single_parent_mux_test_suite, &clk_single_parent_mux_test_suite,
&clk_uncached_test_suite &clk_uncached_test_suite
); );
MODULE_DESCRIPTION("Kunit tests for clk framework");
MODULE_LICENSE("GPL v2"); MODULE_LICENSE("GPL v2");
...@@ -165,4 +165,6 @@ static struct platform_driver clk_mt2701_aud_drv = { ...@@ -165,4 +165,6 @@ static struct platform_driver clk_mt2701_aud_drv = {
}, },
}; };
module_platform_driver(clk_mt2701_aud_drv); module_platform_driver(clk_mt2701_aud_drv);
MODULE_DESCRIPTION("MediaTek MT2701 audio clocks driver");
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
...@@ -106,4 +106,6 @@ static struct platform_driver clk_mt2701_bdp_drv = { ...@@ -106,4 +106,6 @@ static struct platform_driver clk_mt2701_bdp_drv = {
}, },
}; };
module_platform_driver(clk_mt2701_bdp_drv); module_platform_driver(clk_mt2701_bdp_drv);
MODULE_DESCRIPTION("MediaTek MT2701 BDP clocks driver");
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
...@@ -60,4 +60,6 @@ static struct platform_driver clk_mt2701_eth_drv = { ...@@ -60,4 +60,6 @@ static struct platform_driver clk_mt2701_eth_drv = {
}, },
}; };
module_platform_driver(clk_mt2701_eth_drv); module_platform_driver(clk_mt2701_eth_drv);
MODULE_DESCRIPTION("MediaTek MT2701 Ethernet clocks driver");
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
...@@ -57,4 +57,6 @@ static struct platform_driver clk_mt2701_g3d_drv = { ...@@ -57,4 +57,6 @@ static struct platform_driver clk_mt2701_g3d_drv = {
}, },
}; };
module_platform_driver(clk_mt2701_g3d_drv); module_platform_driver(clk_mt2701_g3d_drv);
MODULE_DESCRIPTION("MediaTek MT2701 GPU g3d clocks driver");
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
...@@ -57,4 +57,6 @@ static struct platform_driver clk_mt2701_hif_drv = { ...@@ -57,4 +57,6 @@ static struct platform_driver clk_mt2701_hif_drv = {
}, },
}; };
module_platform_driver(clk_mt2701_hif_drv); module_platform_driver(clk_mt2701_hif_drv);
MODULE_DESCRIPTION("MediaTek MT2701 HIFSYS clocks driver");
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
...@@ -54,4 +54,6 @@ static struct platform_driver clk_mt2701_img_drv = { ...@@ -54,4 +54,6 @@ static struct platform_driver clk_mt2701_img_drv = {
}, },
}; };
module_platform_driver(clk_mt2701_img_drv); module_platform_driver(clk_mt2701_img_drv);
MODULE_DESCRIPTION("MediaTek MT2701 imgsys clocks driver");
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
...@@ -87,4 +87,6 @@ static struct platform_driver clk_mt2701_mm_drv = { ...@@ -87,4 +87,6 @@ static struct platform_driver clk_mt2701_mm_drv = {
.id_table = clk_mt2701_mm_id_table, .id_table = clk_mt2701_mm_id_table,
}; };
module_platform_driver(clk_mt2701_mm_drv); module_platform_driver(clk_mt2701_mm_drv);
MODULE_DESCRIPTION("MediaTek MT2701 MultiMedia ddp clocks driver");
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
...@@ -59,4 +59,6 @@ static struct platform_driver clk_mt2701_vdec_drv = { ...@@ -59,4 +59,6 @@ static struct platform_driver clk_mt2701_vdec_drv = {
}, },
}; };
module_platform_driver(clk_mt2701_vdec_drv); module_platform_driver(clk_mt2701_vdec_drv);
MODULE_DESCRIPTION("MediaTek MT2701 Video Decoders clocks driver");
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
...@@ -1037,4 +1037,6 @@ static int __init clk_mt2701_init(void) ...@@ -1037,4 +1037,6 @@ static int __init clk_mt2701_init(void)
} }
arch_initcall(clk_mt2701_init); arch_initcall(clk_mt2701_init);
MODULE_DESCRIPTION("MediaTek MT2701 main clocks driver");
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
...@@ -163,4 +163,6 @@ static struct platform_driver clk_mt2712_apmixed_drv = { ...@@ -163,4 +163,6 @@ static struct platform_driver clk_mt2712_apmixed_drv = {
}, },
}; };
module_platform_driver(clk_mt2712_apmixed_drv) module_platform_driver(clk_mt2712_apmixed_drv)
MODULE_DESCRIPTION("MediaTek MT2712 apmixedsys clocks driver");
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
...@@ -76,4 +76,6 @@ static struct platform_driver clk_mt2712_bdp_drv = { ...@@ -76,4 +76,6 @@ static struct platform_driver clk_mt2712_bdp_drv = {
}, },
}; };
module_platform_driver(clk_mt2712_bdp_drv); module_platform_driver(clk_mt2712_bdp_drv);
MODULE_DESCRIPTION("MediaTek MT2712 BDP clocks driver");
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
...@@ -54,4 +54,6 @@ static struct platform_driver clk_mt2712_img_drv = { ...@@ -54,4 +54,6 @@ static struct platform_driver clk_mt2712_img_drv = {
}, },
}; };
module_platform_driver(clk_mt2712_img_drv); module_platform_driver(clk_mt2712_img_drv);
MODULE_DESCRIPTION("MediaTek MT2712 imgsys clocks driver");
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
...@@ -50,4 +50,6 @@ static struct platform_driver clk_mt2712_jpgdec_drv = { ...@@ -50,4 +50,6 @@ static struct platform_driver clk_mt2712_jpgdec_drv = {
}, },
}; };
module_platform_driver(clk_mt2712_jpgdec_drv); module_platform_driver(clk_mt2712_jpgdec_drv);
MODULE_DESCRIPTION("MediaTek MT2712 JPEG Decoder clocks driver");
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
...@@ -49,4 +49,6 @@ static struct platform_driver clk_mt2712_mfg_drv = { ...@@ -49,4 +49,6 @@ static struct platform_driver clk_mt2712_mfg_drv = {
}, },
}; };
module_platform_driver(clk_mt2712_mfg_drv); module_platform_driver(clk_mt2712_mfg_drv);
MODULE_DESCRIPTION("MediaTek MT2712 GPU mfg clocks driver");
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
...@@ -128,4 +128,6 @@ static struct platform_driver clk_mt2712_mm_drv = { ...@@ -128,4 +128,6 @@ static struct platform_driver clk_mt2712_mm_drv = {
.id_table = clk_mt2712_mm_id_table, .id_table = clk_mt2712_mm_id_table,
}; };
module_platform_driver(clk_mt2712_mm_drv); module_platform_driver(clk_mt2712_mm_drv);
MODULE_DESCRIPTION("MediaTek MT2712 MultiMedia ddp clocks driver");
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
...@@ -62,4 +62,6 @@ static struct platform_driver clk_mt2712_vdec_drv = { ...@@ -62,4 +62,6 @@ static struct platform_driver clk_mt2712_vdec_drv = {
}, },
}; };
module_platform_driver(clk_mt2712_vdec_drv); module_platform_driver(clk_mt2712_vdec_drv);
MODULE_DESCRIPTION("MediaTek MT2712 Video Decoders clocks driver");
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
...@@ -51,4 +51,6 @@ static struct platform_driver clk_mt2712_venc_drv = { ...@@ -51,4 +51,6 @@ static struct platform_driver clk_mt2712_venc_drv = {
}, },
}; };
module_platform_driver(clk_mt2712_venc_drv); module_platform_driver(clk_mt2712_venc_drv);
MODULE_DESCRIPTION("MediaTek MT2712 Video Encoders clocks driver");
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
...@@ -1000,4 +1000,6 @@ static struct platform_driver clk_mt2712_drv = { ...@@ -1000,4 +1000,6 @@ static struct platform_driver clk_mt2712_drv = {
}, },
}; };
module_platform_driver(clk_mt2712_drv); module_platform_driver(clk_mt2712_drv);
MODULE_DESCRIPTION("MediaTek MT2712 main clocks driver");
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
...@@ -76,4 +76,6 @@ static struct platform_driver clk_mt6765_audio_drv = { ...@@ -76,4 +76,6 @@ static struct platform_driver clk_mt6765_audio_drv = {
}, },
}; };
module_platform_driver(clk_mt6765_audio_drv); module_platform_driver(clk_mt6765_audio_drv);
MODULE_DESCRIPTION("MediaTek MT6765 audio clocks driver");
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
...@@ -57,4 +57,6 @@ static struct platform_driver clk_mt6765_cam_drv = { ...@@ -57,4 +57,6 @@ static struct platform_driver clk_mt6765_cam_drv = {
}, },
}; };
module_platform_driver(clk_mt6765_cam_drv); module_platform_driver(clk_mt6765_cam_drv);
MODULE_DESCRIPTION("MediaTek MT6765 Camera clocks driver");
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
...@@ -53,4 +53,6 @@ static struct platform_driver clk_mt6765_img_drv = { ...@@ -53,4 +53,6 @@ static struct platform_driver clk_mt6765_img_drv = {
}, },
}; };
module_platform_driver(clk_mt6765_img_drv); module_platform_driver(clk_mt6765_img_drv);
MODULE_DESCRIPTION("MediaTek MT6765 imgsys clocks driver");
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
...@@ -50,4 +50,6 @@ static struct platform_driver clk_mt6765_mipi0a_drv = { ...@@ -50,4 +50,6 @@ static struct platform_driver clk_mt6765_mipi0a_drv = {
}, },
}; };
module_platform_driver(clk_mt6765_mipi0a_drv); module_platform_driver(clk_mt6765_mipi0a_drv);
MODULE_DESCRIPTION("MediaTek MT6765 Camera clocks driver");
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
...@@ -79,4 +79,6 @@ static struct platform_driver clk_mt6765_mm_drv = { ...@@ -79,4 +79,6 @@ static struct platform_driver clk_mt6765_mm_drv = {
}, },
}; };
module_platform_driver(clk_mt6765_mm_drv); module_platform_driver(clk_mt6765_mm_drv);
MODULE_DESCRIPTION("MediaTek MT6765 MultiMedia clocks driver");
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
...@@ -52,4 +52,6 @@ static struct platform_driver clk_mt6765_vcodec_drv = { ...@@ -52,4 +52,6 @@ static struct platform_driver clk_mt6765_vcodec_drv = {
}, },
}; };
module_platform_driver(clk_mt6765_vcodec_drv); module_platform_driver(clk_mt6765_vcodec_drv);
MODULE_DESCRIPTION("MediaTek MT6765 Video Codec clocks driver");
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
...@@ -873,4 +873,6 @@ static int __init clk_mt6765_init(void) ...@@ -873,4 +873,6 @@ static int __init clk_mt6765_init(void)
} }
arch_initcall(clk_mt6765_init); arch_initcall(clk_mt6765_init);
MODULE_DESCRIPTION("MediaTek MT6765 main clocks driver");
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
...@@ -110,6 +110,7 @@ static struct platform_driver clk_mt6779_aud_drv = { ...@@ -110,6 +110,7 @@ static struct platform_driver clk_mt6779_aud_drv = {
.of_match_table = of_match_clk_mt6779_aud, .of_match_table = of_match_clk_mt6779_aud,
}, },
}; };
module_platform_driver(clk_mt6779_aud_drv); module_platform_driver(clk_mt6779_aud_drv);
MODULE_DESCRIPTION("MediaTek MT6779 audio clocks driver");
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
...@@ -61,6 +61,7 @@ static struct platform_driver clk_mt6779_cam_drv = { ...@@ -61,6 +61,7 @@ static struct platform_driver clk_mt6779_cam_drv = {
.of_match_table = of_match_clk_mt6779_cam, .of_match_table = of_match_clk_mt6779_cam,
}, },
}; };
module_platform_driver(clk_mt6779_cam_drv); module_platform_driver(clk_mt6779_cam_drv);
MODULE_DESCRIPTION("MediaTek MT6779 Camera clocks driver");
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
...@@ -55,4 +55,6 @@ static struct platform_driver clk_mt6779_img_drv = { ...@@ -55,4 +55,6 @@ static struct platform_driver clk_mt6779_img_drv = {
}; };
module_platform_driver(clk_mt6779_img_drv); module_platform_driver(clk_mt6779_img_drv);
MODULE_DESCRIPTION("MediaTek MT6779 imgsys clocks driver");
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
...@@ -57,4 +57,6 @@ static struct platform_driver clk_mt6779_ipe_drv = { ...@@ -57,4 +57,6 @@ static struct platform_driver clk_mt6779_ipe_drv = {
}; };
module_platform_driver(clk_mt6779_ipe_drv); module_platform_driver(clk_mt6779_ipe_drv);
MODULE_DESCRIPTION("MediaTek MT6779 Image Processing Engine clocks driver");
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
...@@ -52,4 +52,6 @@ static struct platform_driver clk_mt6779_mfg_drv = { ...@@ -52,4 +52,6 @@ static struct platform_driver clk_mt6779_mfg_drv = {
}; };
module_platform_driver(clk_mt6779_mfg_drv); module_platform_driver(clk_mt6779_mfg_drv);
MODULE_DESCRIPTION("MediaTek MT6779 GPU mfg clocks driver");
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
...@@ -106,4 +106,6 @@ static struct platform_driver clk_mt6779_mm_drv = { ...@@ -106,4 +106,6 @@ static struct platform_driver clk_mt6779_mm_drv = {
}; };
module_platform_driver(clk_mt6779_mm_drv); module_platform_driver(clk_mt6779_mm_drv);
MODULE_DESCRIPTION("MediaTek MT6779 MultiMedia mdp/ddp clocks driver");
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
...@@ -64,4 +64,6 @@ static struct platform_driver clk_mt6779_vdec_drv = { ...@@ -64,4 +64,6 @@ static struct platform_driver clk_mt6779_vdec_drv = {
}; };
module_platform_driver(clk_mt6779_vdec_drv); module_platform_driver(clk_mt6779_vdec_drv);
MODULE_DESCRIPTION("MediaTek MT6779 Video Decoders clocks driver");
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
...@@ -55,4 +55,6 @@ static struct platform_driver clk_mt6779_venc_drv = { ...@@ -55,4 +55,6 @@ static struct platform_driver clk_mt6779_venc_drv = {
}; };
module_platform_driver(clk_mt6779_venc_drv); module_platform_driver(clk_mt6779_venc_drv);
MODULE_DESCRIPTION("MediaTek MT6779 Video Encoders clocks driver");
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
...@@ -1330,4 +1330,6 @@ static int __init clk_mt6779_init(void) ...@@ -1330,4 +1330,6 @@ static int __init clk_mt6779_init(void)
} }
arch_initcall(clk_mt6779_init); arch_initcall(clk_mt6779_init);
MODULE_DESCRIPTION("MediaTek MT6779 main clocks driver");
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
...@@ -97,5 +97,5 @@ static struct platform_driver clk_mt6795_mm_drv = { ...@@ -97,5 +97,5 @@ static struct platform_driver clk_mt6795_mm_drv = {
}; };
module_platform_driver(clk_mt6795_mm_drv); module_platform_driver(clk_mt6795_mm_drv);
MODULE_DESCRIPTION("MediaTek MT6795 MultiMedia clocks driver"); MODULE_DESCRIPTION("MediaTek MT6795 MMSYS clocks driver");
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
...@@ -50,4 +50,6 @@ static struct platform_driver clk_mt6797_img_drv = { ...@@ -50,4 +50,6 @@ static struct platform_driver clk_mt6797_img_drv = {
}, },
}; };
module_platform_driver(clk_mt6797_img_drv); module_platform_driver(clk_mt6797_img_drv);
MODULE_DESCRIPTION("MediaTek MT6797 imgsys clocks driver");
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
...@@ -100,4 +100,6 @@ static struct platform_driver clk_mt6797_mm_drv = { ...@@ -100,4 +100,6 @@ static struct platform_driver clk_mt6797_mm_drv = {
.id_table = clk_mt6797_mm_id_table, .id_table = clk_mt6797_mm_id_table,
}; };
module_platform_driver(clk_mt6797_mm_drv); module_platform_driver(clk_mt6797_mm_drv);
MODULE_DESCRIPTION("MediaTek MT6797 MultiMedia clocks driver");
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
...@@ -61,4 +61,6 @@ static struct platform_driver clk_mt6797_vdec_drv = { ...@@ -61,4 +61,6 @@ static struct platform_driver clk_mt6797_vdec_drv = {
}, },
}; };
module_platform_driver(clk_mt6797_vdec_drv); module_platform_driver(clk_mt6797_vdec_drv);
MODULE_DESCRIPTION("MediaTek MT6797 Video Decoders clocks driver");
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
...@@ -52,4 +52,6 @@ static struct platform_driver clk_mt6797_venc_drv = { ...@@ -52,4 +52,6 @@ static struct platform_driver clk_mt6797_venc_drv = {
}, },
}; };
module_platform_driver(clk_mt6797_venc_drv); module_platform_driver(clk_mt6797_venc_drv);
MODULE_DESCRIPTION("MediaTek MT6797 Video Encoders clocks driver");
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
...@@ -708,4 +708,6 @@ static int __init clk_mt6797_init(void) ...@@ -708,4 +708,6 @@ static int __init clk_mt6797_init(void)
} }
arch_initcall(clk_mt6797_init); arch_initcall(clk_mt6797_init);
MODULE_DESCRIPTION("MediaTek MT6797 main clocks driver");
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
...@@ -156,4 +156,6 @@ static struct platform_driver clk_mt7622_aud_drv = { ...@@ -156,4 +156,6 @@ static struct platform_driver clk_mt7622_aud_drv = {
}, },
}; };
module_platform_driver(clk_mt7622_aud_drv); module_platform_driver(clk_mt7622_aud_drv);
MODULE_DESCRIPTION("MediaTek MT7622 audio clocks driver");
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
...@@ -86,4 +86,6 @@ static struct platform_driver clk_mt7622_eth_drv = { ...@@ -86,4 +86,6 @@ static struct platform_driver clk_mt7622_eth_drv = {
}, },
}; };
module_platform_driver(clk_mt7622_eth_drv); module_platform_driver(clk_mt7622_eth_drv);
MODULE_DESCRIPTION("MediaTek MT7622 Ethernet clocks driver");
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
...@@ -98,4 +98,6 @@ static struct platform_driver clk_mt7622_hif_drv = { ...@@ -98,4 +98,6 @@ static struct platform_driver clk_mt7622_hif_drv = {
}, },
}; };
module_platform_driver(clk_mt7622_hif_drv); module_platform_driver(clk_mt7622_hif_drv);
MODULE_DESCRIPTION("MediaTek MT7622 HIF clocks driver");
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
...@@ -157,4 +157,6 @@ static struct platform_driver clk_mt7629_eth_drv = { ...@@ -157,4 +157,6 @@ static struct platform_driver clk_mt7629_eth_drv = {
}; };
builtin_platform_driver(clk_mt7629_eth_drv); builtin_platform_driver(clk_mt7629_eth_drv);
MODULE_DESCRIPTION("MediaTek MT7629 Ethernet clocks driver");
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
...@@ -93,4 +93,6 @@ static struct platform_driver clk_mt7629_hif_drv = { ...@@ -93,4 +93,6 @@ static struct platform_driver clk_mt7629_hif_drv = {
}, },
}; };
module_platform_driver(clk_mt7629_hif_drv); module_platform_driver(clk_mt7629_hif_drv);
MODULE_DESCRIPTION("MediaTek MT2701 HIF clocks driver");
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
...@@ -698,4 +698,6 @@ static int clk_mt7629_init(void) ...@@ -698,4 +698,6 @@ static int clk_mt7629_init(void)
} }
arch_initcall(clk_mt7629_init); arch_initcall(clk_mt7629_init);
MODULE_DESCRIPTION("MediaTek MT7629 main clocks driver");
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
...@@ -99,4 +99,6 @@ static struct platform_driver clk_mt7981_apmixed_drv = { ...@@ -99,4 +99,6 @@ static struct platform_driver clk_mt7981_apmixed_drv = {
}, },
}; };
builtin_platform_driver(clk_mt7981_apmixed_drv); builtin_platform_driver(clk_mt7981_apmixed_drv);
MODULE_DESCRIPTION("MediaTek MT7981 apmixedsys clocks driver");
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
...@@ -114,4 +114,6 @@ static struct platform_driver clk_mt7981_eth_drv = { ...@@ -114,4 +114,6 @@ static struct platform_driver clk_mt7981_eth_drv = {
}, },
}; };
module_platform_driver(clk_mt7981_eth_drv); module_platform_driver(clk_mt7981_eth_drv);
MODULE_DESCRIPTION("MediaTek MT7981 Ethernet clocks driver");
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
...@@ -204,4 +204,6 @@ static struct platform_driver clk_mt7981_infracfg_drv = { ...@@ -204,4 +204,6 @@ static struct platform_driver clk_mt7981_infracfg_drv = {
}, },
}; };
module_platform_driver(clk_mt7981_infracfg_drv); module_platform_driver(clk_mt7981_infracfg_drv);
MODULE_DESCRIPTION("MediaTek MT7981 infracfg clocks driver");
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
...@@ -420,4 +420,6 @@ static struct platform_driver clk_mt7981_topckgen_drv = { ...@@ -420,4 +420,6 @@ static struct platform_driver clk_mt7981_topckgen_drv = {
}, },
}; };
module_platform_driver(clk_mt7981_topckgen_drv); module_platform_driver(clk_mt7981_topckgen_drv);
MODULE_DESCRIPTION("MediaTek MT7981 top clock generators driver");
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
...@@ -97,4 +97,6 @@ static struct platform_driver clk_mt7986_apmixed_drv = { ...@@ -97,4 +97,6 @@ static struct platform_driver clk_mt7986_apmixed_drv = {
}, },
}; };
builtin_platform_driver(clk_mt7986_apmixed_drv); builtin_platform_driver(clk_mt7986_apmixed_drv);
MODULE_DESCRIPTION("MediaTek MT7986 apmixedsys clocks driver");
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
...@@ -313,4 +313,6 @@ static struct platform_driver clk_mt7986_topckgen_drv = { ...@@ -313,4 +313,6 @@ static struct platform_driver clk_mt7986_topckgen_drv = {
}, },
}; };
module_platform_driver(clk_mt7986_topckgen_drv); module_platform_driver(clk_mt7986_topckgen_drv);
MODULE_DESCRIPTION("MediaTek MT7986 top clock generators driver");
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
...@@ -111,4 +111,6 @@ static struct platform_driver clk_mt7988_apmixed_drv = { ...@@ -111,4 +111,6 @@ static struct platform_driver clk_mt7988_apmixed_drv = {
}, },
}; };
builtin_platform_driver(clk_mt7988_apmixed_drv); builtin_platform_driver(clk_mt7988_apmixed_drv);
MODULE_DESCRIPTION("MediaTek MT7988 apmixedsys clocks driver");
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
...@@ -295,4 +295,6 @@ static struct platform_driver clk_mt7988_infracfg_drv = { ...@@ -295,4 +295,6 @@ static struct platform_driver clk_mt7988_infracfg_drv = {
.remove_new = mtk_clk_simple_remove, .remove_new = mtk_clk_simple_remove,
}; };
module_platform_driver(clk_mt7988_infracfg_drv); module_platform_driver(clk_mt7988_infracfg_drv);
MODULE_DESCRIPTION("MediaTek MT7988 infracfg clocks driver");
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
...@@ -322,4 +322,6 @@ static struct platform_driver clk_mt7988_topckgen_drv = { ...@@ -322,4 +322,6 @@ static struct platform_driver clk_mt7988_topckgen_drv = {
}, },
}; };
module_platform_driver(clk_mt7988_topckgen_drv); module_platform_driver(clk_mt7988_topckgen_drv);
MODULE_DESCRIPTION("MediaTek MT7988 top clock generators driver");
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
...@@ -142,4 +142,6 @@ static struct platform_driver clk_mt8167_apmixed_drv = { ...@@ -142,4 +142,6 @@ static struct platform_driver clk_mt8167_apmixed_drv = {
}, },
}; };
builtin_platform_driver(clk_mt8167_apmixed_drv) builtin_platform_driver(clk_mt8167_apmixed_drv)
MODULE_DESCRIPTION("MediaTek MT8167 apmixedsys clocks driver");
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
...@@ -61,4 +61,6 @@ static struct platform_driver clk_mt8167_audsys_drv = { ...@@ -61,4 +61,6 @@ static struct platform_driver clk_mt8167_audsys_drv = {
}, },
}; };
module_platform_driver(clk_mt8167_audsys_drv); module_platform_driver(clk_mt8167_audsys_drv);
MODULE_DESCRIPTION("MediaTek MT8167 audio clocks driver");
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
...@@ -53,4 +53,6 @@ static struct platform_driver clk_mt8167_imgsys_drv = { ...@@ -53,4 +53,6 @@ static struct platform_driver clk_mt8167_imgsys_drv = {
}, },
}; };
module_platform_driver(clk_mt8167_imgsys_drv); module_platform_driver(clk_mt8167_imgsys_drv);
MODULE_DESCRIPTION("MediaTek MT8167 imgsys clocks driver");
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
...@@ -51,4 +51,6 @@ static struct platform_driver clk_mt8167_mfgcfg_drv = { ...@@ -51,4 +51,6 @@ static struct platform_driver clk_mt8167_mfgcfg_drv = {
}, },
}; };
module_platform_driver(clk_mt8167_mfgcfg_drv); module_platform_driver(clk_mt8167_mfgcfg_drv);
MODULE_DESCRIPTION("MediaTek MT8167 GPU mfg clocks driver");
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
...@@ -92,4 +92,6 @@ static struct platform_driver clk_mt8167_mm_drv = { ...@@ -92,4 +92,6 @@ static struct platform_driver clk_mt8167_mm_drv = {
.id_table = clk_mt8167_mm_id_table, .id_table = clk_mt8167_mm_id_table,
}; };
module_platform_driver(clk_mt8167_mm_drv); module_platform_driver(clk_mt8167_mm_drv);
MODULE_DESCRIPTION("MediaTek MT8167 MultiMedia clocks driver");
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
...@@ -60,4 +60,6 @@ static struct platform_driver clk_mt8167_vdec_drv = { ...@@ -60,4 +60,6 @@ static struct platform_driver clk_mt8167_vdec_drv = {
}, },
}; };
module_platform_driver(clk_mt8167_vdec_drv); module_platform_driver(clk_mt8167_vdec_drv);
MODULE_DESCRIPTION("MediaTek MT8167 Video Decoders clocks driver");
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
...@@ -894,4 +894,6 @@ static struct platform_driver clk_mt8167_drv = { ...@@ -894,4 +894,6 @@ static struct platform_driver clk_mt8167_drv = {
}, },
}; };
module_platform_driver(clk_mt8167_drv); module_platform_driver(clk_mt8167_drv);
MODULE_DESCRIPTION("MediaTek MTì8167 main clocks driver");
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
...@@ -98,7 +98,17 @@ CLK_OF_DECLARE_DRIVER(mtk_infrasys, "mediatek,mt8173-infracfg", ...@@ -98,7 +98,17 @@ CLK_OF_DECLARE_DRIVER(mtk_infrasys, "mediatek,mt8173-infracfg",
static int clk_mt8173_infracfg_probe(struct platform_device *pdev) static int clk_mt8173_infracfg_probe(struct platform_device *pdev)
{ {
struct device_node *node = pdev->dev.of_node; struct device_node *node = pdev->dev.of_node;
int r; int r, i;
if (!infra_clk_data) {
infra_clk_data = mtk_alloc_clk_data(CLK_INFRA_NR_CLK);
if (!infra_clk_data)
return -ENOMEM;
} else {
for (i = 0; i < CLK_INFRA_NR_CLK; i++)
if (infra_clk_data->hws[i] == ERR_PTR(-EPROBE_DEFER))
infra_clk_data->hws[i] = ERR_PTR(-ENOENT);
}
r = mtk_clk_register_gates(&pdev->dev, node, infra_gates, r = mtk_clk_register_gates(&pdev->dev, node, infra_gates,
ARRAY_SIZE(infra_gates), infra_clk_data); ARRAY_SIZE(infra_gates), infra_clk_data);
......
...@@ -192,4 +192,6 @@ static struct platform_driver clk_mt8183_apmixed_drv = { ...@@ -192,4 +192,6 @@ static struct platform_driver clk_mt8183_apmixed_drv = {
}, },
}; };
builtin_platform_driver(clk_mt8183_apmixed_drv) builtin_platform_driver(clk_mt8183_apmixed_drv)
MODULE_DESCRIPTION("MediaTek MT8183 apmixedsys clocks driver");
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
...@@ -108,4 +108,6 @@ static struct platform_driver clk_mt8183_audio_drv = { ...@@ -108,4 +108,6 @@ static struct platform_driver clk_mt8183_audio_drv = {
}, },
}; };
module_platform_driver(clk_mt8183_audio_drv); module_platform_driver(clk_mt8183_audio_drv);
MODULE_DESCRIPTION("MediaTek MT8183 audio clocks driver");
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
...@@ -58,4 +58,6 @@ static struct platform_driver clk_mt8183_cam_drv = { ...@@ -58,4 +58,6 @@ static struct platform_driver clk_mt8183_cam_drv = {
}, },
}; };
module_platform_driver(clk_mt8183_cam_drv); module_platform_driver(clk_mt8183_cam_drv);
MODULE_DESCRIPTION("MediaTek MT8183 Camera clocks driver");
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
...@@ -58,4 +58,6 @@ static struct platform_driver clk_mt8183_img_drv = { ...@@ -58,4 +58,6 @@ static struct platform_driver clk_mt8183_img_drv = {
}, },
}; };
module_platform_driver(clk_mt8183_img_drv); module_platform_driver(clk_mt8183_img_drv);
MODULE_DESCRIPTION("MediaTek MT8183 imgsys clocks driver");
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
...@@ -51,4 +51,6 @@ static struct platform_driver clk_mt8183_ipu_core0_drv = { ...@@ -51,4 +51,6 @@ static struct platform_driver clk_mt8183_ipu_core0_drv = {
}, },
}; };
module_platform_driver(clk_mt8183_ipu_core0_drv); module_platform_driver(clk_mt8183_ipu_core0_drv);
MODULE_DESCRIPTION("MediaTek MT8183 Pri. Image Processing Unit clocks driver");
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
...@@ -51,4 +51,6 @@ static struct platform_driver clk_mt8183_ipu_core1_drv = { ...@@ -51,4 +51,6 @@ static struct platform_driver clk_mt8183_ipu_core1_drv = {
}, },
}; };
module_platform_driver(clk_mt8183_ipu_core1_drv); module_platform_driver(clk_mt8183_ipu_core1_drv);
MODULE_DESCRIPTION("MediaTek MT8183 Sec. Image Processing Unit clocks driver");
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
...@@ -49,4 +49,6 @@ static struct platform_driver clk_mt8183_ipu_adl_drv = { ...@@ -49,4 +49,6 @@ static struct platform_driver clk_mt8183_ipu_adl_drv = {
}, },
}; };
module_platform_driver(clk_mt8183_ipu_adl_drv); module_platform_driver(clk_mt8183_ipu_adl_drv);
MODULE_DESCRIPTION("MediaTek MT8183 Image Processing Unit ADL driver");
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
...@@ -118,4 +118,6 @@ static struct platform_driver clk_mt8183_ipu_conn_drv = { ...@@ -118,4 +118,6 @@ static struct platform_driver clk_mt8183_ipu_conn_drv = {
}, },
}; };
module_platform_driver(clk_mt8183_ipu_conn_drv); module_platform_driver(clk_mt8183_ipu_conn_drv);
MODULE_DESCRIPTION("MediaTek MT8183 Image Processing Unit Bus clocks driver");
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
...@@ -50,4 +50,6 @@ static struct platform_driver clk_mt8183_mfg_drv = { ...@@ -50,4 +50,6 @@ static struct platform_driver clk_mt8183_mfg_drv = {
}, },
}; };
module_platform_driver(clk_mt8183_mfg_drv); module_platform_driver(clk_mt8183_mfg_drv);
MODULE_DESCRIPTION("MediaTek MT8183 GPU mfg clocks driver");
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
...@@ -102,4 +102,6 @@ static struct platform_driver clk_mt8183_mm_drv = { ...@@ -102,4 +102,6 @@ static struct platform_driver clk_mt8183_mm_drv = {
.id_table = clk_mt8183_mm_id_table, .id_table = clk_mt8183_mm_id_table,
}; };
module_platform_driver(clk_mt8183_mm_drv); module_platform_driver(clk_mt8183_mm_drv);
MODULE_DESCRIPTION("MediaTek MT8183 MultiMedia clocks driver");
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
...@@ -62,4 +62,6 @@ static struct platform_driver clk_mt8183_vdec_drv = { ...@@ -62,4 +62,6 @@ static struct platform_driver clk_mt8183_vdec_drv = {
}, },
}; };
module_platform_driver(clk_mt8183_vdec_drv); module_platform_driver(clk_mt8183_vdec_drv);
MODULE_DESCRIPTION("MediaTek MT8183 Video Decoders clocks driver");
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
...@@ -54,4 +54,6 @@ static struct platform_driver clk_mt8183_venc_drv = { ...@@ -54,4 +54,6 @@ static struct platform_driver clk_mt8183_venc_drv = {
}, },
}; };
module_platform_driver(clk_mt8183_venc_drv); module_platform_driver(clk_mt8183_venc_drv);
MODULE_DESCRIPTION("MediaTek MT8183 Video Encoders clocks driver");
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
...@@ -906,4 +906,6 @@ static struct platform_driver clk_mt8183_drv = { ...@@ -906,4 +906,6 @@ static struct platform_driver clk_mt8183_drv = {
}, },
}; };
module_platform_driver(clk_mt8183_drv) module_platform_driver(clk_mt8183_drv)
MODULE_DESCRIPTION("MediaTek MT8183 main clocks driver");
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
...@@ -192,4 +192,6 @@ static struct platform_driver clk_mt8186_apmixed_drv = { ...@@ -192,4 +192,6 @@ static struct platform_driver clk_mt8186_apmixed_drv = {
}, },
}; };
module_platform_driver(clk_mt8186_apmixed_drv); module_platform_driver(clk_mt8186_apmixed_drv);
MODULE_DESCRIPTION("MediaTek MT8186 apmixedsys clocks driver");
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
...@@ -89,4 +89,6 @@ static struct platform_driver clk_mt8186_cam_drv = { ...@@ -89,4 +89,6 @@ static struct platform_driver clk_mt8186_cam_drv = {
}, },
}; };
module_platform_driver(clk_mt8186_cam_drv); module_platform_driver(clk_mt8186_cam_drv);
MODULE_DESCRIPTION("MediaTek MT8186 Camera clocks driver");
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
...@@ -67,4 +67,6 @@ static struct platform_driver clk_mt8186_img_drv = { ...@@ -67,4 +67,6 @@ static struct platform_driver clk_mt8186_img_drv = {
}, },
}; };
module_platform_driver(clk_mt8186_img_drv); module_platform_driver(clk_mt8186_img_drv);
MODULE_DESCRIPTION("MediaTek MT8186 imgsys clocks driver");
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
...@@ -66,4 +66,6 @@ static struct platform_driver clk_mt8186_imp_iic_wrap_drv = { ...@@ -66,4 +66,6 @@ static struct platform_driver clk_mt8186_imp_iic_wrap_drv = {
}, },
}; };
module_platform_driver(clk_mt8186_imp_iic_wrap_drv); module_platform_driver(clk_mt8186_imp_iic_wrap_drv);
MODULE_DESCRIPTION("MediaTek MT8186 I2C Wrapper clocks driver");
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
...@@ -238,4 +238,6 @@ static struct platform_driver clk_mt8186_infra_ao_drv = { ...@@ -238,4 +238,6 @@ static struct platform_driver clk_mt8186_infra_ao_drv = {
}, },
}; };
module_platform_driver(clk_mt8186_infra_ao_drv); module_platform_driver(clk_mt8186_infra_ao_drv);
MODULE_DESCRIPTION("MediaTek MT8186 infracfg clocks driver");
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
...@@ -54,4 +54,6 @@ static struct platform_driver clk_mt8186_ipe_drv = { ...@@ -54,4 +54,6 @@ static struct platform_driver clk_mt8186_ipe_drv = {
}, },
}; };
module_platform_driver(clk_mt8186_ipe_drv); module_platform_driver(clk_mt8186_ipe_drv);
MODULE_DESCRIPTION("MediaTek MT8186 Image Processing Engine clocks driver");
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
...@@ -79,4 +79,6 @@ static struct platform_driver clk_mt8186_mdp_drv = { ...@@ -79,4 +79,6 @@ static struct platform_driver clk_mt8186_mdp_drv = {
}, },
}; };
module_platform_driver(clk_mt8186_mdp_drv); module_platform_driver(clk_mt8186_mdp_drv);
MODULE_DESCRIPTION("MediaTek MT8186 Multimedia Data Path clocks driver");
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
...@@ -48,4 +48,6 @@ static struct platform_driver clk_mt8186_mfg_drv = { ...@@ -48,4 +48,6 @@ static struct platform_driver clk_mt8186_mfg_drv = {
}, },
}; };
module_platform_driver(clk_mt8186_mfg_drv); module_platform_driver(clk_mt8186_mfg_drv);
MODULE_DESCRIPTION("MediaTek MT8186 GPU mfg clocks driver");
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
...@@ -78,4 +78,6 @@ static struct platform_driver clk_mt8186_mm_drv = { ...@@ -78,4 +78,6 @@ static struct platform_driver clk_mt8186_mm_drv = {
.id_table = clk_mt8186_mm_id_table, .id_table = clk_mt8186_mm_id_table,
}; };
module_platform_driver(clk_mt8186_mm_drv); module_platform_driver(clk_mt8186_mm_drv);
MODULE_DESCRIPTION("MediaTek MT8186 MultiMedia clocks driver");
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
...@@ -732,4 +732,6 @@ static struct platform_driver clk_mt8186_topck_drv = { ...@@ -732,4 +732,6 @@ static struct platform_driver clk_mt8186_topck_drv = {
}, },
}; };
module_platform_driver(clk_mt8186_topck_drv); module_platform_driver(clk_mt8186_topck_drv);
MODULE_DESCRIPTION("MediaTek MT8186 top clock generators driver");
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment