mirror of
https://github.com/openwrt/openwrt.git
synced 2024-12-21 22:47:56 +00:00
20ea6adbf1
Build system: x86_64 Build-tested: bcm2708, bcm2709, bcm2710, bcm2711 Run-tested: bcm2708/RPiB+, bcm2709/RPi3B, bcm2710/RPi3B, bcm2711/RPi4B Signed-off-by: Marty Jones <mj8263788@gmail.com> Signed-off-by: Álvaro Fernández Rojas <noltari@gmail.com>
29 lines
915 B
Diff
29 lines
915 B
Diff
From 3ac4dc10f82935d6cfc759bb34e9686b391f3371 Mon Sep 17 00:00:00 2001
|
|
From: Phil Elwell <phil@raspberrypi.org>
|
|
Date: Mon, 13 Feb 2017 17:20:08 +0000
|
|
Subject: [PATCH] clk-bcm2835: Mark used PLLs and dividers CRITICAL
|
|
|
|
The VPU configures and relies on several PLLs and dividers. Mark all
|
|
enabled dividers and their PLLs as CRITICAL to prevent the kernel from
|
|
switching them off.
|
|
|
|
Signed-off-by: Phil Elwell <phil@raspberrypi.org>
|
|
---
|
|
drivers/clk/bcm/clk-bcm2835.c | 5 +++++
|
|
1 file changed, 5 insertions(+)
|
|
|
|
--- a/drivers/clk/bcm/clk-bcm2835.c
|
|
+++ b/drivers/clk/bcm/clk-bcm2835.c
|
|
@@ -1378,6 +1378,11 @@ bcm2835_register_pll_divider(struct bcm2
|
|
divider->div.hw.init = &init;
|
|
divider->div.table = NULL;
|
|
|
|
+ if (!(cprman_read(cprman, data->cm_reg) & data->hold_mask)) {
|
|
+ init.flags |= CLK_IS_CRITICAL;
|
|
+ divider->div.flags |= CLK_IS_CRITICAL;
|
|
+ }
|
|
+
|
|
divider->cprman = cprman;
|
|
divider->data = divider_data;
|
|
|