6127daa850
Certain platforms such as DRA7 have quirky memory maps such as: PRM_ABBLDO_DSPEVE_CTRL 0x4ae07e20 PRM_ABBLDO_IVA_CTRL 0x4ae07e24 other-registers PRM_ABBLDO_DSPEVE_SETUP 0x4ae07e30 PRM_ABBLDO_IVA_SETUP 0x4ae07e34 These need the address range allocation to be either not reserved OR unique allocation per register instance or use something like syscon based solution. By going with unique allocation per register, we are able to now have a single compatible driver for all instances on all platforms which use the IP block. So, introduce a new "ti,abb-v3" compatible to allow for definitions where explicit register definitions are provided, while maintaining backward compatibility of older predefined register offsets provided by "ti-abb-v1" and "ti-abb-v2". As part of this change, we rename a few variables to indicate the appropriate meaning. Signed-off-by: Nishanth Menon <nm@ti.com> Signed-off-by: Mark Brown <broonie@linaro.org>
133 lines
5.4 KiB
Plaintext
133 lines
5.4 KiB
Plaintext
Adaptive Body Bias(ABB) SoC internal LDO regulator for Texas Instruments SoCs
|
|
|
|
Required Properties:
|
|
- compatible: Should be one of:
|
|
- "ti,abb-v1" for older SoCs like OMAP3
|
|
- "ti,abb-v2" for newer SoCs like OMAP4, OMAP5
|
|
- "ti,abb-v3" for a generic definition where setup and control registers are
|
|
provided (example: DRA7)
|
|
- reg: Address and length of the register set for the device. It contains
|
|
the information of registers in the same order as described by reg-names
|
|
- reg-names: Should contain the reg names
|
|
- "base-address" - contains base address of ABB module (ti,abb-v1,ti,abb-v2)
|
|
- "control-address" - contains control register address of ABB module (ti,abb-v3)
|
|
- "setup-address" - contains setup register address of ABB module (ti,abb-v3)
|
|
- "int-address" - contains address of interrupt register for ABB module
|
|
(also see Optional properties)
|
|
- #address-cell: should be 0
|
|
- #size-cell: should be 0
|
|
- clocks: should point to the clock node used by ABB module
|
|
- ti,settling-time: Settling time in uSecs from SoC documentation for ABB module
|
|
to settle down(target time for SR2_WTCNT_VALUE).
|
|
- ti,clock-cycles: SoC specific data about count of system ti,clock-cycles used for
|
|
computing settling time from SoC Documentation for ABB module(clock
|
|
cycles for SR2_WTCNT_VALUE).
|
|
- ti,tranxdone-status-mask: Mask to the int-register to write-to-clear mask
|
|
indicating LDO tranxdone (operation complete).
|
|
- ti,abb_info: An array of 6-tuples u32 items providing information about ABB
|
|
configuration needed per operational voltage of the device.
|
|
Each item consists of the following in the same order:
|
|
volt: voltage in uV - Only used to index ABB information.
|
|
ABB mode: one of the following:
|
|
0-bypass
|
|
1-Forward Body Bias(FBB)
|
|
3-Reverse Body Bias(RBB)
|
|
efuse: (see Optional properties)
|
|
RBB enable efuse Mask: (See Optional properties)
|
|
FBB enable efuse Mask: (See Optional properties)
|
|
Vset value efuse Mask: (See Optional properties)
|
|
|
|
NOTE: If more than 1 entry is present, then regulator is setup to change
|
|
voltage, allowing for various modes to be selected indexed off
|
|
the regulator. Further, ABB LDOs are considered always-on by
|
|
default.
|
|
|
|
Optional Properties:
|
|
- reg-names: In addition to the required properties, the following are optional
|
|
- "efuse-address" - Contains efuse base address used to pick up ABB info.
|
|
- "ldo-address" - Contains address of ABB LDO overide register address.
|
|
"efuse-address" is required for this.
|
|
- ti,ldovbb-vset-mask - Required if ldo-address is set, mask for LDO override
|
|
register to provide override vset value.
|
|
- ti,ldovbb-override-mask - Required if ldo-address is set, mask for LDO
|
|
override register to enable override vset value.
|
|
- ti,abb_opp_sel: Addendum to the description in required properties
|
|
efuse: Mandatory if 'efuse-address' register is defined. Provides offset
|
|
from efuse-address to pick up ABB characteristics. Set to 0 if
|
|
'efuse-address' is not defined.
|
|
RBB enable efuse Mask: Optional if 'efuse-address' register is defined.
|
|
'ABB mode' is force set to RBB mode if value at "efuse-address"
|
|
+ efuse maps to RBB mask. Set to 0 to ignore this.
|
|
FBB enable efuse Mask: Optional if 'efuse-address' register is defined.
|
|
'ABB mode' is force set to FBB mode if value at "efuse-address"
|
|
+ efuse maps to FBB mask (valid only if RBB mask does not match)
|
|
Set to 0 to ignore this.
|
|
Vset value efuse Mask: Mandatory if ldo-address is set. Picks up from
|
|
efuse the value to set in 'ti,ldovbb-vset-mask' at ldo-address.
|
|
|
|
Example #1: Simplest configuration (no efuse data, hard coded ABB table):
|
|
abb_x: regulator-abb-x {
|
|
compatible = "ti,abb-v1";
|
|
regulator-name = "abb_x";
|
|
#address-cell = <0>;
|
|
#size-cells = <0>;
|
|
reg = <0x483072f0 0x8>, <0x48306818 0x4>;
|
|
reg-names = "base-address", "int-address";
|
|
ti,tranxdone-status-mask = <0x4000000>;
|
|
clocks = <&sysclk>;
|
|
ti,settling-time = <30>;
|
|
ti,clock-cycles = <8>;
|
|
ti,abb_info = <
|
|
/* uV ABB efuse rbb_m fbb_m vset_m */
|
|
1012500 0 0 0 0 0 /* Bypass */
|
|
1200000 3 0 0 0 0 /* RBB mandatory */
|
|
1320000 1 0 0 0 0 /* FBB mandatory */
|
|
>;
|
|
};
|
|
|
|
Example #2: Efuse bits contain ABB mode setting (no LDO override capability)
|
|
abb_y: regulator-abb-y {
|
|
compatible = "ti,abb-v2";
|
|
regulator-name = "abb_y";
|
|
#address-cell = <0>;
|
|
#size-cells = <0>;
|
|
reg = <0x4a307bd0 0x8>, <0x4a306014 0x4>, <0x4A002268 0x8>;
|
|
reg-names = "base-address", "int-address", "efuse-address";
|
|
ti,tranxdone-status-mask = <0x4000000>;
|
|
clocks = <&sysclk>;
|
|
ti,settling-time = <50>;
|
|
ti,clock-cycles = <16>;
|
|
ti,abb_info = <
|
|
/* uV ABB efuse rbb_m fbb_m vset_m */
|
|
975000 0 0 0 0 0 /* Bypass */
|
|
1012500 0 0 0x40000 0 0 /* RBB optional */
|
|
1200000 0 0x4 0 0x40000 0 /* FBB optional */
|
|
1320000 1 0 0 0 0 /* FBB mandatory */
|
|
>;
|
|
};
|
|
|
|
Example #3: Efuse bits contain ABB mode setting and LDO override capability
|
|
abb_z: regulator-abb-z {
|
|
compatible = "ti,abb-v2";
|
|
regulator-name = "abb_z";
|
|
#address-cell = <0>;
|
|
#size-cells = <0>;
|
|
reg = <0x4ae07ce4 0x8>, <0x4ae06010 0x4>,
|
|
<0x4a002194 0x8>, <0x4ae0C314 0x4>;
|
|
reg-names = "base-address", "int-address",
|
|
"efuse-address", "ldo-address";
|
|
ti,tranxdone-status-mask = <0x8000000>;
|
|
/* LDOVBBMM_MUX_CTRL */
|
|
ti,ldovbb-override-mask = <0x400>;
|
|
/* LDOVBBMM_VSET_OUT */
|
|
ti,ldovbb-vset-mask = <0x1F>;
|
|
clocks = <&sysclk>;
|
|
ti,settling-time = <50>;
|
|
ti,clock-cycles = <16>;
|
|
ti,abb_info = <
|
|
/* uV ABB efuse rbb_m fbb_m vset_m */
|
|
975000 0 0 0 0 0 /* Bypass */
|
|
1200000 0 0x4 0 0x40000 0x1f00 /* FBB optional, vset */
|
|
>;
|
|
};
|