1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
|
/*
* Copyright 2007 Luc Verhaegen <lverhaegen@novell.com>
* Copyright 2007 Matthias Hopf <mhopf@novell.com>
* Copyright 2007 Egbert Eich <eich@novell.com>
* Copyright 2007 Advanced Micro Devices, Inc.
*
* Permission is hereby granted, free of charge, to any person obtaining a
* copy of this software and associated documentation files (the "Software"),
* to deal in the Software without restriction, including without limitation
* the rights to use, copy, modify, merge, publish, distribute, sublicense,
* and/or sell copies of the Software, and to permit persons to whom the
* Software is furnished to do so, subject to the following conditions:
*
* The above copyright notice and this permission notice shall be included in
* all copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
* THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
* OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
* ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
* OTHER DEALINGS IN THE SOFTWARE.
*/
#ifndef _RHD_PLL_H
#define _RHD_PLL_H
struct rhdPLL {
int scrnIndex;
#define PLL_NAME_PLL1 "PLL 1"
#define PLL_NAME_PLL2 "PLL 2"
char *Name;
/* also used as an index to rhdPtr->PLLs */
#define PLL_ID_PLL1 0
#define PLL_ID_PLL2 1
#define PLL_ID_NONE -1
int Id;
CARD32 CurrentClock;
Bool Active;
/* from defaults or from atom */
CARD32 RefClock;
CARD32 IntMin;
CARD32 IntMax;
CARD32 PixMin;
CARD32 PixMax;
ModeStatus (*Valid) (struct rhdPLL *PLL, CARD32 Clock);
void (*Set) (struct rhdPLL *PLL, CARD16 ReferenceDivider,
CARD16 FeedbackDivider, CARD8 PostDivider);
void (*Power) (struct rhdPLL *PLL, int Power);
void (*Save) (struct rhdPLL *PLL);
void (*Restore) (struct rhdPLL *PLL);
/* For save/restore: Move to a Private */
Bool Stored;
Bool StoreActive;
CARD32 StoreRefDiv;
CARD32 StoreFBDiv;
CARD32 StorePostDiv;
CARD32 StoreControl;
CARD32 StoreSpreadSpectrum;
/* RV620/RV635/RS780 */
Bool StoreDCCGCLKOwner;
CARD32 StoreDCCGCLK;
CARD8 StoreScalerPostDiv;
CARD8 StoreSymPostDiv;
};
void RHDPLLsInit(RHDPtr rhdPtr);
ModeStatus RHDPLLValid(struct rhdPLL *PLL, CARD32 Clock);
void RHDPLLSet(struct rhdPLL *PLL, CARD32 Clock);
void RHDPLLPower(struct rhdPLL *PLL, int Power);
void RHDPLLsPowerAll(RHDPtr rhdPtr, int Power);
void RHDPLLsShutdownInactive(RHDPtr rhdPtr);
void RHDPLLsSave(RHDPtr rhdPtr);
void RHDPLLsRestore(RHDPtr rhdPtr);
void RHDPLLsDestroy(RHDPtr rhdPtr);
#endif /* _RHD_PLL_H */
|