]> git.baikalelectronics.ru Git - kernel.git/commit
drivers: soc: sunxi: add support for remapping func value to reg value
authorIcenowy Zheng <icenowy@aosc.io>
Wed, 9 Aug 2017 08:56:26 +0000 (16:56 +0800)
committerChen-Yu Tsai <wens@csie.org>
Fri, 18 Aug 2017 06:30:20 +0000 (14:30 +0800)
commitcb51e9e70d27009b7360d1ef90716ea03d58006a
tree2d601761ca8a4973fe53c3a845b325c764297e90
parent84179293ddd7b70e134d005f313979b0979a900e
drivers: soc: sunxi: add support for remapping func value to reg value

On some Allwinner SoCs, sometimes the value needed to write into the
register to claim SRAM is not equal to the value specified in the
device tree.

The device tree binding defines 0 as "mapped to CPU" and 1 as "mapped
to X device". This matches the value written to the configuration
register for the SRAM blocks currently supported. However, the not yet
supported VE SRAM block is claimed for the device by writing 0x7fffffff,
which is vastly different from the other blocks. On the A64, SRAM C is
claimed by the device by writing a 0, which is the opposite of the
current design.

Add a value remapping in sunxi_sram_func structure, and let the
sunxi_sram_of_parse function set the remapped register value.
This allows us to keep the convention currently used in the device tree
binding.

Signed-off-by: Icenowy Zheng <icenowy@aosc.io>
[wens@csie.org: Clarified commit message]
Signed-off-by: Chen-Yu Tsai <wens@csie.org>
drivers/soc/sunxi/sunxi_sram.c