• Finley Xiao's avatar
    clk: Add clk_composite_set_rate_and_parent · 9e52cec0
    Finley Xiao authored
    When changing the clock-rate, currently a new parent is set first and a
    divider adapted thereafter. This may result in the clock-rate overflowing
    its target rate for a short time if the new parent has a higher rate than
    the old parent.
    
    While this often doesn't produce negative effects, it can affect components
    in a voltage-scaling environment, like the GPU on the rk3399 socs, where
    the voltage than simply is to low for the temporarily to high clock rate.
    
    For general clock hirarchies this may need more extensive adaptions to
    the common clock-framework, but at least for composite clocks having
    both parent and rate settings it is easy to create a short-term solution to
    make sure the clock-rate does not overflow the target.
    Signed-off-by: default avatarFinley Xiao <finley.xiao@rock-chips.com>
    Reviewed-by: default avatarHeiko Stuebner <heiko@sntech.de>
    Signed-off-by: default avatarStephen Boyd <sboyd@codeaurora.org>
    9e52cec0
clk-composite.c 8.7 KB