Initial commit of OpenSPARC T2 design and verification files.
[OpenSPARC-T2-DV] / verif / diag / assembly / peu / PCIeDrainState.s
CommitLineData
86530b38
AT
1/*
2* ========== Copyright Header Begin ==========================================
3*
4* OpenSPARC T2 Processor File: PCIeDrainState.s
5* Copyright (C) 1995-2007 Sun Microsystems, Inc. All Rights Reserved
6* 4150 Network Circle, Santa Clara, California 95054, U.S.A.
7*
8* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
9*
10* This program is free software; you can redistribute it and/or modify
11* it under the terms of the GNU General Public License as published by
12* the Free Software Foundation; version 2 of the License.
13*
14* This program is distributed in the hope that it will be useful,
15* but WITHOUT ANY WARRANTY; without even the implied warranty of
16* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17* GNU General Public License for more details.
18*
19* You should have received a copy of the GNU General Public License
20* along with this program; if not, write to the Free Software
21* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
22*
23* For the avoidance of doubt, and except that if any non-GPL license
24* choice is available it will apply instead, Sun elects to use only
25* the General Public License version 2 (GPLv2) at this time for any
26* software where a choice of GPL license versions is made
27* available with the language indicating that GPLv2 or any later version
28* may be used, or where a choice of which version of the GPL is applied is
29* otherwise unspecified.
30*
31* Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
32* CA 95054 USA or visit www.sun.com if you need additional information or
33* have any questions.
34*
35*
36* ========== Copyright Header End ============================================
37*/
38#define ENABLE_PCIE_LINK_TRAINING
39#define MAIN_PAGE_HV_ALSO
40
41#define H_HT0_Data_access_error_0x32
42#define SUN_H_HT0_Data_access_error_0x32 \
43 inc %l4; \
44 done;
45
46#include "hboot.s"
47#include "peu_defines.h"
48#include "dmu_peu_regs.h"
49
50#define MEM_WR_ADDR mpeval(N2_PCIE_BASE_ADDR + MEM32_OFFSET_BASE_REG_DATA)
51#define DMA_DATA_ADDR 0x0000000123456000
52#define DMARD_ADDR1 0xfffc000123456000
53#define DMARD_ADDR2 0xfffc000123457000
54#define DMARD_ADDR3 0xfffc000123458000
55#define DMARD_ADDR4 0xfffc000123459000
56
57/*
58Test case code start
59*/
60.text
61.global main
62
63main:
64 ta T_CHANGE_HPRIV
65 nop
66
67 ! make sure the detect.quiet bit is set
68 setx FIRE_PLC_TLU_CTB_TLR_CSR_A_TLU_CTL_ADDR, %g1, %g3
69 ldx [%g3], %g4
70 mov 0x100, %g5
71 orcc %g5, %g4, %g5 ! OR in bit 8 == 1
72 stx %g5, [%g3]
73 ldx [%g3], %g4
74
75/************************************************************
76 Fire off some PIOs and DMA Reads, then bring down the link.
77 ************************************************************/
78Start_PIOs_and_DMARDs:
79DmaRd1: setx MEM_WR_ADDR, %g1, %g2
80! $EV trig_pc_d(1, @VA(.MAIN.DmaRd1)) -> EnablePCIeIgCmd("DMARD",DMARD_ADDR1,DMARD_ADDR1,"64'h40",1)
81DmaRd2: setx 0x3335373992828384, %g1, %l0
82! $EV trig_pc_d(1, @VA(.MAIN.DmaRd2)) -> EnablePCIeIgCmd("DMARD",DMARD_ADDR2,DMARD_ADDR2,"64'h40",1)
83 stw %l0, [%g2 + 8]
84 stx %l0, [%g2 + 16]
85
86 ! here is where we bring down the link, to force an error
87Bring_down_the_link:
88 setx FIRE_PLC_TLU_CTB_TLR_CSR_A_OE_ERR_RW1C_ALIAS_ADDR, %g1, %g2
89 ldx [%g2], %g3
90 stx %g3, [%g2] ! clear any OE status bits
91
92 nop ! $EV trig_pc_d(1, @VA(.MAIN.Bring_down_the_link)) -> EnablePCIeIgCmd("LINKDOWN",0,0,0,1)
93
94 ! now wait for the "link down" primary or secondary status to be set
95 mov 255, %l0
96 setx 0x0000020000000200, %g1, %l1 ! mask for Link Down Primary and Secondary Events
97
98Wait_for_link_down:
99 ldx [%g2], %g3
100 andcc %l1, %g3, %g4
101 bne Check_drain_state
102 nop
103
104 dec %l0
105 brnz %l0, Wait_for_link_down
106 nop
107 b test_failed
108 nop
109
110/************************************************************
111 check that drain.state bit is set in the PEU Status Register
112 ************************************************************/
113Check_drain_state:
114! This user event will force the next PIO to NOT to call expectPCIE().
115! $EV trig_pc_d(1,@VA(.MAIN.Check_drain_state)) -> EnablePCIeIgCmd("PIO_NOEXP",0,0,0,1)
116
117 setx FIRE_PLC_TLU_CTB_TLR_CSR_A_TLU_STS_ADDR, %g1, %g3
118 ldx [%g3], %g4
119 mov 0x100, %g5
120 andcc %g4, %g5, %l0
121 bz test_failed ! branch if drain state is not set
122 nop
123
124 ! issue PIO read request(s) - these should complete with Bus Error
125 mov 0, %l4
126 setx MEM_WR_ADDR, %g1, %g4
127PioBusErr:
128 ldx [%g4], %l3 ! ==> this should get a bus error
129
130 dec %l4 ! <== only one interrupt expected
131 brnz %l4, test_failed
132
133 ! insure that no outstanding DMA read requests are outstanding
134 ! by checking that there are no entries on the Transaction Scoreboard
135 setx FIRE_DLC_TSB_CSR_A_TSB_STS_ADDR, %g1, %g5
136 mov 0, %l0
137 dec %l0
138 mov 0x01, %l1
139 xor %l1, %l0, %l1
140Wait_for_dma_read_clear:
141 ldx [%g5], %l4
142 andcc %l4, %l1, %l2
143 bnz Wait_for_dma_read_clear
144
145 ! clear the link down bit from the Other Error clear reg
146 ldx [%g2], %l1
147 stx %l1, [%g2] ! RW1C
148 ldx [%g2], %l1
149 brnz %l1, test_failed ! branch if link down is not cleared
150 nop
151
152 ! clear the drain bit from the PEU Status reg
153 mov 0x100, %g5
154 stx %g5, [%g3] ! RW1C
155 ldx [%g3], %g4
156 andcc %g4, %g5, %g4
157 bnz test_failed ! branch if drain state is not cleared
158 nop
159
160 ! clear any error bits from from the DLPL Status reg
161 setx FIRE_PLC_TLU_CTB_TLR_CSR_A_EVENT_ERR_STS_CLR_RW1C_ALIAS_ADDR, %g1, %g6
162 ldx [%g6], %l7
163 stx %l7, [%g6] ! RW1C
164 ldx [%g6], %l7
165 brnz %l7, test_failed ! branch if it is not cleared
166 nop
167
168/************************************************************
169 Now redo link training...
170 ************************************************************/
171redo_link_training:
172 nop ! $EV trig_pc_d(1, @VA(.MAIN.redo_link_training)) -> EnablePCIeIgCmd("LINKUP",0,0,0,1)
173
174 ! clear bit 8, to not remain in Detect.Quiet state
175 setx FIRE_PLC_TLU_CTB_TLR_CSR_A_TLU_CTL_ADDR, %g1, %g3
176 mov 0x001, %l4
177 stx %l4, [%g3]
178
179! wait for the "Link Up" status bit to get set in the PEU
180! (this code copied from peu_init.h)
181
182 setx FIRE_PLC_TLU_CTB_TLR_CSR_A_OE_ERR_RW1C_ALIAS_ADDR, %g1, %g3
183 ldx [%g3], %l4
184 stx %l4, [%g3] ! clear any status bits that are set
185 setx FIRE_PLC_TLU_CTB_TLR_CSR_A_CORE_STATUS_ADDR, %g1, %g4
186 mov 255, %l0
187 mov FIRE_PLC_TLU_CTB_TLR_CSR_A_OE_EN_ERR__LUP_P, %l1
188
189LinkTrainingLoop2:
190 ldx [%g3], %l4 ! bit 8 is Link Up primary event
191 ldx [%g4], %l5 ! bits 48:44 are the LTSSM state
192 andcc %l1, %l4, %l4
193 bne LinkTrainingDone2
194 nop
195
196 dec %l0
197 brnz %l0, LinkTrainingLoop2
198 nop
199 b test_failed
200 nop
201
202/********************************************************************
203 Do a couple of PIOs and DMAs to verify that the PCIe link is working.
204 ********************************************************************/
205LinkTrainingDone2: nop
206 ! clear any error bits from from the DLPL Status reg
207 setx FIRE_PLC_TLU_CTB_TLR_CSR_A_EVENT_ERR_STS_CLR_RW1C_ALIAS_ADDR, %g1, %g6
208 ldx [%g6], %l7
209 stx %l7, [%g6] ! RW1C
210 ldx [%g6], %l7
211 brnz %l7, test_failed ! branch if it is not cleared
212 nop
213
214 setx MEM_WR_ADDR, %g1, %g5
215 mov 0, %l4
216DmaRd3: nop
217! $EV trig_pc_d(1, @VA(.MAIN.DmaRd3)) -> EnablePCIeIgCmd("DMARD",DMARD_ADDR3,DMARD_ADDR3,"64'h40",1)
218 stx %g3, [%g5+24] ! 3 PIO Writes
219 stw %g4, [%g5+32]
220 stb %g5, [%g5+40]
221DmaRd4: nop
222! $EV trig_pc_d(1, @VA(.MAIN.DmaRd4)) -> EnablePCIeIgCmd("DMARD",DMARD_ADDR4,DMARD_ADDR4,"64'h40",1)
223 ldx [%g5+24], %l0 ! 3 PIO Reads
224 ldx [%g5+32], %l1
225 ldx [%g5+40], %l2
226
227 ldx [%g3], %l5 ! bit 8 is Link Up primary event
228 ldx [%g4], %l6 ! bits 48:44 are the LTSSM state
229 ldx [%g6], %l7 ! dlpl status
230
231 brnz %l4, test_failed ! no interrupts were expected
232 nop
233
234test_passed:
235 EXIT_GOOD
236
237test_failed:
238 EXIT_BAD
239
240
241SECTION .DATA DATA_VA=DMA_DATA_ADDR
242attr_data {
243 Name = .DATA,
244 hypervisor,
245 compressimage
246}
247.data
248 .xword 0x0101010101010101
249 .xword 0x0101010101010101
250 .xword 0x0101010101010101
251 .xword 0x0101010101010101
252 .xword 0x0101010101010101
253 .xword 0x0101010101010101
254 .xword 0x0101010101010101
255 .xword 0x0101010101010101
256 .align 0x1000
257 .xword 0x0202020202020202
258 .xword 0x0202020202020202
259 .xword 0x0202020202020202
260 .xword 0x0202020202020202
261 .xword 0x0202020202020202
262 .xword 0x0202020202020202
263 .xword 0x0202020202020202
264 .xword 0x0202020202020202
265 .align 0x1000
266 .xword 0x0303030303030303
267 .xword 0x0303030303030303
268 .xword 0x0303030303030303
269 .xword 0x0303030303030303
270 .xword 0x0303030303030303
271 .xword 0x0303030303030303
272 .xword 0x0303030303030303
273 .xword 0x0303030303030303
274 .align 0x1000
275 .xword 0x0404040404040404
276 .xword 0x0404040404040404
277 .xword 0x0404040404040404
278 .xword 0x0404040404040404
279 .xword 0x0404040404040404
280 .xword 0x0404040404040404
281 .xword 0x0404040404040404
282 .xword 0x0404040404040404
283
284/************************************************************************/