• 周琰杰 (Zhou Yanjie)'s avatar
    dt-bindings: timer: Add new OST support for the upcoming new driver. · 0fce2e02
    周琰杰 (Zhou Yanjie) authored
    The new OST has one global timer and two or four percpu timers, so there
    will be three combinations in the upcoming new OST driver: the original
    GLOBAL_TIMER + PERCPU_TIMER, the new GLOBAL_TIMER + PERCPU_TIMER0/1 and
    GLOBAL_TIMER + PERCPU_TIMER0/1/2/3, For this, add the macro definition
    about OST_CLK_PERCPU_TIMER0/1/2/3. And in order to ensure that all the
    combinations work normally, the original ABI values of OST_CLK_PERCPU_TIMER
    and OST_CLK_GLOBAL_TIMER need to be exchanged to ensure that in any
    combinations, the clock can be registered (by calling clk_hw_register())
    from index 0.
    
    Before this patch, OST_CLK_PERCPU_TIMER and OST_CLK_GLOBAL_TIMER are only
    used in two places, one is when using "assigned-clocks" to configure the
    clocks in the DTS file; the other is when registering the clocks in the
    sysost driver. When the values of these two ABIs are exchanged, the ABI
    value used by sysost driver when registering the clock, and the ABI value
    used by DTS when configuring the clock using "assigned-clocks" will also
    change accordingly. Therefore, there is no situation that causes the wrong
    clock to the configured. Therefore, exchanging ABI values will not cause
    errors in the existing codes when registering and configuring the clocks.
    
    Currently, in the mainline, only X1000 and X1830 are using sysost driver,
    and the upcoming X2000 will also use sysost driver. This patch has been
    tested on all three SoCs and all works fine.
    Tested-by: default avatar周正 (Zhou Zheng) <sernia.zhou@foxmail.com>
    Signed-off-by: default avatar周琰杰 (Zhou Yanjie) <zhouyanjie@wanyeetech.com>
    Reviewed-by: default avatarRob Herring <robh@kernel.org>
    Signed-off-by: default avatarDaniel Lezcano <daniel.lezcano@linaro.org>
    Link: https://lore.kernel.org/r/20201026155842.10196-2-zhouyanjie@wanyeetech.com
    0fce2e02
ingenic,sysost.h 446 Bytes