1 // Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies). |
|
2 // All rights reserved. |
|
3 // This component and the accompanying materials are made available |
|
4 // under the terms of the License "Eclipse Public License v1.0" |
|
5 // which accompanies this distribution, and is available |
|
6 // at the URL "http://www.eclipse.org/legal/epl-v10.html". |
|
7 // |
|
8 // Initial Contributors: |
|
9 // Nokia Corporation - initial contribution. |
|
10 // |
|
11 // Contributors: |
|
12 // |
|
13 // Description: This is the header file for the PCI driver test , so far implemented |
|
14 // only on the Naviengine platform |
|
15 |
|
16 #ifndef __TPCI_TEST_H |
|
17 #define __TPCI_TEST_H |
|
18 |
|
19 #ifndef __KERNEL_MODE__ |
|
20 #define __E32TEST_EXTENSION__ |
|
21 #include <e32test.h> |
|
22 #include <e32def_private.h> |
|
23 #endif // __KERNEL_MODE__ |
|
24 |
|
25 _LIT(KPciLdd, "d_pci.ldd"); |
|
26 _LIT(KPciLddFactory, "PCI_test_factory"); |
|
27 _LIT(KPciTest, "PCI Test LDD"); |
|
28 |
|
29 /** |
|
30 Test driver op-codes |
|
31 */ |
|
32 enum TPciTestCmd |
|
33 { |
|
34 EGetTestInfo, |
|
35 EAccessConfigSpace, |
|
36 EAccessMemorySpace, |
|
37 EOpenPciDChunk, |
|
38 EOpenPciPlatHwChunk, |
|
39 EOpenPciMappedChunk, |
|
40 EOpenPciWindowChunk, |
|
41 ERunUnitTests |
|
42 }; |
|
43 |
|
44 /** |
|
45 Identifies a PCI Function (device) on the system |
|
46 */ |
|
47 struct TPciDevice |
|
48 { |
|
49 TPciDevice() |
|
50 :iVendorId(0xFFFFFFFF), iDeviceId(0xFFFFFFFF), iInstance(0) {} |
|
51 |
|
52 TPciDevice(TUint aVendorId, TUint aDeviceId, TInt aInstance=0) |
|
53 :iVendorId(aVendorId), iDeviceId(aDeviceId), iInstance(aInstance) {} |
|
54 |
|
55 TUint iVendorId; |
|
56 TUint iDeviceId; |
|
57 TInt iInstance; ///< Unit to open (there could be multiple devices on system) |
|
58 }; |
|
59 |
|
60 /** |
|
61 Used to send chunk size and recieve |
|
62 PCI address |
|
63 */ |
|
64 struct TPciChunkCreateInfo |
|
65 { |
|
66 TPciChunkCreateInfo() |
|
67 :iSize(0), iPciAddress(NULL) |
|
68 { |
|
69 } |
|
70 |
|
71 TPciChunkCreateInfo(TInt aSize, TUint& aPciAddress, TRequestStatus* aStatus=NULL) |
|
72 :iSize(aSize), iPciAddress(&aPciAddress), iStatus(aStatus) |
|
73 { |
|
74 } |
|
75 TInt iSize; |
|
76 TUint* iPciAddress; |
|
77 TRequestStatus* iStatus; |
|
78 }; |
|
79 |
|
80 /** |
|
81 Information about the PSL required by the |
|
82 user side test |
|
83 */ |
|
84 struct TPciTestInfo |
|
85 { |
|
86 TPciDevice iDevice; ///< Probe for this |
|
87 |
|
88 /** |
|
89 Supplies the necessary information to test Read, Write, and |
|
90 Modify for a word of PCI memory or configuration space |
|
91 */ |
|
92 struct TAddrSpaceTest |
|
93 { |
|
94 TAddrSpaceTest() |
|
95 :iOffset(0), iExpectedValue(0), iReadOnlyMask(0) |
|
96 {} |
|
97 |
|
98 TAddrSpaceTest(TUint aOffset, TUint aExpectedValue, TUint aReadOnlyMask) |
|
99 :iOffset(aOffset), iExpectedValue(aExpectedValue), iReadOnlyMask(aReadOnlyMask) |
|
100 {} |
|
101 |
|
102 /** |
|
103 Returns a specified sub byte, or word from the whole dword |
|
104 */ |
|
105 inline TUint Expected(TInt aBitWidth, TInt aExtraOffset) const |
|
106 { |
|
107 //the right shift required to get field to bit 0 |
|
108 const TInt shift = 8 *((aExtraOffset + iOffset) % 4); |
|
109 |
|
110 const TUint mask = 0xFFFFFFFF >> (32-aBitWidth); |
|
111 return (iExpectedValue >> shift) & mask; |
|
112 } |
|
113 |
|
114 const TUint iOffset; |
|
115 const TUint iExpectedValue; ///< The initial value of word |
|
116 const TUint iReadOnlyMask; ///< Mask of unwritable bits |
|
117 //Future work, memory spaces should state a bar index |
|
118 }; |
|
119 |
|
120 |
|
121 TAddrSpaceTest iCfgSpaceRead; |
|
122 TAddrSpaceTest iCfgSpaceWrite; |
|
123 |
|
124 TUint iMemSpaceIndex; ///< Memory space to select |
|
125 TAddrSpaceTest iMemSpaceRead; |
|
126 TAddrSpaceTest iMemSpaceWrite; |
|
127 |
|
128 TInt iNumberOfBars; ///< Number of simultaneous mappings into PCI space |
|
129 }; |
|
130 |
|
131 class RPci; |
|
132 class TAddrSpace; |
|
133 /** |
|
134 This class encapsulates all the various read/write/and modify commands |
|
135 that can be carried out on a PCI memory space. The command is stored user |
|
136 side, and then executed on kernel side when KRun() is called. |
|
137 */ |
|
138 class TUserPciSpace |
|
139 { |
|
140 public: |
|
141 TUserPciSpace() |
|
142 :iPci(NULL), iOperation(EInvalid), iBitWidth(0), iOffset(0), |
|
143 iWriteValue(0), iClearMask(0), iSetMask(0) |
|
144 {} |
|
145 TUserPciSpace(RPci& aPci); |
|
146 |
|
147 /** |
|
148 Perform the encapsulated read/write/or modify |
|
149 @note Only run on kernel side |
|
150 */ |
|
151 TUint KRun(TAddrSpace& aAddrSpace); |
|
152 |
|
153 /** |
|
154 Clone method is required so that multiple threads may |
|
155 have their own copy of a TUserPciSpace (without knowing |
|
156 its runtime type) |
|
157 */ |
|
158 virtual TUserPciSpace* Clone() const = 0; |
|
159 |
|
160 TUint Read(TInt aBitWidth, TUint aOffset) |
|
161 { |
|
162 iOffset = aOffset; |
|
163 iOperation = ERead; |
|
164 iBitWidth = aBitWidth; |
|
165 |
|
166 return Call(); |
|
167 } |
|
168 |
|
169 void Write(TInt aBitWidth, TUint aOffset, TUint aValue) |
|
170 { |
|
171 iOffset = aOffset; |
|
172 iOperation = EWrite; |
|
173 iBitWidth = aBitWidth; |
|
174 |
|
175 iWriteValue = aValue; |
|
176 Call(); |
|
177 } |
|
178 |
|
179 void Modify(TInt aBitWidth, TUint aOffset, TUint aClearMask, TUint aSetMask) |
|
180 { |
|
181 iOffset = aOffset; |
|
182 iOperation = EModify; |
|
183 iBitWidth = aBitWidth; |
|
184 |
|
185 iClearMask = aClearMask; |
|
186 iSetMask = aSetMask; |
|
187 Call(); |
|
188 } |
|
189 |
|
190 protected: |
|
191 /** |
|
192 Makes a request to iPci and passes a copy of this object to |
|
193 the kernel side. |
|
194 */ |
|
195 virtual TUint Call() =0; |
|
196 |
|
197 enum TOperation {EInvalid, ERead, EWrite, EModify}; |
|
198 |
|
199 /** |
|
200 Pointer to a PCI device handle |
|
201 */ |
|
202 RPci* iPci; |
|
203 |
|
204 TOperation iOperation; //!< Type of access to perform |
|
205 TInt iBitWidth; |
|
206 |
|
207 TUint iOffset; |
|
208 TUint32 iWriteValue; |
|
209 TUint32 iClearMask; |
|
210 TUint32 iSetMask; |
|
211 }; |
|
212 |
|
213 /** |
|
214 Grants access to a PCI device's (identified |
|
215 by aPci) config space from user side |
|
216 */ |
|
217 class TUserConfigSpace : public TUserPciSpace |
|
218 { |
|
219 public: |
|
220 TUserConfigSpace() |
|
221 :TUserPciSpace() |
|
222 {} |
|
223 TUserConfigSpace(RPci& aPci); |
|
224 |
|
225 virtual TUserPciSpace* Clone() const; |
|
226 private: |
|
227 TUint Call(); |
|
228 }; |
|
229 |
|
230 /** |
|
231 Grants access to some region of a PCI |
|
232 device's memory space. A PCI device(or function) |
|
233 may have up to 8 distinct memory spaces |
|
234 */ |
|
235 class TUserMemorySpace : public TUserPciSpace |
|
236 { |
|
237 public: |
|
238 TUserMemorySpace() |
|
239 :TUserPciSpace(), iBarIndex(-1) |
|
240 {} |
|
241 |
|
242 TUserMemorySpace(RPci& aPci, TInt aBarIndex); |
|
243 |
|
244 virtual TUserPciSpace* Clone() const; |
|
245 |
|
246 inline TInt BarIndex() {return iBarIndex;} |
|
247 |
|
248 private: |
|
249 TUint Call(); |
|
250 |
|
251 TInt iBarIndex; ///< Each PCI function may have up to 8 memory spaces |
|
252 }; |
|
253 |
|
254 #endif //__TPCI_TEST_H |
|