|
@@ -48,6 +48,8 @@ static void clock_mux_update(RccClockMuxState *mux, bool bypass_source)
|
|
uint64_t src_freq;
|
|
uint64_t src_freq;
|
|
Clock *current_source = mux->srcs[mux->src];
|
|
Clock *current_source = mux->srcs[mux->src];
|
|
uint32_t freq_multiplier = 0;
|
|
uint32_t freq_multiplier = 0;
|
|
|
|
+ bool clk_changed = false;
|
|
|
|
+
|
|
/*
|
|
/*
|
|
* To avoid rounding errors, we use the clock period instead of the
|
|
* To avoid rounding errors, we use the clock period instead of the
|
|
* frequency.
|
|
* frequency.
|
|
@@ -60,7 +62,10 @@ static void clock_mux_update(RccClockMuxState *mux, bool bypass_source)
|
|
}
|
|
}
|
|
|
|
|
|
clock_set_mul_div(mux->out, freq_multiplier, mux->multiplier);
|
|
clock_set_mul_div(mux->out, freq_multiplier, mux->multiplier);
|
|
- clock_update(mux->out, clock_get(current_source));
|
|
|
|
|
|
+ clk_changed |= clock_set(mux->out, clock_get(current_source));
|
|
|
|
+ if (clk_changed) {
|
|
|
|
+ clock_propagate(mux->out);
|
|
|
|
+ }
|
|
|
|
|
|
src_freq = clock_get_hz(current_source);
|
|
src_freq = clock_get_hz(current_source);
|
|
/* TODO: can we simply detect if the config changed so that we reduce log spam ? */
|
|
/* TODO: can we simply detect if the config changed so that we reduce log spam ? */
|