164b70da0SThomas Gleixner // SPDX-License-Identifier: GPL-2.0-or-later
2f7018c21STomi Valkeinen /*
3f7018c21STomi Valkeinen  * Copyright 1998-2008 VIA Technologies, Inc. All Rights Reserved.
4f7018c21STomi Valkeinen  * Copyright 2001-2008 S3 Graphics, Inc. All Rights Reserved.
5f7018c21STomi Valkeinen  * Copyright 2011 Florian Tobias Schandinat <FlorianSchandinat@gmx.de>
6f7018c21STomi Valkeinen  */
7f7018c21STomi Valkeinen /*
8f7018c21STomi Valkeinen  * clock and PLL management functions
9f7018c21STomi Valkeinen  */
10f7018c21STomi Valkeinen 
11f7018c21STomi Valkeinen #include <linux/kernel.h>
12f7018c21STomi Valkeinen #include <linux/via-core.h>
13598041f3SBartlomiej Zolnierkiewicz 
14f7018c21STomi Valkeinen #include "via_clock.h"
15f7018c21STomi Valkeinen #include "global.h"
16f7018c21STomi Valkeinen #include "debug.h"
17f7018c21STomi Valkeinen 
18dc4d5214SLad, Prabhakar static const char *via_slap = "Please slap VIA Technologies to motivate them "
19f7018c21STomi Valkeinen 	"releasing full documentation for your platform!\n";
20f7018c21STomi Valkeinen 
cle266_encode_pll(struct via_pll_config pll)21f7018c21STomi Valkeinen static inline u32 cle266_encode_pll(struct via_pll_config pll)
22f7018c21STomi Valkeinen {
23f7018c21STomi Valkeinen 	return (pll.multiplier << 8)
24f7018c21STomi Valkeinen 		| (pll.rshift << 6)
25f7018c21STomi Valkeinen 		| pll.divisor;
26f7018c21STomi Valkeinen }
27f7018c21STomi Valkeinen 
k800_encode_pll(struct via_pll_config pll)28f7018c21STomi Valkeinen static inline u32 k800_encode_pll(struct via_pll_config pll)
29f7018c21STomi Valkeinen {
30f7018c21STomi Valkeinen 	return ((pll.divisor - 2) << 16)
31f7018c21STomi Valkeinen 		| (pll.rshift << 10)
32f7018c21STomi Valkeinen 		| (pll.multiplier - 2);
33f7018c21STomi Valkeinen }
34f7018c21STomi Valkeinen 
vx855_encode_pll(struct via_pll_config pll)35f7018c21STomi Valkeinen static inline u32 vx855_encode_pll(struct via_pll_config pll)
36f7018c21STomi Valkeinen {
37f7018c21STomi Valkeinen 	return (pll.divisor << 16)
38f7018c21STomi Valkeinen 		| (pll.rshift << 10)
39f7018c21STomi Valkeinen 		| pll.multiplier;
40f7018c21STomi Valkeinen }
41f7018c21STomi Valkeinen 
cle266_set_primary_pll_encoded(u32 data)42f7018c21STomi Valkeinen static inline void cle266_set_primary_pll_encoded(u32 data)
43f7018c21STomi Valkeinen {
44f7018c21STomi Valkeinen 	via_write_reg_mask(VIASR, 0x40, 0x02, 0x02); /* enable reset */
45f7018c21STomi Valkeinen 	via_write_reg(VIASR, 0x46, data & 0xFF);
46f7018c21STomi Valkeinen 	via_write_reg(VIASR, 0x47, (data >> 8) & 0xFF);
47f7018c21STomi Valkeinen 	via_write_reg_mask(VIASR, 0x40, 0x00, 0x02); /* disable reset */
48f7018c21STomi Valkeinen }
49f7018c21STomi Valkeinen 
k800_set_primary_pll_encoded(u32 data)50f7018c21STomi Valkeinen static inline void k800_set_primary_pll_encoded(u32 data)
51f7018c21STomi Valkeinen {
52f7018c21STomi Valkeinen 	via_write_reg_mask(VIASR, 0x40, 0x02, 0x02); /* enable reset */
53f7018c21STomi Valkeinen 	via_write_reg(VIASR, 0x44, data & 0xFF);
54f7018c21STomi Valkeinen 	via_write_reg(VIASR, 0x45, (data >> 8) & 0xFF);
55f7018c21STomi Valkeinen 	via_write_reg(VIASR, 0x46, (data >> 16) & 0xFF);
56f7018c21STomi Valkeinen 	via_write_reg_mask(VIASR, 0x40, 0x00, 0x02); /* disable reset */
57f7018c21STomi Valkeinen }
58f7018c21STomi Valkeinen 
cle266_set_secondary_pll_encoded(u32 data)59f7018c21STomi Valkeinen static inline void cle266_set_secondary_pll_encoded(u32 data)
60f7018c21STomi Valkeinen {
61f7018c21STomi Valkeinen 	via_write_reg_mask(VIASR, 0x40, 0x04, 0x04); /* enable reset */
62f7018c21STomi Valkeinen 	via_write_reg(VIASR, 0x44, data & 0xFF);
63f7018c21STomi Valkeinen 	via_write_reg(VIASR, 0x45, (data >> 8) & 0xFF);
64f7018c21STomi Valkeinen 	via_write_reg_mask(VIASR, 0x40, 0x00, 0x04); /* disable reset */
65f7018c21STomi Valkeinen }
66f7018c21STomi Valkeinen 
k800_set_secondary_pll_encoded(u32 data)67f7018c21STomi Valkeinen static inline void k800_set_secondary_pll_encoded(u32 data)
68f7018c21STomi Valkeinen {
69f7018c21STomi Valkeinen 	via_write_reg_mask(VIASR, 0x40, 0x04, 0x04); /* enable reset */
70f7018c21STomi Valkeinen 	via_write_reg(VIASR, 0x4A, data & 0xFF);
71f7018c21STomi Valkeinen 	via_write_reg(VIASR, 0x4B, (data >> 8) & 0xFF);
72f7018c21STomi Valkeinen 	via_write_reg(VIASR, 0x4C, (data >> 16) & 0xFF);
73f7018c21STomi Valkeinen 	via_write_reg_mask(VIASR, 0x40, 0x00, 0x04); /* disable reset */
74f7018c21STomi Valkeinen }
75f7018c21STomi Valkeinen 
set_engine_pll_encoded(u32 data)76f7018c21STomi Valkeinen static inline void set_engine_pll_encoded(u32 data)
77f7018c21STomi Valkeinen {
78f7018c21STomi Valkeinen 	via_write_reg_mask(VIASR, 0x40, 0x01, 0x01); /* enable reset */
79f7018c21STomi Valkeinen 	via_write_reg(VIASR, 0x47, data & 0xFF);
80f7018c21STomi Valkeinen 	via_write_reg(VIASR, 0x48, (data >> 8) & 0xFF);
81f7018c21STomi Valkeinen 	via_write_reg(VIASR, 0x49, (data >> 16) & 0xFF);
82f7018c21STomi Valkeinen 	via_write_reg_mask(VIASR, 0x40, 0x00, 0x01); /* disable reset */
83f7018c21STomi Valkeinen }
84f7018c21STomi Valkeinen 
cle266_set_primary_pll(struct via_pll_config config)85f7018c21STomi Valkeinen static void cle266_set_primary_pll(struct via_pll_config config)
86f7018c21STomi Valkeinen {
87f7018c21STomi Valkeinen 	cle266_set_primary_pll_encoded(cle266_encode_pll(config));
88f7018c21STomi Valkeinen }
89f7018c21STomi Valkeinen 
k800_set_primary_pll(struct via_pll_config config)90f7018c21STomi Valkeinen static void k800_set_primary_pll(struct via_pll_config config)
91f7018c21STomi Valkeinen {
92f7018c21STomi Valkeinen 	k800_set_primary_pll_encoded(k800_encode_pll(config));
93f7018c21STomi Valkeinen }
94f7018c21STomi Valkeinen 
vx855_set_primary_pll(struct via_pll_config config)95f7018c21STomi Valkeinen static void vx855_set_primary_pll(struct via_pll_config config)
96f7018c21STomi Valkeinen {
97f7018c21STomi Valkeinen 	k800_set_primary_pll_encoded(vx855_encode_pll(config));
98f7018c21STomi Valkeinen }
99f7018c21STomi Valkeinen 
cle266_set_secondary_pll(struct via_pll_config config)100f7018c21STomi Valkeinen static void cle266_set_secondary_pll(struct via_pll_config config)
101f7018c21STomi Valkeinen {
102f7018c21STomi Valkeinen 	cle266_set_secondary_pll_encoded(cle266_encode_pll(config));
103f7018c21STomi Valkeinen }
104f7018c21STomi Valkeinen 
k800_set_secondary_pll(struct via_pll_config config)105f7018c21STomi Valkeinen static void k800_set_secondary_pll(struct via_pll_config config)
106f7018c21STomi Valkeinen {
107f7018c21STomi Valkeinen 	k800_set_secondary_pll_encoded(k800_encode_pll(config));
108f7018c21STomi Valkeinen }
109f7018c21STomi Valkeinen 
vx855_set_secondary_pll(struct via_pll_config config)110f7018c21STomi Valkeinen static void vx855_set_secondary_pll(struct via_pll_config config)
111f7018c21STomi Valkeinen {
112f7018c21STomi Valkeinen 	k800_set_secondary_pll_encoded(vx855_encode_pll(config));
113f7018c21STomi Valkeinen }
114f7018c21STomi Valkeinen 
k800_set_engine_pll(struct via_pll_config config)115f7018c21STomi Valkeinen static void k800_set_engine_pll(struct via_pll_config config)
116f7018c21STomi Valkeinen {
117f7018c21STomi Valkeinen 	set_engine_pll_encoded(k800_encode_pll(config));
118f7018c21STomi Valkeinen }
119f7018c21STomi Valkeinen 
vx855_set_engine_pll(struct via_pll_config config)120f7018c21STomi Valkeinen static void vx855_set_engine_pll(struct via_pll_config config)
121f7018c21STomi Valkeinen {
122f7018c21STomi Valkeinen 	set_engine_pll_encoded(vx855_encode_pll(config));
123f7018c21STomi Valkeinen }
124f7018c21STomi Valkeinen 
set_primary_pll_state(u8 state)125f7018c21STomi Valkeinen static void set_primary_pll_state(u8 state)
126f7018c21STomi Valkeinen {
127f7018c21STomi Valkeinen 	u8 value;
128f7018c21STomi Valkeinen 
129f7018c21STomi Valkeinen 	switch (state) {
130f7018c21STomi Valkeinen 	case VIA_STATE_ON:
131f7018c21STomi Valkeinen 		value = 0x20;
132f7018c21STomi Valkeinen 		break;
133f7018c21STomi Valkeinen 	case VIA_STATE_OFF:
134f7018c21STomi Valkeinen 		value = 0x00;
135f7018c21STomi Valkeinen 		break;
136f7018c21STomi Valkeinen 	default:
137f7018c21STomi Valkeinen 		return;
138f7018c21STomi Valkeinen 	}
139f7018c21STomi Valkeinen 
140f7018c21STomi Valkeinen 	via_write_reg_mask(VIASR, 0x2D, value, 0x30);
141f7018c21STomi Valkeinen }
142f7018c21STomi Valkeinen 
set_secondary_pll_state(u8 state)143f7018c21STomi Valkeinen static void set_secondary_pll_state(u8 state)
144f7018c21STomi Valkeinen {
145f7018c21STomi Valkeinen 	u8 value;
146f7018c21STomi Valkeinen 
147f7018c21STomi Valkeinen 	switch (state) {
148f7018c21STomi Valkeinen 	case VIA_STATE_ON:
149f7018c21STomi Valkeinen 		value = 0x08;
150f7018c21STomi Valkeinen 		break;
151f7018c21STomi Valkeinen 	case VIA_STATE_OFF:
152f7018c21STomi Valkeinen 		value = 0x00;
153f7018c21STomi Valkeinen 		break;
154f7018c21STomi Valkeinen 	default:
155f7018c21STomi Valkeinen 		return;
156f7018c21STomi Valkeinen 	}
157f7018c21STomi Valkeinen 
158f7018c21STomi Valkeinen 	via_write_reg_mask(VIASR, 0x2D, value, 0x0C);
159f7018c21STomi Valkeinen }
160f7018c21STomi Valkeinen 
set_engine_pll_state(u8 state)161f7018c21STomi Valkeinen static void set_engine_pll_state(u8 state)
162f7018c21STomi Valkeinen {
163f7018c21STomi Valkeinen 	u8 value;
164f7018c21STomi Valkeinen 
165f7018c21STomi Valkeinen 	switch (state) {
166f7018c21STomi Valkeinen 	case VIA_STATE_ON:
167f7018c21STomi Valkeinen 		value = 0x02;
168f7018c21STomi Valkeinen 		break;
169f7018c21STomi Valkeinen 	case VIA_STATE_OFF:
170f7018c21STomi Valkeinen 		value = 0x00;
171f7018c21STomi Valkeinen 		break;
172f7018c21STomi Valkeinen 	default:
173f7018c21STomi Valkeinen 		return;
174f7018c21STomi Valkeinen 	}
175f7018c21STomi Valkeinen 
176f7018c21STomi Valkeinen 	via_write_reg_mask(VIASR, 0x2D, value, 0x03);
177f7018c21STomi Valkeinen }
178f7018c21STomi Valkeinen 
set_primary_clock_state(u8 state)179f7018c21STomi Valkeinen static void set_primary_clock_state(u8 state)
180f7018c21STomi Valkeinen {
181f7018c21STomi Valkeinen 	u8 value;
182f7018c21STomi Valkeinen 
183f7018c21STomi Valkeinen 	switch (state) {
184f7018c21STomi Valkeinen 	case VIA_STATE_ON:
185f7018c21STomi Valkeinen 		value = 0x20;
186f7018c21STomi Valkeinen 		break;
187f7018c21STomi Valkeinen 	case VIA_STATE_OFF:
188f7018c21STomi Valkeinen 		value = 0x00;
189f7018c21STomi Valkeinen 		break;
190f7018c21STomi Valkeinen 	default:
191f7018c21STomi Valkeinen 		return;
192f7018c21STomi Valkeinen 	}
193f7018c21STomi Valkeinen 
194f7018c21STomi Valkeinen 	via_write_reg_mask(VIASR, 0x1B, value, 0x30);
195f7018c21STomi Valkeinen }
196f7018c21STomi Valkeinen 
set_secondary_clock_state(u8 state)197f7018c21STomi Valkeinen static void set_secondary_clock_state(u8 state)
198f7018c21STomi Valkeinen {
199f7018c21STomi Valkeinen 	u8 value;
200f7018c21STomi Valkeinen 
201f7018c21STomi Valkeinen 	switch (state) {
202f7018c21STomi Valkeinen 	case VIA_STATE_ON:
203f7018c21STomi Valkeinen 		value = 0x80;
204f7018c21STomi Valkeinen 		break;
205f7018c21STomi Valkeinen 	case VIA_STATE_OFF:
206f7018c21STomi Valkeinen 		value = 0x00;
207f7018c21STomi Valkeinen 		break;
208f7018c21STomi Valkeinen 	default:
209f7018c21STomi Valkeinen 		return;
210f7018c21STomi Valkeinen 	}
211f7018c21STomi Valkeinen 
212f7018c21STomi Valkeinen 	via_write_reg_mask(VIASR, 0x1B, value, 0xC0);
213f7018c21STomi Valkeinen }
214f7018c21STomi Valkeinen 
set_clock_source_common(enum via_clksrc source,bool use_pll)215f7018c21STomi Valkeinen static inline u8 set_clock_source_common(enum via_clksrc source, bool use_pll)
216f7018c21STomi Valkeinen {
217f7018c21STomi Valkeinen 	u8 data = 0;
218f7018c21STomi Valkeinen 
219f7018c21STomi Valkeinen 	switch (source) {
220f7018c21STomi Valkeinen 	case VIA_CLKSRC_X1:
221f7018c21STomi Valkeinen 		data = 0x00;
222f7018c21STomi Valkeinen 		break;
223f7018c21STomi Valkeinen 	case VIA_CLKSRC_TVX1:
224f7018c21STomi Valkeinen 		data = 0x02;
225f7018c21STomi Valkeinen 		break;
226f7018c21STomi Valkeinen 	case VIA_CLKSRC_TVPLL:
227f7018c21STomi Valkeinen 		data = 0x04; /* 0x06 should be the same */
228f7018c21STomi Valkeinen 		break;
229f7018c21STomi Valkeinen 	case VIA_CLKSRC_DVP1TVCLKR:
230f7018c21STomi Valkeinen 		data = 0x0A;
231f7018c21STomi Valkeinen 		break;
232f7018c21STomi Valkeinen 	case VIA_CLKSRC_CAP0:
233f7018c21STomi Valkeinen 		data = 0xC;
234f7018c21STomi Valkeinen 		break;
235f7018c21STomi Valkeinen 	case VIA_CLKSRC_CAP1:
236f7018c21STomi Valkeinen 		data = 0x0E;
237f7018c21STomi Valkeinen 		break;
238f7018c21STomi Valkeinen 	}
239f7018c21STomi Valkeinen 
240f7018c21STomi Valkeinen 	if (!use_pll)
241f7018c21STomi Valkeinen 		data |= 1;
242f7018c21STomi Valkeinen 
243f7018c21STomi Valkeinen 	return data;
244f7018c21STomi Valkeinen }
245f7018c21STomi Valkeinen 
set_primary_clock_source(enum via_clksrc source,bool use_pll)246f7018c21STomi Valkeinen static void set_primary_clock_source(enum via_clksrc source, bool use_pll)
247f7018c21STomi Valkeinen {
248f7018c21STomi Valkeinen 	u8 data = set_clock_source_common(source, use_pll) << 4;
249f7018c21STomi Valkeinen 	via_write_reg_mask(VIACR, 0x6C, data, 0xF0);
250f7018c21STomi Valkeinen }
251f7018c21STomi Valkeinen 
set_secondary_clock_source(enum via_clksrc source,bool use_pll)252f7018c21STomi Valkeinen static void set_secondary_clock_source(enum via_clksrc source, bool use_pll)
253f7018c21STomi Valkeinen {
254f7018c21STomi Valkeinen 	u8 data = set_clock_source_common(source, use_pll);
255f7018c21STomi Valkeinen 	via_write_reg_mask(VIACR, 0x6C, data, 0x0F);
256f7018c21STomi Valkeinen }
257f7018c21STomi Valkeinen 
dummy_set_clock_state(u8 state)258f7018c21STomi Valkeinen static void dummy_set_clock_state(u8 state)
259f7018c21STomi Valkeinen {
260f7018c21STomi Valkeinen 	printk(KERN_INFO "Using undocumented set clock state.\n%s", via_slap);
261f7018c21STomi Valkeinen }
262f7018c21STomi Valkeinen 
dummy_set_clock_source(enum via_clksrc source,bool use_pll)263f7018c21STomi Valkeinen static void dummy_set_clock_source(enum via_clksrc source, bool use_pll)
264f7018c21STomi Valkeinen {
265f7018c21STomi Valkeinen 	printk(KERN_INFO "Using undocumented set clock source.\n%s", via_slap);
266f7018c21STomi Valkeinen }
267f7018c21STomi Valkeinen 
dummy_set_pll_state(u8 state)268f7018c21STomi Valkeinen static void dummy_set_pll_state(u8 state)
269f7018c21STomi Valkeinen {
270f7018c21STomi Valkeinen 	printk(KERN_INFO "Using undocumented set PLL state.\n%s", via_slap);
271f7018c21STomi Valkeinen }
272f7018c21STomi Valkeinen 
dummy_set_pll(struct via_pll_config config)273f7018c21STomi Valkeinen static void dummy_set_pll(struct via_pll_config config)
274f7018c21STomi Valkeinen {
275f7018c21STomi Valkeinen 	printk(KERN_INFO "Using undocumented set PLL.\n%s", via_slap);
276f7018c21STomi Valkeinen }
277f7018c21STomi Valkeinen 
noop_set_clock_state(u8 state)278f7018c21STomi Valkeinen static void noop_set_clock_state(u8 state)
279f7018c21STomi Valkeinen {
280f7018c21STomi Valkeinen }
281f7018c21STomi Valkeinen 
via_clock_init(struct via_clock * clock,int gfx_chip)282f7018c21STomi Valkeinen void via_clock_init(struct via_clock *clock, int gfx_chip)
283f7018c21STomi Valkeinen {
284f7018c21STomi Valkeinen 	switch (gfx_chip) {
285f7018c21STomi Valkeinen 	case UNICHROME_CLE266:
286f7018c21STomi Valkeinen 	case UNICHROME_K400:
287f7018c21STomi Valkeinen 		clock->set_primary_clock_state = dummy_set_clock_state;
288f7018c21STomi Valkeinen 		clock->set_primary_clock_source = dummy_set_clock_source;
289f7018c21STomi Valkeinen 		clock->set_primary_pll_state = dummy_set_pll_state;
290f7018c21STomi Valkeinen 		clock->set_primary_pll = cle266_set_primary_pll;
291f7018c21STomi Valkeinen 
292f7018c21STomi Valkeinen 		clock->set_secondary_clock_state = dummy_set_clock_state;
293f7018c21STomi Valkeinen 		clock->set_secondary_clock_source = dummy_set_clock_source;
294f7018c21STomi Valkeinen 		clock->set_secondary_pll_state = dummy_set_pll_state;
295f7018c21STomi Valkeinen 		clock->set_secondary_pll = cle266_set_secondary_pll;
296f7018c21STomi Valkeinen 
297f7018c21STomi Valkeinen 		clock->set_engine_pll_state = dummy_set_pll_state;
298f7018c21STomi Valkeinen 		clock->set_engine_pll = dummy_set_pll;
299f7018c21STomi Valkeinen 		break;
300f7018c21STomi Valkeinen 	case UNICHROME_K800:
301f7018c21STomi Valkeinen 	case UNICHROME_PM800:
302f7018c21STomi Valkeinen 	case UNICHROME_CN700:
303f7018c21STomi Valkeinen 	case UNICHROME_CX700:
304f7018c21STomi Valkeinen 	case UNICHROME_CN750:
305f7018c21STomi Valkeinen 	case UNICHROME_K8M890:
306f7018c21STomi Valkeinen 	case UNICHROME_P4M890:
307f7018c21STomi Valkeinen 	case UNICHROME_P4M900:
308f7018c21STomi Valkeinen 	case UNICHROME_VX800:
309f7018c21STomi Valkeinen 		clock->set_primary_clock_state = set_primary_clock_state;
310f7018c21STomi Valkeinen 		clock->set_primary_clock_source = set_primary_clock_source;
311f7018c21STomi Valkeinen 		clock->set_primary_pll_state = set_primary_pll_state;
312f7018c21STomi Valkeinen 		clock->set_primary_pll = k800_set_primary_pll;
313f7018c21STomi Valkeinen 
314f7018c21STomi Valkeinen 		clock->set_secondary_clock_state = set_secondary_clock_state;
315f7018c21STomi Valkeinen 		clock->set_secondary_clock_source = set_secondary_clock_source;
316f7018c21STomi Valkeinen 		clock->set_secondary_pll_state = set_secondary_pll_state;
317f7018c21STomi Valkeinen 		clock->set_secondary_pll = k800_set_secondary_pll;
318f7018c21STomi Valkeinen 
319f7018c21STomi Valkeinen 		clock->set_engine_pll_state = set_engine_pll_state;
320f7018c21STomi Valkeinen 		clock->set_engine_pll = k800_set_engine_pll;
321f7018c21STomi Valkeinen 		break;
322f7018c21STomi Valkeinen 	case UNICHROME_VX855:
323f7018c21STomi Valkeinen 	case UNICHROME_VX900:
324f7018c21STomi Valkeinen 		clock->set_primary_clock_state = set_primary_clock_state;
325f7018c21STomi Valkeinen 		clock->set_primary_clock_source = set_primary_clock_source;
326f7018c21STomi Valkeinen 		clock->set_primary_pll_state = set_primary_pll_state;
327f7018c21STomi Valkeinen 		clock->set_primary_pll = vx855_set_primary_pll;
328f7018c21STomi Valkeinen 
329f7018c21STomi Valkeinen 		clock->set_secondary_clock_state = set_secondary_clock_state;
330f7018c21STomi Valkeinen 		clock->set_secondary_clock_source = set_secondary_clock_source;
331f7018c21STomi Valkeinen 		clock->set_secondary_pll_state = set_secondary_pll_state;
332f7018c21STomi Valkeinen 		clock->set_secondary_pll = vx855_set_secondary_pll;
333f7018c21STomi Valkeinen 
334f7018c21STomi Valkeinen 		clock->set_engine_pll_state = set_engine_pll_state;
335f7018c21STomi Valkeinen 		clock->set_engine_pll = vx855_set_engine_pll;
336f7018c21STomi Valkeinen 		break;
337f7018c21STomi Valkeinen 
338f7018c21STomi Valkeinen 	}
339f7018c21STomi Valkeinen 
340f7018c21STomi Valkeinen 	if (machine_is_olpc()) {
341f7018c21STomi Valkeinen 		/* The OLPC XO-1.5 cannot suspend/resume reliably if the
342f7018c21STomi Valkeinen 		 * IGA1/IGA2 clocks are set as on or off (memory rot
343f7018c21STomi Valkeinen 		 * occasionally happens during suspend under such
344f7018c21STomi Valkeinen 		 * configurations).
345f7018c21STomi Valkeinen 		 *
346f7018c21STomi Valkeinen 		 * The only known stable scenario is to leave this bits as-is,
347f7018c21STomi Valkeinen 		 * which in their default states are documented to enable the
348f7018c21STomi Valkeinen 		 * clock only when it is needed.
349f7018c21STomi Valkeinen 		 */
350f7018c21STomi Valkeinen 		clock->set_primary_clock_state = noop_set_clock_state;
351f7018c21STomi Valkeinen 		clock->set_secondary_clock_state = noop_set_clock_state;
352f7018c21STomi Valkeinen 	}
353f7018c21STomi Valkeinen }
354