• Icenowy Zheng's avatar
    drivers: soc: sunxi: add support for remapping func value to reg value · 8fed2ce9
    Icenowy Zheng authored
    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: default avatarIcenowy Zheng <icenowy@aosc.io>
    [wens@csie.org: Clarified commit message]
    Signed-off-by: default avatarChen-Yu Tsai <wens@csie.org>
    8fed2ce9
sunxi_sram.c 6.65 KB