Merge pull request #17 in PROCESSOR-SDK/pdk from PRSDK-7323 to master
[processor-sdk/pdk.git] / packages / ti / drv / emac / firmware / icss_dualmac / src / rtu_psi_loopback.h
1 ;
2 ;  TEXAS INSTRUMENTS TEXT FILE LICENSE
3 ;
4 ;   Copyright (c) 2018-2019 Texas Instruments Incorporated
5 ;
6 ;  All rights reserved not granted herein.
7 ;
8 ;  Limited License.
9 ;
10 ;  Texas Instruments Incorporated grants a world-wide, royalty-free, non-exclusive
11 ;  license under copyrights and patents it now or hereafter owns or controls to
12 ;  make, have made, use, import, offer to sell and sell ("Utilize") this software
13 ;  subject to the terms herein.  With respect to the foregoing patent license,
14 ;  such license is granted  solely to the extent that any such patent is necessary
15 ;  to Utilize the software alone.  The patent license shall not apply to any
16 ;  combinations which include this software, other than combinations with devices
17 ;  manufactured by or for TI (“TI Devices”).  No hardware patent is licensed hereunder.
18 ;
19 ;  Redistributions must preserve existing copyright notices and reproduce this license
20 ;  (including the above copyright notice and the disclaimer and (if applicable) source
21 ;  code license limitations below) in the documentation and/or other materials provided
22 ;  with the distribution.
23 ;
24 ;  Redistribution and use in binary form, without modification, are permitted provided
25 ;  that the following conditions are met:
26 ;       No reverse engineering, decompilation, or disassembly of this software is
27 ;   permitted with respect to any software provided in binary form.
28 ;       Any redistribution and use are licensed by TI for use only with TI Devices.
29 ;       Nothing shall obligate TI to provide you with source code for the software
30 ;   licensed and provided to you in object code.
31 ;
32 ;  If software source code is provided to you, modification and redistribution of the
33 ;  source code are permitted provided that the following conditions are met:
34 ;       Any redistribution and use of the source code, including any resulting derivative
35 ;   works, are licensed by TI for use only with TI Devices.
36 ;       Any redistribution and use of any object code compiled from the source code
37 ;   and any resulting derivative works, are licensed by TI for use only with TI Devices.
38 ;
39 ;  Neither the name of Texas Instruments Incorporated nor the names of its suppliers
40 ;  may be used to endorse or promote products derived from this software without
41 ;  specific prior written permission.
42 ;
43 ;  DISCLAIMER.
44 ;
45 ;  THIS SOFTWARE IS PROVIDED BY TI AND TI’S LICENSORS "AS IS" AND ANY EXPRESS OR IMPLIED
46 ;  WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY
47 ;  AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL TI AND TI’S
48 ;  LICENSORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
49 ;  CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE
50 ;  GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
51 ;  CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
52 ;  (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,
53 ;  EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
55 ;-------------------------------------------------
56 ;---file: rtu_psi_loopback.h
57 ;---purpose:  loopback macros for rtu_psi 
58 ;---------------------------------------------------
60 ;#define LOOPBACK_TEST  ;direct attach between pru/rtu loopback
61 ;LOOPBACK_TEST2 .set    1 ;direct attach to host loopback
63 ;if loopback, define one of these 4
64 SL_P0   .set    1 ;this port
65 ;#define SL_P1   ;other port
66 ;#define SL_P01  ;both
67 ;#define SL_DROP ;no port
69 loopback_test_forward .macro
70  .if $isdefed("LOOPBACK_TEST")
72 ;force drop
73  .if $isdefed("SL_DROP")
74         clr     r_pix0.b1.t1 ;f_port0
75         clr     r_pix0.b1.t2 ;f_port1
76  .endif
78 ;force it to stay local
79  .if $isdefed("SL_P0")
80  .if $isdefed("SLICE0")
81         clr     r_pix0.b1.t1 ;f_port0
82  .else
83         clr     r_pix0.b1.t2 ;f_port1
84  .endif
86  .endif
88 ;force it to other slice
89  .if $isdefed("SL_P1")
90  .if $isdefed("SLICE0")
91         clr     r_pix0.b1.t2 ;f_port1
92  .else
93         clr     r_pix0.b1.t1 ;f_port0
94  .endif
95  .endif
97 ;leave it set for both
98  .if $isdefed("SL_P01")
99  .endif
100  .endif
101  .endm
103 loopback_test2_forward .macro
104  .if $isdefed("LOOPBACK_TEST2")
106 ;force drop
107  .if $isdefed("SL_DROP")
108         clr     r_pix0.b1.t1 ;f_port0
109         clr     r_pix0.b1.t2 ;f_port1
110  .endif
112 ;force it to stay local
113  .if $isdefed("SL_P0")
114  .if $isdefed("SLICE0")
115         clr     r_pix0.b1.t1 ;f_port0
116  .else
117         clr     r_pix0.b1.t2 ;f_port1
118  .endif
119  .endif
121 ;force it to other slice
122  .if $isdefed("SL_P1")
123  .if $isdefed("SLICE0")
124         clr     r_pix0.b1.t2 ;f_port1
125  .else
126         clr     r_pix0.b1.t1 ;f_port0
127  .endif
128  .endif
130 ;leave it set for both
131  .if $isdefed("SL_P01")
132  .endif
133  .endif
134  .endm