summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJason Reeder2017-12-20 17:04:02 -0600
committerJason Reeder2017-12-20 17:04:02 -0600
commit30b3981dbcbde2759a3da6fb624a867868eefd2d (patch)
treebe85b955821cca121f6fa1c73cd1fee7b0ff1402
downloadtida01555-30b3981dbcbde2759a3da6fb624a867868eefd2d.tar.gz
tida01555-30b3981dbcbde2759a3da6fb624a867868eefd2d.tar.xz
tida01555-30b3981dbcbde2759a3da6fb624a867868eefd2d.zip
Initial commit
Signed-off-by: Jason Reeder <jreeder@ti.com>
-rw-r--r--ARM_User_Space_App/Makefile66
-rw-r--r--ARM_User_Space_App/arm_user_space_app.c306
-rwxr-xr-xARM_User_Space_App/gen/ARM_User_Space_App.outbin0 -> 19340 bytes
-rw-r--r--Makefile14
-rw-r--r--PRUMulti-channelADCInterfaceReferen_manifest.html300
-rw-r--r--PRU_ADS8688_Controller/AM335x_PRU.cmd121
-rw-r--r--PRU_ADS8688_Controller/Makefile125
-rw-r--r--PRU_ADS8688_Controller/PRU_ADS8688_Controller.c391
-rw-r--r--PRU_ADS8688_Controller/gen/PRU_ADS8688_Controller.asm3844
-rw-r--r--PRU_ADS8688_Controller/gen/PRU_ADS8688_Controller.map293
-rw-r--r--PRU_ADS8688_Controller/gen/PRU_ADS8688_Controller.objectbin0 -> 35948 bytes
-rw-r--r--PRU_ADS8688_Controller/gen/PRU_ADS8688_Controller.outbin0 -> 47692 bytes
-rw-r--r--PRU_ADS8688_Controller/gen/PRU_ADS8688_Controller.pp8
-rw-r--r--PRU_ADS8688_Controller/resource_table_empty.h72
-rw-r--r--PRU_ADS8688_Interface/.PRU_ADS8688_Interface.asm.swpbin0 -> 28672 bytes
-rw-r--r--PRU_ADS8688_Interface/AM335x_PRU.cmd117
-rw-r--r--PRU_ADS8688_Interface/Makefile125
-rw-r--r--PRU_ADS8688_Interface/PRU_ADS8688_Interface.asm342
-rw-r--r--PRU_ADS8688_Interface/gen/PRU_ADS8688_Interface.map248
-rw-r--r--PRU_ADS8688_Interface/gen/PRU_ADS8688_Interface.objectbin0 -> 21532 bytes
-rw-r--r--PRU_ADS8688_Interface/gen/PRU_ADS8688_Interface.outbin0 -> 39764 bytes
-rwxr-xr-xdts/am335x-boneblack-pruadc.dts78
-rwxr-xr-xrun.sh13
23 files changed, 6463 insertions, 0 deletions
diff --git a/ARM_User_Space_App/Makefile b/ARM_User_Space_App/Makefile
new file mode 100644
index 0000000..1ad4b2e
--- /dev/null
+++ b/ARM_User_Space_App/Makefile
@@ -0,0 +1,66 @@
1# ARM_CCT environment variable must point to the ARM cross-compile toolchain. E.g.:
2#(Desktop Linux) export ARM_CCT=$(HOME)/ti-processor-sdk-linux-rt-amxxx-evm-ww.xx.yy.zz/
3#linux-devkit/sysroots/x86_64-arago-linux/usr/bin
4
5ifndef ARM_CCT
6define ERROR_BODY
7
8*******************************************************************************
9ARM_CCT environment variable is not set. Examples given:
10(Desktop Linux) export ARM_CCT=$(HOME)/ti-processor-sdk-linux-rt-amxxx-evm-ww.xx.yy.zz/
11linux-devkit/sysroots/x86_64-arago-linux/usr/bin
12*******************************************************************************
13
14endef
15$(error $(ERROR_BODY))
16endif
17
18MKFILE_PATH := $(abspath $(lastword $(MAKEFILE_LIST)))
19CURRENT_DIR := $(notdir $(patsubst %/,%,$(dir $(MKFILE_PATH))))
20PROJ_NAME=$(CURRENT_DIR)
21GEN_DIR=gen
22
23#Math library for square root function
24CFLAGS=-lm
25
26TARGET=$(GEN_DIR)/$(PROJ_NAME).out
27SOURCES=$(wildcard *.c)
28
29all: printStart $(TARGET) printEnd
30
31printStart:
32 @echo ''
33 @echo '************************************************************'
34 @echo 'Building project: $(PROJ_NAME)'
35
36printEnd:
37 @echo ''
38 @echo 'Output files can be found in the "$(GEN_DIR)" directory'
39 @echo ''
40 @echo 'Finished building project: $(PROJ_NAME)'
41 @echo '************************************************************'
42 @echo ''
43
44# Invokes the ARM x86 Cross Compiler to make the .out file
45$(TARGET):
46 @mkdir -p $(GEN_DIR)
47 @echo ''
48 @echo 'Building target: $@'
49 @echo 'Invoking: ARM x86 Cross Compiler'
50 $(ARM_CCT)/arm-linux-gnueabihf-gcc -Wall $(SOURCES) $(CFLAGS) -o $(TARGET) -lncurses -lpthread
51 @echo 'Finished building target: $@'
52
53.PHONY: all clean
54
55# Remove the $(GEN_DIR) directory
56clean:
57 @echo ''
58 @echo '************************************************************'
59 @echo 'Cleaning project: $(PROJ_NAME)'
60 @echo ''
61 @echo 'Removing files in the "$(GEN_DIR)" directory'
62 @rm -rf $(GEN_DIR)
63 @echo ''
64 @echo 'Finished cleaning project: $(PROJ_NAME)'
65 @echo '************************************************************'
66 @echo ''
diff --git a/ARM_User_Space_App/arm_user_space_app.c b/ARM_User_Space_App/arm_user_space_app.c
new file mode 100644
index 0000000..68a87db
--- /dev/null
+++ b/ARM_User_Space_App/arm_user_space_app.c
@@ -0,0 +1,306 @@
1/*
2 * Copyright (C) 2017 Texas Instruments Incorporated - http://www.ti.com/
3 *
4 *
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions
7 * are met:
8 *
9 * * Redistributions of source code must retain the above copyright
10 * notice, this list of conditions and the following disclaimer.
11 *
12 * * Redistributions in binary form must reproduce the above copyright
13 * notice, this list of conditions and the following disclaimer in the
14 * documentation and/or other materials provided with the
15 * distribution.
16 *
17 * * Neither the name of Texas Instruments Incorporated nor the names of
18 * its contributors may be used to endorse or promote products derived
19 * from this software without specific prior written permission.
20 *
21 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
22 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
23 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
24 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
25 * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
26 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
27 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
28 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
29 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
30 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
31 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
32 */
33
34#include <sys/types.h>
35#include <unistd.h>
36#include <sys/stat.h>
37#include <sys/mman.h>
38#include <fcntl.h>
39#include <stdio.h>
40#include <stdlib.h>
41#include <unistd.h>
42#include <stdint.h>
43#include <math.h>
44#include <time.h>
45#include <string.h>
46#include <sched.h>
47#include <pthread.h>
48#include <limits.h>
49#include <ncurses.h>
50
51#define PING_ADDR 0x9FFC0000
52#define PONG_ADDR 0x9FFE0000
53#define PING 0
54#define PONG 1
55#define DATA_READY 0x0000FFFF
56#define IN_PROGRESS 0x00000000
57#define NUM_CHANNELS 48
58#define NUM_DEVICES 6
59#define NUM_SAMPLES_PER_CYCLE 640
60#define MAX_CSV_SAMPLES 65536
61
62volatile float min[NUM_CHANNELS];
63volatile float max[NUM_CHANNELS];
64volatile float result[NUM_CHANNELS];
65volatile uint16_t compensation, delay;
66volatile int16_t csv_samples[MAX_CSV_SAMPLES];
67volatile uint16_t csv_channel = 0;
68volatile uint32_t csv_sample_num = 0;
69volatile uint32_t csv_counter = 0;
70
71struct buffer {
72 uint32_t flags;
73 uint32_t comp_delay;
74 uint32_t samples[NUM_CHANNELS*NUM_SAMPLES_PER_CYCLE];
75};
76
77void *capture_func(void *data)
78{
79 int i, j;
80 struct buffer *ping_ptr, *pong_ptr;
81 uint32_t samples[NUM_CHANNELS*NUM_SAMPLES_PER_CYCLE];
82 uint64_t cur_square_sum = 0;
83 int16_t cur_min = INT16_MAX;
84 int16_t cur_max = INT16_MIN;
85 int16_t signed_val;
86 struct timespec sleep;
87 uint8_t curr_buff = PING;
88
89 /* Open the /dev/mem device to access the shared buffers */
90 int fd = open("/dev/mem",O_RDWR|O_SYNC);
91 if(fd < 0)
92 {
93 printf("Can't open /dev/mem\n");
94 return NULL;
95 }
96 /* mmap 128kB ping and pong buffers */
97 ping_ptr = (struct buffer *) mmap(0, getpagesize()*32, PROT_READ|PROT_WRITE, MAP_SHARED, fd, PING_ADDR);
98 pong_ptr = (struct buffer *) mmap(0, getpagesize()*32, PROT_READ|PROT_WRITE, MAP_SHARED, fd, PONG_ADDR);
99 if(ping_ptr == NULL || pong_ptr == NULL)
100 {
101 printf("Can't mmap\n");
102 return NULL;
103 }
104
105 /* put sine wave in memory */
106 /*
107 for(i = 0; i < NUM_SAMPLES_PER_CYCLE; i++) {
108 for(j = 0; j < NUM_CHANNELS; j++) {
109 ping_ptr->samples[i*NUM_CHANNELS+j] = sine_wave[i];
110 pong_ptr->samples[i*NUM_CHANNELS+j] = sine_wave[i];
111 }
112 }
113 */
114
115 /* Configure the sleep delay to 250us */
116 sleep.tv_sec = 0;
117 sleep.tv_nsec = 250000L;
118
119 /* Wait until PING buffer is in progress before beginning */
120 while (ping_ptr->flags != IN_PROGRESS)
121 nanosleep(&sleep, NULL);
122
123 while(1) {
124 /* Wait for the buffers to be ready and then memcpy the sample
125 * data to local memory. If the buffer is not ready yet, go to
126 * sleep for 250us before checking again. This thread is
127 * running at the highest priority so it needs to sleep when
128 * not in use or it will starve all other threads.
129 */
130 if (curr_buff == PING) {
131 while (ping_ptr->flags != DATA_READY)
132 nanosleep(&sleep, NULL);
133 compensation = ping_ptr->comp_delay >> 16;
134 delay = ping_ptr->comp_delay & 0xFFFF;
135 memcpy(samples, ping_ptr->samples, sizeof(samples));
136 curr_buff = PONG;
137 }
138 else {
139 while (pong_ptr->flags != DATA_READY)
140 nanosleep(&sleep, NULL);
141 compensation = pong_ptr->comp_delay >> 16;
142 delay = pong_ptr->comp_delay & 0xFFFF;
143 memcpy(samples, pong_ptr->samples, sizeof(samples));
144 curr_buff = PING;
145 }
146
147 /* Iterate through a full cycle for each channel */
148 for (j = 0; j < NUM_CHANNELS; j++) {
149 for(i = 0; i < NUM_SAMPLES_PER_CYCLE; i++) {
150 /* Convert the ADC code to it's signed equivalent */
151 signed_val = (uint16_t)samples[i*NUM_CHANNELS+j] - 0x8000;
152 if (j == csv_channel && csv_counter < csv_sample_num)
153 csv_samples[csv_counter++] = signed_val;
154 /* Check for min and max values throughout the cycle */
155 if(signed_val < cur_min)
156 cur_min = signed_val;
157 if(signed_val > cur_max)
158 cur_max = signed_val;
159 /* Accumulate the squares to be used in the RMS calc */
160 cur_square_sum += signed_val * signed_val;
161 }
162 /* Convert the min and max from ADC codes to voltages and store them */
163 min[j] = (float)cur_min * 0.0003125;
164 max[j] = (float)cur_max * 0.0003125;
165 /* Complete the Root Mean Square (RMS) calculation for this channel and store it */
166 result[j] = (sqrt(cur_square_sum / 640.0)) * 0.0003125;
167 /* Reset the current variables to defaults for the next channel iteration */
168 cur_min = INT16_MAX;
169 cur_max = INT16_MIN;
170 cur_square_sum = 0;
171 }
172 }
173
174 return NULL;
175}
176
177void *print_func(void *data)
178{
179 int i;
180 float frequency;
181
182 /* Initialize the screen */
183 initscr();
184 /* Set the timeout to 250ms for waiting for user input */
185 timeout(250);
186 curs_set(0);
187
188 /* Print each channel's min, max, and RMS values to the screen */
189 while (1) {
190 for(i = 0; i < NUM_CHANNELS/2; i++) {
191 mvprintw(i, 0, "Ch%02d Vpp:[%.3f,%.3f]", i, min[i], max[i]);
192 mvprintw(i, 28, "RMS:%.3f", result[i]);
193 mvprintw(i, 39, "| Ch%02d Vpp:[%.3f,%.3f]", i+NUM_CHANNELS/2, min[i+NUM_CHANNELS/2], max[i+NUM_CHANNELS/2]);
194 mvprintw(i, 69, "RMS:%.3f", result[i+NUM_CHANNELS/2]);
195 }
196
197 frequency = (1.0 / ((delay * NUM_CHANNELS / NUM_DEVICES + compensation) * 0.000000005)) / NUM_SAMPLES_PER_CYCLE;
198
199 mvprintw(NUM_CHANNELS/2 + 1, 0, "Delay:%d, Compensation:%d", delay, compensation);
200 mvprintw(NUM_CHANNELS/2 + 2, 0, "Estimated Frequency:%.3f Hz", frequency);
201 mvprintw(NUM_CHANNELS/2 + 4, 0, "Press any key to exit");
202 /* Refresh the screen with the latest data */
203 refresh();
204 /* If a character is received then exit the while(1) loop */
205 if(getch() != -1)
206 break;
207 }
208
209 /* Close the window */
210 endwin();
211
212 return NULL;
213}
214
215int main(int argc, char* argv[])
216{
217 struct sched_param param;
218 pthread_attr_t attr;
219 pthread_t capture_thread, print_thread;
220 int ret;
221 uint32_t i;
222 FILE *fp;
223
224 /* Check for command line arguments requesting to create a CSV file
225 * argv[1] - CSV file name
226 * argv[2] - Channel number to store results from
227 * argv[3] - Number of samples to store (max of 32000)
228 * example given:
229 * ./ARM_User_Space_App.out chan3_2048samples.csv 3 2048
230 */
231 if(argc == 4) {
232 csv_sample_num = atoi(argv[3]);
233 if (csv_sample_num > MAX_CSV_SAMPLES)
234 csv_sample_num = MAX_CSV_SAMPLES;
235 csv_channel = atoi(argv[2]);
236 if (csv_channel > NUM_CHANNELS)
237 csv_channel = 0;
238 }
239
240
241 /* Lock memory */
242 if(mlockall(MCL_CURRENT|MCL_FUTURE) == -1) {
243 printf("mlockall failed: %m\n");
244 exit(-2);
245 }
246 /* Initialize pthread attributes (default values) */
247 ret = pthread_attr_init(&attr);
248 if (ret) {
249 printf("init pthread attributes failed\n");
250 goto out;
251 }
252 /* Set the stack size, need at least 0x1E000 for the samples array */
253 ret = pthread_attr_setstacksize(&attr, PTHREAD_STACK_MIN + 0x20000);
254 if (ret) {
255 printf("pthread setstacksize failed\n");
256 goto out;
257 }
258 /* Set scheduler policy and priority of pthread */
259 ret = pthread_attr_setschedpolicy(&attr, SCHED_FIFO);
260 if (ret) {
261 printf("pthread setschedpolicy failed\n");
262 goto out;
263 }
264 param.sched_priority = 99;
265 ret = pthread_attr_setschedparam(&attr, &param);
266 if (ret) {
267 printf("pthread setschedparam failed\n");
268 goto out;
269 }
270 /* Use scheduling parameters of attr */
271 ret = pthread_attr_setinheritsched(&attr, PTHREAD_EXPLICIT_SCHED);
272 if (ret) {
273 printf("pthread setinheritsched failed\n");
274 goto out;
275 }
276 /* Create a pthread with specified attributes (priority 99) */
277 ret = pthread_create(&capture_thread, &attr, capture_func, NULL);
278 if (ret) {
279 printf("create capture_thread failed\n");
280 goto out;
281 }
282 /* Create a pthread with lower priority to print the results */
283 ret = pthread_create(&print_thread, NULL, print_func, NULL);
284 if (ret) {
285 printf("create capture_thread failed\n");
286 goto out;
287 }
288 /* Join the print thread and wait until it is done (key press) */
289 ret = pthread_join(print_thread, NULL);
290 if (ret)
291 printf("join capture_thread failed: %m\n");
292
293 /* Write the samples to a csv file if requested */
294 if(argc == 4) {
295 fp = fopen(argv[1], "w+");
296 for (i = 0; i < csv_sample_num; i++) {
297 fprintf(fp, "%d\n", csv_samples[i]);
298 }
299 fclose(fp);
300
301 printf("\n%s file created with %d sample(s) from channel %d\n\n", argv[1], csv_sample_num, csv_channel);
302 }
303
304out:
305 return ret;
306}
diff --git a/ARM_User_Space_App/gen/ARM_User_Space_App.out b/ARM_User_Space_App/gen/ARM_User_Space_App.out
new file mode 100755
index 0000000..6540f44
--- /dev/null
+++ b/ARM_User_Space_App/gen/ARM_User_Space_App.out
Binary files differ
diff --git a/Makefile b/Makefile
new file mode 100644
index 0000000..ef00f66
--- /dev/null
+++ b/Makefile
@@ -0,0 +1,14 @@
1SUBDIRS=PRU_ADS8688_Controller PRU_ADS8688_Interface ARM_User_Space_App
2
3all: $(SUBDIRS)
4
5$(SUBDIRS):
6 @$(MAKE) -C $@
7
8clean:
9 @for d in $(SUBDIRS); do (cd $$d; $(MAKE) clean ); done
10
11.PHONY: all clean $(SUBDIRS)
12
13
14
diff --git a/PRUMulti-channelADCInterfaceReferen_manifest.html b/PRUMulti-channelADCInterfaceReferen_manifest.html
new file mode 100644
index 0000000..5281ac4
--- /dev/null
+++ b/PRUMulti-channelADCInterfaceReferen_manifest.html
@@ -0,0 +1,300 @@
1<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
2<html xmlns="http://www.w3.org/1999/xhtml">
3<head>
4 <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
5 <meta http-equiv="Content-Style-Type" content="text/css" />
6 <meta name="generator" content="pandoc" />
7 <title>Manifest File</title>
8 <style type="text/css">code{white-space: pre;}</style>
9 <link href="data:text/css;charset=utf-8,%0A%0A%0A%0A%40font%2Dface%20%7B%0Afont%2Dfamily%3A%20%27Open%20Sans%27%3B%0Afont%2Dstyle%3A%20normal%3B%0Afont%2Dweight%3A%20400%3B%0Asrc%3A%20url%28%27data%3Afont%2Fwoff2%3Bbase64%2Cd09GMgABAAAAADzUABIAAAAAhjgAADxwAAEZmgAAAAAAAAAAAAAAAAAAAAAAAAAAGhYbDBx0BmAAgUwIgSIJjzQREAqBpESBjUIBNgIkA4ZsE70QC4M8AAQgBYIyB4QoDIIJG8J3CQg7WxX5j0PthLRbJVvedpUoKlTzFUWwcUCG52fZ%2F%2F%2F%2F%2F3lJxxAlWAMiaNd12%2F9PqJmJKW5iyEExieloQ9KxVuZAQ07T1g7vfgVloomBA%2FUEiuEMCGVsPBsLc9rD3dPKhTisOejgNULCLyjxoeYlBGuZsjRKads6GS6b8QRDIttvKSa68bAbLrwP31TZsuGVyrv7lPcTS4bG9tKpUh76wlIon84X%2FsDUs5lHxlTP%2Fif%2BNs2eosU%2Fnf%2FBfw%2FriGqqb%2BffLOvzVA9JiiYPkV3xr7qrZ%2Fbum4pAxULkIPkZgBBQJu%2F2AG2zs1GxcgYq2FMQpj1RETESsbAKmzJyopiJzNnDKkTX5pwurDm2%2Fl%2BkLvK%2F%2Bx%2FAP6A2ZgrZRvjS1KSQBer9XuGyk3Iw3zfX%2B1eWZFmG4CQDj7CYnr8CXBV4ueyfuup7tsiSJbYtuxH%2FjmfaSz7qPupZoCCZ%2BkF0QXRpQIvhcQTov6omea3KKY0pFP4oK73IomFDl%2BISgLSDg2T3m9LqWHnZhsdUX6Zbs2x9S8bARE7Ay%2By7Qf%2FnllVniRftubDauc4suapKNQPzE8citiadRhUeQAB2Or6gcE01zLrqvv3azJyYfdvFLJRBRNN%2BrORtiKb4r90jEQolkS9CXdeapUUtovJYdjvKac7KcpzMaA1l%2FuGrT4aVVrGvMVAuLrBgPpJTtAv0AsQv4mpVYhTdrISsR3HVOUDRuJh4nIdPy752XK3pgwsJHaOiCfRBCMYnBZa2NQIs0MJBCLKQcLAUFiLHsSb1NBwDuVM%2B%2BS0pbMpCb4wnNT80UzMTE9QxNEqUXUj%2BXtWyBRikfCGFLhWNnelMh67A%2Bx%2BBHyAogRS0C1I6L0lJt9RGUJGUzgZAjQekU04ENxHSBYHaRMdLMVd257vKTeW69pbnoi9NTzZ4puUyQp2QCOOWBcHlBVHZINQPsqpeQjArJqPxaQKweFrTR1P%2Fk%2BXq%2B%2FE66DKZ2KGI2ZjJZNOIfxEploB4nMfYbCEuPnLbpwkSihwCCsbniQTAguiPVErkU4mUNL%2BUgcJFiymBc06kZQAgwjK%2Bx5hwzplJMQDIJhWEDSTOGJKlWpoIMEUadBm6RwiOj8PFkZ74BMmB3NPHvuQZdmtwhPKxaCIC1O5pSECsQvXqWxLjy0SwLDAMtWW45JcEf9qVQU4AAOvKcpvthncBrrn3f6P2TFH5pL6ErAoIPAgbyH0bD2BVQtHJQvXeU9iytiHI6oIFw3FX7KYd%2Fws48OV6eVger6oIUYdoQXQh%2BhBbCAZCg0ws5P%2F%2F30%2BhOw99btm1DAYcrQBRhWi8jM0FaH419ud9hVS%2F0ut62vSv6Q%2FT11%2BiySYajVNbtUV%2Fb5%2FexPSeyXTDklT41IpZiv4R2m3Dfcp9KWoG9CMAOmZLgoOTwv9t%2FXjG7O9no%2FSNV51dlkUn2AXcpNQTLI0adKlSGjJgNWg3YlhoCCEQH%2BDv5%2Bvj7eXp4Y5zw7piXJyd0I6nHeztbG2srSxPIeDmZidNDQ30YVA9XR1tprpw1uhWsieLKhwIhGlDCFAphITMFTNSlJXCvFS7BnGYV1RMYWUSk86rwpJKpWQBZbBSCbm2Z1laCiZ6RfcBbuU87snz7Dx7R5L4WZIjvKrod%2BrtYCMx9O8mwhLRGcX3ibFESNJCqbD2cGBXU%2FncuJtPLlOhOxfmmcPUG5mPZuIouu1w9CKPimlUnXUEk4VEgpJLUlkHBxWtYuH7JsyXkXXj7AS4sDsaU8uIxeWw2Z6h9iA3uWnrBnnWSoOFDnWyWxohn666Da3a54egEGCM4tGe%2Fq6VLupikmKFCY7LkmodtkTc48IxKTyS9g%2BEon9%2FU0Gfmor%2F91YEWgYeaf9eEUU9e7fPaySLVll%2FZPSApEe2n04%2F31YHDfx09bMcma9lC2vvLpFPB%2FysabdbsZqgVGlqkCjKQZaCw9RL5J8Wfq78fbpRRBgkAAxoN%2B77EOTWB8wGH4agD%2FWBsmqI94A%2BFBiQym357qjcbDkjVNVS8mFxqGkbhEW5Q0rbxes%2B9DWsbK1TFiIP2X%2Fhky3m5JlDhoxIiRi5oUREAgQUJuwkwnKXsPYD82bP2nAFm5nLbZFniAVCw4pU%2Bqg9HOyqPE6GeWwEVpAL1OD4ReXMWGnlZg8RK1l6TAzjjnw3zNBtlCkyLGpSVg1rGp%2BrMhHlAiC6HaUwo4ZUViqrXkR1biihit4A5P8VJcWHBXYcMDHm%2BVEtaISkshedHnqp6MBKe1ILH2yAviHdNTbXS94mvwv%2FXjJusom6TmqUVBr6dCPYTMTqM4WFYrEPaeGMiEBczEg9JsYNFvESiiy%2BaBSdP6UREzNPxAMb5yCrnRydl5oLRghNYHpYqm5Mgj6bGcLtSEgUSpzEqZvZQFUoCd%2F491qYH9vIUigQkxnUr0rZ1DjE2gzGWOAk0qO4y%2BJrS01dMjSQ4BtaLQQN1jAHBNY3Z6by%2BicjUAwNoFPEHxGQX4a1QACbwPpnIaq0UdSymS9t3E1qlrFMKJ%2FBEWWA%2FWb4dE4kRd6bmY5kiLfD64zt8%2BWeHB%2BcZTDDLXesW9PnCSGUaC%2FE0%2Fg8RZElPKlHYd4R7O5c%2FqbimL%2BpNfRGnjFI1Yl%2BT0jLaWSclz9Gb1iMoXN8hCL0wWchLqS69sXHGrHBDM6USOEEjrLDEcJdS7xNCJA%2Fn3BSiMbMyQ2EY0xIu4G4X%2BP7uAO45rs8N8kzl2cvL4xlqOUwSd5HLl85EA942MMMthyFVM0aP%2BLaJViU0jrK0n3ILadidX5Df0hDFXwCIWJ0r4T58QM6uleTuOxYSd5zM7DK9LQcKM%2BQeJzGwd2LDM6BRtSKpoM5txsh5UZ5vkuBS74pKpYGVnlVvQ5o%2BQbwNE%2B9qX3yYO35Jmz%2Bn5HIpUfJ2vyfcGnkNDFvIWM3%2Bl0SAJ48tws8taOvAL%2BPojsDoRsZILghY5rGbIwyhURLrWp55YC9KERyteUrrJvBxgK83RyXPcVHMCoV1zkeyAymKLA4qBuCE17rUFLPeFWiZKX9NFIPkWfjuZHm4voKGHuz5gt7xXpTvCZPhpARHTMjea8%2FwnPKhOSEpZhhrY3kuKgm88Euz4ZRsxiLqrUUXDCM2Sh%2FKjJmOI83BylGUktaOGk4F61UfJ35fCC5yHDGsBjkhYxBFaw8KhGxVNLhVakk7yq4dSzlWFZijCc1zkeTkYwYnyJoLlobOWOUa2uxks1KRCtDLiVjk7zikMsiyxS%2FO%2BRxwCZCqTBKXOZTycx5EuMsI%2Fy25wHe4lzgXyOx2rgm%2FVNMKc6TRgCgiHfgRiM%2FFYcSvBA7nUJ2UqhAvL6znIECFAsKRIF0WBJkLQgKX9nAKe6KytVSyscM%2FYoBzpAcZ0LQDwAHwYTaxCTnK7Eg7dJpjEys%2BmX%2BymSpJybTABwIUK3FISB%2BvfEPpaYfX6dhYCS%2FArvbXpMxAOujddHcKCy9oAuosBwO%2Fd66aodBZ6D7bZbgOVjxhKzQcG9DNEl3hATNHPFDklxcc4NylfRkG88t2VfSoUwj1nL97IcKprRrU0xLaftUQLvKqBE0YCLFJ3XjQTVlx5kKoTYQIvTnMDpYqQumFfIquUaT3%2BTlFnBAUcDaS6Ykgm4D6mHZ3T5LS7ASqCHVNII69RkiqGYX8m%2BKFuRyLBfKpASn%2BovFuh8NjOEFNgt3km%2FK1AYKDnTQbKHVKfxpUg74CJVZ%2FQzVmPSrAGHPRrKIU8EQJywFPBHiZyoRp9ZiqatfCUYZAy10RUjDNhY0ApFk%2FRCyRru7v1GbH2EdpTUYrJNxdP9Ib3%2BKy%2BLdDlcvu7brITIlW20bGBWyvH0bbUTBXw42%2BLKEajBc93Xyvzg460i8KDqQpbI8P3hvRfdjuH3yYpVuP7ea3AJpxwwZtyHxnXa%2FnKVrKjEQL0ouoeIxVpsuMrmtKoWLpgAemjUmg13xepWbjuhaStVsQCvFIriQZRKfAWu5xpjxjqLR%2B92hNWoQUpec70wOSdjJSPAalndek2pgvd9VjXFyCq44wwNIpqzRTtwaEINuYuVywyQb9DmkDnaB%2BQq%2FKBrBntgVwLySNWNI3LTiTgU3U4wpJTHRMn%2BLtfsYleDP1XfFrU2cbdHOGW1GMxq7WE17UZzrbpJsXeX1zvkSyQmmvmRPyMTrQqFtbSYuvTlGSycJKvDElm2kcqatiRtM%2BXAOliz6XR6Ql9bpw5unABUyOZmgUjozRPHLFnqBm%2FwT1OcWK8qbpMEwmn6fkxQEFdGYoZxDwFdZbaHVC%2FztMekCVCMn9lawhkKL7TRk45pkUC%2B5tZSrFzs5CgqwTej3T7yWhaE5gLHwn%2B0h%2B1rVeqVTATVL7Tx7iWvUzv%2FJv4Af1N%2B6fX3rQ6vzx0zd7AM9pZGZ08pB7ixFyHMPMxRekmvk8%2B3fknvFVjbKAAscRdHPQn3bUdqk4DItx4uAP4uJoEdaEbR9%2BhVL1jrs8QEmOsah78uflhUlTGTIDO74%2BgLrewWOW3kkDAFWPFFoTSDBczNkV%2BTIpFW0FdcpU7qk8OkJ36V4143X8%2FRiB6b0k02n%2BPhuQfsjDBbaNp6O24mTETI5ypKMLGM%2BSlrrls1SDdfGMEMfrBVHTthLvtRiagZGJqAA2xWj%2FLQSS0wDnrjYqKDWY%2FRsARcIH4dVTFwMoU%2Bztku1jDMPKPHUi0CfPBUERXHmkBwha9YGGWoT4OvQAnlRhh0FcT9RN9eB9p2k9lUBEL4Kdj9SqUBb3XloMCJaYYQk4unEKTGtoGNjJ0UjPt%2BF0WKcKYdukt4QMO73z5xqVuff5E9rtA%2FfYyz%2FMnjX2wNnKQ6l27H9CWD%2BRO1%2B1pn9i7z%2FJfyrHBDGtR4e3FSyagyypIf%2BrO7UH43VZHiezC5WmiLqWU%2BxfgZqHdvoYE0uUczILmJXnvYQMuvrM9eFXgB8GyglGRDci42j%2F97nBN%2Fc2w9KTWDMBTid2ylcc0NoRoKMCdY%2B9XNfyvR1x19xfBrMibf6RUaTKowUrS5N7Dy3sl8q6yweBdOJHvfOYiQnu8iCUlX75Ez%2ByPPLUvSO5cXrlTFVGP2yqazi%2BDhaRUHVMTJzYyZcq0nRnU9ws8xROWtlaAxirS8Tbqt4mbE2nUu2ExdSdJ1Dt2%2FjOykL4PKLdSEIpa8QNypx84hVFSRca1604waGkUD0TyhAH%2FRT2vxpWMp0yEZk9toonGknwSgn97RBT1ampeL6tJ%2FCfGT4kdwVLcjyqvbqO67OKxmgbJzJWVBM5mqTNsYBERk3uj8adjIxDI%2BZHZM8eh835zUILIO2%2BSXKwJp9UIGbuKzbWJZ2NadauiyPJhjjgDOiMrQMWYVi8Vc2bUH2U%2BrnIASPySLy%2B6FkoLOAyxMMvE85z04IXu4pv%2BjPSofeKtXzYo3loMlVucEoR1aBZtgFt7Uk1A8CTZfhJlFQSN9GQQcIfRJ%2F0WFcWY1XK0BA4YkZuXRbkev7njNeq0XSet7ub29Cdc6t6TT5P6n%2FDEquLSQhlN6OtJJXVa7taVdntCPWBuVy2kThB89AhmQoY9JUclVtB3yZE%2F5EKRI%2FWR31zf0nq3wnRUu1XfBKJSb%2B87VxAAI%2FX7ErAZUgZgPNnfDmXeiVlaqbMzzlt6XPsvZ0nbW6A6D3zUKXbqGHxqvKtoc5crxS7qLwGAbJaLPtkpjrRpyNdM8fjceFhJSYMO9r6iLFvEKJGYZlsTIJ4YkyUMEx91H8UGDAEN59eGv0JettWx37%2BNmLtlctzWeP1eNg4%2B4jgYG%2BnMlx36HAQPeh7bEXxQc1sI6fag097394Tlss8Fq3N2tXtZetrm6FQcFnPOKL8d6J0UGhGVHi3LgvPV3c4QwXYohJghOdXYX9k1GzOZ8QGGkfo0ey6Vgbnh64wGlPreR2h3dUFDlzlGNHXDSrWo11Xy3N0knfiB38owN%2FfZ1biv5wcfbt5smBxuWm298%2Ft27VXO5rGe3a0JCEi7E3mof7ai61bn%2F%2B%2FvdtpXF5oGWq646GkbKicU19htpCodYv1%2FGIaVIvaTrii2uulsZCRYZxDdzwQKW7pnusdoxdw56oNYw4fq0WFwNCkYvUk9AIMFEOf5%2F1gSXXSXKxx9jYojEuTk6uNkjn06onF3i6SjzO5v9mKzjvPyn4SP959KOYUnxM%2Fv7xZyniS4Zju%2B4Qp03fzq4NyhlqhxjeHJBniFExDgfjwWSGcR0UttJ4hjE9m9lp1Yin11cVEwfs4nyCs7aGP955tz9Xe1bmcMfRGvTZ5PTLyLru2UZN0LTS6HzLns5vkrRl3TCTnkize%2FDoAiOJgabGlvHNjorUlrzi6FFkmis%2BMxT73o9x%2BGHVBdvv98Cv12%2Bz2STuyQz%2FQe7rRvF5kHlUz41qe92Dojegl5svIAL%2F%2FSr16XM13bFImFk9f84iJ6pHg2BpOc7vcofyKMq2tKxpnzEcGS3f6KUa9%2BEXVNIGnD7%2BceP58a2XfwjffSEe%2BH6zoXtutLn5fHNYu3tIKTbJd7YlCaMJe6Wp2XWbCUtAaEOZN2%2B8uzCUxpxtwc0Gtl8s4P17%2F8n7v29d%2FhtRW%2B2dw83qfX9ZjBaWy2F2tp%2BvzY8527GCbXNkshUGk4rqc%2BLD6WU9Tg122dXhCU3Z3s54bBiL5qLQ6KuW%2BPm7oYQF2DJgIYiy%2BuLN7sv%2FxHbbn7JyoB%2FMG88uDjU1DrUSWe7BJViS%2F2xLgpP51lyqzC6ofLfu9CHFj5U5JdVs7V11nZu%2B2stxYmfls3b479R2wimJUcOqB6ptdbpO6xknVcG%2FYCn09kLAeMFzlCAtlnS3jhh8JQVLDUhkZBT4tkOj4bYVl2PvXDu4NO6un%2BEZW5QeT0CTo3RmDX3DSy6bVMaDhuAPvaXJQfQkCT%2BQQVBbTGLHyK2ZWx%2F%2BW8aMq2KUVA%2BV55hE8r2JhVYZ2ZbZZ%2B5Lk0G%2FI5zczPd%2FJzCv4b%2BnNjUkCh%2B21z4F%2BD5cnhe6P%2Fy%2FtR05aylhNwUCo2XeNXph12N%2BdwIKu9yo9%2BMymzS6DiHoFipFGVLG123A7bxzekKTlxlNIzWqEl7WsHXQo4%2F%2FSQxiVLnnsioKptOW%2F8rUQ8zOVbVU8UouuSMXkF%2BU0SraYOs%2Fu9Ys2zutn7lEVpKej%2BBPL95%2FPY53az7vrU9gvEupKia3AyK8ZUJe3nyIlpbOiV9NO3CEseEf5jkbNe9k8iM7ItWZttSxj5eTSmRnpAVq9b8vm1ToJ1iPF7km%2FiUvKJj75v0Wwal9A78oaeKgbghBqLKadFfdbP0%2FA2MzgjMVGxjLEMwYQ0qeiQxrxip4xyXmkDOY2eDI1Wu7mu9uKK6zKh1IZh123N3yzDfeKnLRYLK1%2FbRFZEFSXXcHzqFTAhrfeSBNFO%2B%2FxqYGpK6AtF2lLfCfgVXE95sgGT7XkeBcXkbcvQ5Sl4JqufWaEZ8%2FiYpttneJrElOiKrC2MU04vaijf6x%2BPLtF8LY4Cf867dvDUNsOfip2Uf1Ccf63Qqg3192Pd9q7m%2B%2BUr91FVX5wa72O%2FW2E5H0S8M9hkcGRYmKvrquNksBt3d0YQl1TVsxUfDmd9zhhsbmsZIrT3BoHeaKCv%2BzcK3zUCjswCR5bPwM1cs%2BusG%2FGXkTN7XZP%2Frv5t5Dni%2Bqles5XtlJTfKyii73q4K%2F8p%2B4hKplu0vT3unEde5A%2Fdt5c3%2Bd1ASBINr%2FTI1dXNxcW72wub60BENv8BYhP3gjkA0eV0lozmZAp0uv36ZPPdwPGJGnHiiikRtCSmXm3XIvbo%2BoEnhcaWql%2BRWlLnUeako2Lo8rhyw1Z0NW5etRN6XjmFxox0oVo5HBffX3%2BoXLKc7pzgvr83r2D5kPl7TKSqwmzLWolRchjsdMeDnrc9e1s8dOLZMMly1A9K%2Bteh1A5JkORPI8T%2FdUKKZEEhYLSam%2B6KUEBK5%2FQo8dp3nAZlHfer9Vtem36ynrkUNAH2SgkbPXipVuamPIXK5CAOQsyD9xAJc%2FuDR81kte5oIIpjQjP796Am9R7GeyjIhZvzy5fPSFdnZmtCvuvOiG6FQaNSwtws34Zdj9j%2FrS0p%2BN76XO%2BNj5g3XrcgBRRU5%2BiVg8iDp4s2asffXNm67rY13tT%2Ffute9hEhQ%2BCkPBCiCTH77ndK5b1CWUalj4jG0P8PuqG21b0631bfpaxSmcV%2FyPMBmZTyb3nmX3S4n6CHld5bD8H6EyJnuMtXRH7x37%2BlgL%2B%2FnOftehc7HCN1UDMXFhq8d3Pkk%2FJX0TXl7aHJmdcG8LhnVDxNdelXePS3U6nKvl2Bm92FTZ5Gyue67ZObTFBNN0jcujtDCRoYU1bio2Loo40rbKnEmWW%2F%2Bja8uIYZIV4aS7cdjq3NX2Rp7eVVX%2B296W%2BJJmqlqLte8pe8dQjFGgbspwGpe%2Fej0Io6D1AwhtJ9bt3ShMDU3HsDbJRakig%2FbUUjrt29Gvn%2FSiooyejYq8MsZkz6V7Dkr8e3L4hBwJuA83jLZ14%2BruTWQQB8eZN7ShGRu2W1t3GBpn6xl%2FiBqpxCi4%2BOACg%2F%2FhfMZIukVsPJni4RPBsTHZG5f2H9K2GCKFqeyhzdghGysximUQ9%2FmUY%2F2ArbJMRvbZ1tkL8Zy3vzinu%2BnioSMHV6neDjLzHQtNEfC5AIITLsTlXFy6un8T28Dhid4L9zD0Fn6LIeTrm%2FkXIgKrCwNLmX5sfVFdIDAJljT%2B%2BFoagUKI7A8%2FGhwceXiwN3L%2F%2FOD5Q8NJBRdIS0YFrTXBBVWp3A5yDB31zXh4ZCRlI8XSL16MtF8Q2IZZREMNfa%2B2b%2Fc9dPTO5nTOCu%2FDXp%2FdGjWppx3W%2FcKau8dGklKfTt77PXdUXKW9jM8dnnMYL%2BEqReFgjDHh7meVu1ykUczL%2FH4vDq5afhtknzJONbZCmHS9OH%2FnYR6G7WPAPRnIqA0goDPC%2BhxY1mcCT6d6VjxgX50dcbOtGHKpyM5xdzK9HWdVj1rFVjVaytFM%2FcHZJRPJssanfevO%2BXVjXN9F%2F3e69DQzLoKEUlzHbQJzQM%2BlQ%2FQB1Sot4s1wCbQb16%2Fs3Ub1qQvj5j5U%2B76QcgEN0bxums8lLlVV8xsMY%2BQuyGBKM%2FLOmWV5Lm6K1J0xLeYBGoFzFW%2FQuGs0q3EFGgip23710YT8d5zpIrxQ%2BQpkUHvwEsfr1tAEv2xx6dSly7oAFDf3KcvnUD4StBrw81XBnCbtN9eli%2BwqL3dZZipmHHfN%2Fiw0%2FQQZFheEKH1TCn2BjTB5KJlII2YJ1F0R2BllmycXheTWlwpQidEWZ%2FnjvNpXIisG%2FKf64Hbmm2q9VqwHQML1yuKn15syWHkuUru0P9llEUMPKxWozy8KSTbvujV2RaAuw%2FU8TzSipOdkKZj63zhV7EzojEtrwmSdCIE5nYhRN7cscQzpSEhvwBVB3LQ9tENVoA%2FHB%2F8%2BnVxlnr0d9r011xk3G6Sro4n9zOfkUy0iN5h3trWXZf%2F6p9ZhonLIQ7AeIgqvLbdIn%2Bjff3C3Z3u4vt72tPH5raujePvyLq%2FGgsKCOgNOCedJPLryZeJrO1uk%2FpbZ92fXS67bzz27hVvcz3dPqaiNIFaUJ%2BEYJQm4qvJIIrPaPSu7zD2RUUEkVpUnYEsq4nAV5URieaV7ypmCrO5eGu1cD5nS20%2BhdQ9C3J7m35tSFxIULXEYc5gTgofA9iX2Y3mA2rzgXBBHt2lQ%2Fbd68XooaN4oiFDlDXU3wGcQ8u7UbET2aETroxgx%2BhXqXjSqLdo%2BH99lecGlvSM1zL%2FO3ZDl11L3jnX3YQm6zRu6YhpQUefpZvZnqg3FuB7JDHUiN8d4lyVz7AWrfDPxLZlL1i7ygXEuCgQyyhumn46yiNaHoQsRaz4YBbvhaVnd1SuqmGSPFPeXBRWaFn6LP4Fd3fl8f%2B%2Fxj2tn6HY29FQLy2bcjc2IiK3tGxGbWxHbGyuhETu7OxF3VkOTNyYnTU0nJqaMJqcMZ6YmjQynZvb%2BkxWr46KjgidG10VlxCYmdiUPidCEDJht8UkWxlFkKyajKjlvffpSfNYWFxEjlCmUaG3lr0%2FoyMZAIiCR2VhCR416cAcNoxWhFUnDBncYObeqyFQzrWtO7P%2BZ5hcdgPYkoCNSZiv9AvO9NI9rRu7EVMa2FYhw2KXOcnabee5EoBMVwSVgObHvrQzuAoOxwC0L9G9oxgcyuPMURgCN7O9HyXrelrOyAvAUsk6de3jyh1chBP9oiKclxhfjiIqBYRBOwYwMVnlLaZZfSEdL9eTQkp4B6o2ff6KL8rTZwJnFhhEW1aqgxaXgYKD5DT01JynWB%2BPg6%2BLinGlMwYQe1Z6KrOrOtlFt%2B%2FpvxrQ2elvJBD155VumAqFQ9L%2Fxnst3e4f5qtRaJDI4rzqCiRLi%2BD50P%2BjAOYUVEKYAojOHuScqci%2Fw%2Fvaffws%2F%2BPftSYPOfWcHjHViHnS%2BtqnMQ2JYpA7kjZRNO18%2FA0sTH1SabPBshiVlXh%2BqBOM1pjFdiCKhhPCKSOcoiMnLzKExXkfLyIX%2BwWFuJ2toQaA%2FPywvmUTMyy8g0klJ0jBbBrhxZmG1IrUiaJjgphJKl7WeuJi49zgy36M1Gp9LsvdQ9bKOL8vK92uHxZjbVqxHXb%2FKvzCG1U12DAnxj4wPRlMjtOeNK%2FPsHDDOaCes1WNacQJlf5pEsizwcU%2Fw%2Be6MyXneVieGr9mhqY7xWNm%2FupDtY4oGDoQbZlazO9idc%2F4F2Vwi2uaNcEFHwc%2BrscEgqiJhu86Kio2KiYhaXUwkMTI%2BdjUhKi4%2BOlYtvez90PqrqC7HJ7VrdiM9PfS41x0RXZHjS2q9tjWfIpveZSzEpfjPpIqODs3GovFdRgfTJNzIkBEHnwlya5V9YXasvZR%2B3qjHAL6a0h14rPLI862GofYr1du3LJ3avlY2UIJdrZx1IKNYa2%2BL2siE7oS%2BlbH5yykY9uuzZjg%2BzzMgJd212D8qP9ARQ8KiPKwdQ0%2F5VQaWKD7jcubmHl18eue3bjYKJSLM%2Bn%2FN%2FSu2mEzdIKn5OU0DeGSxu%2BF1VCxjKMgwEhU8FpWx%2FEbiaeoVsRpbYrcuXr%2BNAGuDJOgUvvUrXidVDC6NTnZEpYSENA%2BPsOPOiV4QG0yz27fIqzkvcU6su2Q4pj6QX%2FlYXaSa8MlfT5XBz1%2BLijx%2BHpdLtT68dVWajUt9W050iIBjaGdxCR7H1Z4pd7I7G4bqh1Va50e7%2FZOHp3gD0303PO75ZzOprmalxl%2FFfsIS1WNrM41E3fleyMgEoCY7E4Onkb0jGGc6gTTAI5vqic%2BmeUaXF3ei4H%2BOoxJ2mR4oSirg0HEwZBG3y8BakAcIkmec56NSGdcpZNQnhf%2FJRBL82fTe07w%2BMELMy%2FEmBwABnH2USKib%2BkjnosANo7N88xl%2B6%2B5pidTov65yRhYAdBXC3aKrUpKJTHRiqLJ0pzffoMNA3dtu%2FdyfANzACLD4lRUEoQdp4kOjFWGF7x2ou9nVzyThIHERkw9lt7IdyDaZ13KLt45Bz0kPxKo8Ivt0g%2FTbgvU7tb2%2F2hx0PhweZN3de8K%2Be57Txsdk3S9pGpQ8B%2BkpGyTIrn8urkwoSeaEppUXlqrkBFuWMyqZAUiqqsXhXGx%2BdmJCDi02NpcSn1CQnRph7WSPRM5lYW192QaFttdCYB6Z%2BEN9THFQXQuTx7HgXEoV0YwA9TZ1g0IQfx3HgXOzqqD%2B91nhLDm59fRlgCUniF9ZUAqNkbTKLXD6F%2FpTXoHAezU5Xy%2FfVUObL%2F99DCuvrO7liRVoUmwh4GijW74i9RcDg0OVsChxq7witTgnJDhcHTL4IS%2BrKI1ELSjIoZxJSSUzFPrxT1PXkNwyFKgb%2FuBZ03mN%2BRWmgFg45ejT8l8pWBWtsVN6DTq%2FvT7WzXLqaEaPH0PAJwFOKUvNVMCXVTqkL6ynd7w1FI2tOU8gP6T%2BKiUTF8Wi7ebtloRO51pkkfRahYiHZ%2Fbjx33DP%2BxHofEc2GOLtY8LsAxkAWVt0gCjPcD0EgZ2ShnA2vI7sNHdqjld1AQcfV%2FvSa0%2Bq%2FTR%2FgH0fc%2FYUenZog9aOt65r0ZAOB0zfJle%2BCrh%2FUisKEeusFHKQEjlFcFoZUPv%2FsWgod2Rwpf733uTyMvwUP5WP%2BJTneUhnB4S4cu44avYe5McylYe7FiE0%2B0w7EXYm4Ql21n5EbTLuoHzrTgLoW8QsvxhyOqzIaSvO1b%2Birpy1BnYqJtH26MUQj84ZPmvDtJ89Eo9PmXm7zyc3iHhy7PhvUmzxahfVL6F%2Ff4f4vyuCKEfbV82h6z%2B0kFawR%2F8Ic6vIIR%2BYcjy4h2k1aJE2BYHIdUzNZCJ7ARbgP%2B2NVMOYB1yRZ6XlFzCWrGEK4V7Fp7fh1rnw8qM%2BaO1dE2rD7IXBwyXtd1nTypsUPk%2B7MYlhv0SGJFdZbJpZdWx%2BL9vP%2Fw058WPYbhNLhAYD4pjIUsmkOvlGk9Ae6vxmAHaJ6pAHTCs1rbQ19IWHakImgdhbqKKZoq5027aAtS%2FbeYAH8yh7TKaK%2BpH7SrmAN60J8xFWm0OwKGVvJqoyK%2Bh3h50qLs9kQ8wnYk6U6y1GY6hpLxNaSpoB%2F0hIE6mI0YBZXOlz4M%2Bij6KrEJnBpB7%2Bka2cqyLteJNIMgQaJvSAkAEOSSiwALKzo6zPyLdR2qzPwsXC7H6izblK01ArjhoLwILdg%2FvBF5ub68UiQDi1pEq5siO2vsmdSbSLab049%2FvbP01kQZhA9pT2yXN1Pl4d3txEfcg0g9JUkONP5BVivDf%2Beg89HXrfNK7rnO3c9aATViSx2BsTnb%2FOP0N9jEuj%2FdsOipxwZ2UPhldJM%2BhqMYThuMeJzjimpC4o%2BIGDSKqRT2bZ%2B%2Ftq%2FKdUaKuwDr7qdaU7r2W%2FLASNVbDJAYkFFt37nzft%2B3Dn%2Bu6o4NIOIUDkwi8ASkf%2Bxyv%2Bk4nAVs26jy%2Fb916HDF%2BWShyA9AQx8nbdq1o%2Bwai9%2Fqg3zA%2BHEfF6C3xUNCHMaQisLUik74%2FxR%2FqulPCJyJId6%2B6TjNeW7BErLvRYnGzE7eWnjqkro7qweX2jt7WzbphgcF%2F3Uo6M0WVBS6c%2Fi6jU6hgTJeH483x0VJvmnHFnz7r5Eu6YLaP9C1pUbNBh8Os9TP%2BihmG%2F45Q81rRxt43MpiZWf5XlUWDoaL%2F6EbY11IZskC6vjxFZedYU3Eu%2BcnQ9ZnlKc5LEBGyf1x30PsBC2qh1pZNYuqA819OQlH9QLq9DmBx1drYkv0ETKKE7QE%2B3qVmfm7gWYFWOtInTlBABRTsFrgoFJDN%2BQe8ghZKvWLvUkCUOUyNhGN914OMiMeal6%2FhjPvtQ42Gyo4tacDkQIlKFTcjj3SALhlsfY%2BBogaDOmEzBJ3IaWjFayxLDm%2FA41m1xPrtEAJj4HWh6PMexarqvCZGsV5PXrNmYlybaAIaVPhsqv535p7wEIoxWHkuEjKRN3Bjk0cssmwm54t1LuNcGHQssiIifD6EenIAdCnl%2FMlLSusXaK2GGhfTDFw%2BnwPQEW3WMu8u3nKcuh0q4muKBmX9o5xRlvfOz%2BpxvoQoAlvi8BVEseIFQLzIKZpN8R0ac85xLAzdbqnbz2raa%2FZ7CfVkhWxguR8FGDgV%2B8FRWA%2FdQggAy6pt9STWF1qHXVGjPVhqFdKWfgbfH6%2FPybWUVqCKOrxHW4virYMPdNXNRDV134XcvmewdVqU6iQMJVF4BGhbi6%2FrsVQQ4En0JzjB6TVJgs33LaD1lj4nEQqoGhpZyead99yzOcBI46cdwMquJu9ZVVa8xGKlLPZN1Mubp%2FqHrBgC7At9Qy4v9fPn%2BMeZyx9%2BxHF6QpujH%2F0y35%2B6wMOjCyFPdUmkYBiLyWB0%2BEROuk6UIROcO%2FczqMD518X0AY%2BFOTZaiHVys8jMoeq8wpgO3fEV2kPcjxWQ9fOGcUV6xzXvaw8v8TiPdVcIQw0R1NXYIZgCUZ8hSLpFkln38GYKKjIJEklt0T9BKYWgn0gR6fJjTHyfuL9iCkg4EedSyTaNjGbinSqKrEnT7izD52MYvgSA1Dq%2BRGLd78dIQj1Lj3hCSCIKbTXxJ7JMc2RSsEmHjDGLX6jlKXW9M%2BTpgwVbIbSLHp%2BMhpJ5RYKXc7O%2FOZmOAByNgMfLeBY1HGZEY%2Bm6FtuuTMSIaDHuELcIfcTYy6R5nN48lr6HYfQ5sj4xmVgzoTFMUy8pTH16ZUGJhQxQ5%2FMIcyHwZ4SIZtMrGIodYeuHQmFiRQWAOd84IWXt%2BBKFbTYCYajnb8i0b%2BtUE6H6yPKczYOskSs0fEapwCxfFqESFJmb%2FeKdezIJElAHgh82coKqyha%2BvMLI21YBusHRhkSJObmx7GLYyoQwC%2BUulk2Ekc3eZUga4jiVdUDVUhKpJTGEmVruJjPYn6nZiOGg1Fr94AQiNwlGwiRbZGOqJSNajU9egUDxozGwBjX2DCVjFcBJWCfIEjaYkOSiEl9OEKWeZnS9BSgJCMk1cKSnWoxqfOavNZnaD9QR6DdMDntCmPEfxUUCtqQBErC1Ldd91kgonepcgrXZL7Lk%2BAthG%2Fxjs5hukeWXk6bxGXrYJGm5vOfMX7CU5kppyeAKqaDskrmPhZ5rEaMx9QJJvp4rqIt3wlGItBT99uIKWAf40K5eYvH9wsEgXjg6RKoo9rTgK1ch0Gs1phF0N1I3m%2FvSABKq7C7kAG5ReCNRxUZLLGoRc8SjQOfDmF%2BJEWjciXt5bQpYLHLJCinnNDVWXioBT00BpKbvCczwAS9SDP0Y1vHOQ7wzj2PzfC2nPyZ3IQkkfbkYTdeN%2BNnbyDypqleyH94jFtnBZLHeejik9%2Fz07s57wM5WN2o1bI7Qpt9J3bbO9%2F2xJ9aPtEzJsfIq1ppPHtuStwLAFzh3Zw%2FAax5FxCqqjYkGp9hHVNqTIuX%2FnPY9%2BCHPW0rHQWVfUF0kg1bLIFeFAdlflFgtcikpiiYZvQRYm2VsZUGm55B2HT03O9Y3YIYERKIBgoWw7rkpnfMZxx33S7Raj6qy9A1WRwcpmjY2GI5JJbnT%2FE%2FsfF%2B33VeMZAgFIAU7XpWSDzam7KtkIHJyAyiDnRpRmfjTLbJuZRh4%2F5iyybFZuvKZXyxxjr5frhjLTTqDkSvZzt5P0Dk7aE5qxxUaDBrbVB0MoxlPJpUKgcUBwSp4n5U1c%2BsFFPecw%2Bhz05AXkwTsh%2Fv%2Bu0w09dG7k0BdT7cUecveW3vjNbFFwXOfED5EEWy4R19MwxoWZB8%2B%2BEc4gHgJURKYrHkWZSVVG7LC6Lu%2Fyj1Jf%2BfDrwD3TDnJtalTH2x6ugD%2B3Lh8OJ7ESiuWJunkuUFagviyrgvk%2BRYjEaRfm35SSmXBSX9EVQt4jVihTdBqwwyK7adx0dqbUx8owyxySevNjnjNYJBHAGM7hKzwxSR8hzTOM%2FHuPkgpsyifAVj3c%2BSVREw%2BbWA81vpI0OW03FJEbZir1rOQOTRefgB5QyOuLVHYjmDrv7R%2FOUK1wRQLu%2FcDAKq%2FbbwDFi285lWmmLNgsDjj83FD0lmo8DBFiskRvrN%2Fls51y%2BYXxb4OXLVT5dJ8DWQylXVTv4M3TYBg3xBqIF%2B%2B3pi%2Fx3HRc6mNYKGhe95Py3LNYOu6dnQ7t3avWSmDJB6c606XLNZCd9bHySOYSxOmITVzjZPJQuXBu6CfTvos%2F4NI6UV%2Fzkxp5EG73IUraubALTXq5tzoTxDoYfK8aSaS4o7%2B5FyiHz4dPaJzPt%2FeMy%2B53Q%2FhoFzlOLcHmvutTuDrxqCFw%2Fbr0c4N24jMNp0W3OzJs%2BdUYjLySqaYrE8xNXl4XIZuiC2Y%2FT2okht7i9JIhyKhtR%2F%2FM6%2FnIyGmpgI0oJTbNIVz9%2F%2BH9fi%2BVR9izUG0o5%2FPUtylRen6qomwdW0nf9WUhKKp%2FISkIcw64Za66sA5j3kLdlbxOkX67Lm0FkDP2mfB%2BKlPYbYh9aHm1hIkV%2BVuFLNevIxedIV57pw3sOIPK2Ly4YO%2F69LBYiEmSTcD9tpr7TQms7lSS7w4akMUPE0EvV%2F7B%2BdXTvrGSfJ5GNIQssF8qrKbLyCRhzQsQ3%2FNlzmci%2FxKzJ0ai4nIaYAQiqyoIy1NMVRpuI5xH2c77%2Fn1dtiYEEAKDy7LlHuln%2FvKWhnPQaaAquw%2FQLAdA0W%2B6XQO6N9K7oN2LkMDtH8%2FmRX2J9ZTMOc6ytcULn0b5sv%2FwqO3JZ2Awh1ZB%2BlY%2BEf4ywOMD2TOJYAtZI9uwTiVmh9rOtVwfvLk98UqKPtfvSAvdVZMlsnIjJYF3h9gnEi%2BGLvNZvaejXX5S9yyR%2Fj07%2F8fWvOmPhZLNnB88rHUonwssp9qer%2BvPbmsvcCixgRSpYGQhRQ80PASi0YRSkVE%2Fagksk6JHoyzW7TIMRMOWlWPT%2B4GPoYKoUap%2FIPhTyW5CeXl4soyww0ImMqhKSiLd8XBsP%2FYb2L%2FsmfWpPfZTNyHV3Akyxidu5tWs6nsPw0M1NKo4Lx8U4Y7HXxz3yTmTE61JRzb%2F5puraZxgud11xMFgDdQK%2FdQTeaNmr%2FE%2BIwIDwrz2LCfolHhV%2Fybj%2F3ME57jGPwYgQV5qGIzNgJPqY%2Fhr9wuqeKqcQSKNSp81%2BGgV%2FGS44SVY9wq6fzz6v2BjJcQpcSFO5C7k%2FeHm5vNlRs4lGkUnzyVeAaIfZh0bZx8o8q7MlDnnw5WgWf95XqAlbvdpl%2Bs%2BLav6%2BltDvr3j4ePto%2BuNHf47p7nq63DuLvdVk8ynd5TaAuJPU5cuRlJy0aM%2Bm3i0McychfySsX2GxJ4N%2FAxiFYNRap3nMrHDfyXWeZUno8A6qbSLljKn3Z8eiVHq2u00R3nvC8SdD8oRVF9Rh%2F7Z%2F8GP8YkAnmggovybRkiC7ytcQkrIQacCg0I8kNIWGs0qwdH%2BB74lLZz%2FYDczXf%2BRNNRUYhRe9u9uR5o0fz6Kq%2F%2BvqtyXMyDsXTofuk6p66pYkaHhbWOutXSgxvKiiO%2FvMIrFDkxTzitx4HgK%2FAKjztUlSmPAPe9pmYOY1DjmJLrufFdJ21QSj%2Bi5mj2hj77FA%2FhmSTzOM0054UPvW3TTIe1WrdlOVpn%2BLfuuMt3D3QYYTyXKenK2xviclsvyOIKkLW9Eb9ffrzgjnQXiWEwuyWS3Ve7QXIB50Oqp7KP1%2FiCbrbYTcIN%2BrpxQCqW0vKkZv%2F7KzTs%2FMGnFdHXJKyvTf4SJDnklRZ02taSdrWev8WwJUzNZXCQcX0FTYraWryRyugVGdii5W9n9jXA%2FtfUR%2BGb2XxVqjbny2E85uCTJ19eG%2BFeP2F3lvcZB44hJlPCtj38aWQECQjatV%2B1IHMt3ABj55%2FGcVpVgzw1O60cFqdIt7s81vEdWU3Gk%2FFVPZ2YyXTSThDnw6QKw2IBb1iw8JLaZwgNTNLRbq30q2jGMcE7odKxOL70RUFyY9aLYabhrBOi3u%2BmRVoUSNsVmo2h7Q9pLd%2BmJ8fYeSDcopo%2FQo%2BmLpHGP7Wp8g2dy7WtAAQAYrl7ur8Qd39v7P8AiX9fXfbNrRC16qx%2BXFn5mz09nBuYxALMfZNNtQBMbpmOAOYe%2BqdtVmD9zXxHfZS3rYzmkoCSN7sGVj2F2Uwgs1XZ0CG58ZFjA7NECljkHDJFkN49OX5yLK0Ciw5W%2BUyxShKJvkzH05G0Cc2U6WU6WUqxHdThCDFHLbJmOjEi5DVZQNvEVgMraoehJDUnOkQfUG9OUPR6dL7rTQNto037AFpjpyj3BPW1IOOlZDp5ey8Xcw0wnuFE9gDl1YC8I35tACdWoiK8IzMIonb0f6QnqpMqMt%2BYqTuoiz2oWVRQeDQzlkG4Dc0UUQNFtDcnshidGclmdIk8tBVn7JWKcSV79dMOaFNzQykIGLajkggGCSJYnxNQQRwyOT4qEVdvnnMoyNUccUIXiNpmJXXEQj1xahgRXw5h618C7IFzVD1VAv%2F%2FxelKtE2IXNKpR%2F53M80Bmed07IHpcl4VAHZ37fUbEM%2BcNiPqnEtIvktRZvi%2Fvwkw%2F0YaaZvMObcEamqkEO8mgTH2G1v5lxmOS1Hb8ARThSIcUET7Q8UoyDzWHeUGMueWQO0JKcS7SQBw84DCzeYUq2isRs7LAeaKZJIOlIDDJ%2FnBEU4Nte3kbWporw5OgoYGLFbJFLCY6BcSsytzqQ0nL9PEKcomxZFOs62lOxQ7W0TM9015QkAAVr7ZpS21LADMD9cRAe3kxUtcS0as2Vw7incZj6nrw%2BQXuCFrEpKldNJlCtlypBAJEwWBiIH2QlaiyoGrCFU1dY2aVAvaOrp6%2BgaGRo46jqsTOHX25wYA3AAAAAAAAAAAAAAAAH%2FrgH3t1NJ7bPjslz%2BXQ742%2FGfH4OBq0ZwEMoVKs9mWc9uwY7c9H%2Bf6v2ucKYgCAIAFAAAAAAAAAPDZeoZMxu57fJ%2Fv1%2BlX0R%2FEma%2FdVA5sLGdbGouxcizGgjYW7dm6Tvf0TPq3axrD7HuLcTlr1%2B6II6cuV5EbkUoUCYKIgfasMrw%2BS7bXzz788sciiUyh0mxu7DFeRERERERERET829HX5puaxiSz73U%2BNuRAUAIRAxkOz0KqPRERERERfc6eCYex3lf6DL%2F8wT2bGNkFx3VZs0hKBoVKs9mWc9uwY7c9Hz9ioR%2Bzc8MwMzMzMzMzM%2FPn1vT%2Fhdn7Fnu9jvU3xlaiRCBiIMPtWShRi4iIiIiIDGwhIl2t6ffVTGF229ThHhn3PX6fpV%2F%2BxJmvxxYPz2eVnwSEbgJbshSVLmRkywWrgJDXMCnim4srQmgCEgUGWkSSJFOoNJuVbCvHXoVU1dQ1alrVgraOrp6%2BgaGRo45r1gmcOuscXaMb9FDLHimDlWfh62ka3%2Bx96whBCUQMZNj%2B38Ju09gwu0177G8K4x1hLMZiLPI45AO%2FQCFDCUiWQulCRrYcKiASJioJRAy0aJUEMoVKs1kpQGWoqKqpa2hqaevo6ukbGBo56jhYJ3DqzHU36NKbjL5timPYAAAAAAAAABQJ9UmSqvNLklRdLj1f%2BjyOa4sF8JEHG%2Fkkv0Ahw6bOHIvFscXieFNY%2FNacQyRYVBKIGGjRKglkCpVms1KYylBRVVPX0NTS1tHV0zcwNHK0STbwC6%2FdiAw8SzYdwBgzLJLIFCrN5rnupe%2Bf3zNHMEY%2FZquz4772CMOK%2BOYMztOLdfvy%2FOOTMEY%2FZgF%2FAAAAAHDeNw9j9DEKwzfoaxt7AsTY7WOHjx0ydjZERERExNidOuEdx%2BnqXNclShwQERFRdmNmZmbmL79vBz%2BzvsvrwXz8AoWsShVlSElZRVVNXUNTS1tHV0%2FfwNDIkZv06J6J8u1IXl4%2BVA8olORBob4n5BxKzkI%2BQila2AGGYRiGYbgiQyKFG5FSbxERERER6R8dHo%2FH4%2FF4fP%2B78SGXjKy877HPO%2FlEVBEEQVRVVRVRJBoeRc1QMxRFUTMzM0MNZUeSJEmSJEmSJNu2bdu2bdu2AQAAAACACgAAAAAAAAAAAACghQl%2Fi4GZIZm%2BSZJMr52nlqUVq611VGvjvsW%2FnLVrd8SRU5eryI1IJYoEQcRAe1YZXp8lk8KQSCIiIiIiAwMLIZHJZFVVVVXVgYGFkikUipmZmZnZwMDCKHhUKhUAAAAYGFiASqPRSJIkyYGBBWnOWlVVVVVVVVVV9XwfHzDeEdw9PL28ffrZ%2Fvlj42yMMcYYY4wfkyRJkmTbtm37uCztTrrJDwAAAAAAAAAAAEDAnyMU8SLee%2B%2B9VFBKaV3rtDHGWGutc8557z0QyT0AAEg3kiRJkgcAAAAAQEREREQkIiIiImJmZmZmFhERERFRVVVVVT3vsTRGP2bzZ2ZmZmZ9EwYz58595ty6COacc8455%2FzuLl363aV3nSTxM1MHBAA%2BU0N5YrdpQbLMhQNiYX%2F8umRyFLY6Q84RIA841ARJH7I4Vog9iF3YfKwIVeHHipJFuyClBSrnK0uCDBB4MTJQBUiQhC5NDAonVHEHJF7mKCBO5iUcNAjnA0KCPh4EAnwpBVmvoiLJtEshmGl5R%2F5AS0ZbHpnFlrk%2FJ2cmRlZO4gwkoZTLRJGEwTSkWGiqG5U5L%2B5cuPKBl5NPsmAG%2FgtSy3uiKpkNfQaIX2VaSJgIUWJAxEmQ%2FNb%2BO540GbLkyFOgSIkyFarUqDtBgyYt2iB06NIDBaPPgCEjxkycZMYcHIIFJJRTLFmxZsOWHXsOTnOE5sSZCwxXWG6%2FFnqd8%2BDJizcfvvz4C4AXiCBIsBChwhCFixApSrQYEwaVY7qiw1sVGtQ6Z9RQCKkJYROyO4yvvqnXqcqap77oMeaH734aMGnLpimx4jSJd1OCG7a9k%2BjArj3TknzW7J67DiX74Fi1FCSp0qXJ0CcTWVYTX3%2FpaLLleC9XvjwFihRa0q9EsTNKHfnoIr4Zs%2B574oE583gWreNasKHSuKuuuRwiPoVojDGJuV9fOJ%2BY2nHLbXcy49K0NDH6eSQ43AkjnnlZAoUal0lJEHa9lJJ50zDWGY5QZ2EBTjyfTqHSsxIopEzKmYzEIlCCiaehu1xnXwgBIqB1lDZOaM4NLQGZlXfRmp4IeR%2Bgr%2B3lidT2xMK09VGyBBgSSlBT%2BF%2FbhKMtCuU%2BuyO13fUOCkh5gohAPSqRjpTQTtRd6nQV2mdvNe0Pfq63hS5BA3mCoIxUIshZftSiyPu0RWQOWURwlUV2zh6LLNLXH0ogBNL5dz5QYtonwhO1KOM37OCTOOCf7qQWBMkoZo4SJA6awEeImlzJlQaij6aA0Ghqh%2FhuXr69gfO%2BBPM1DWufSXB7NW9%2Bn6uyyNy7FwSr9%2B4%2FCLLe%2B8GnLABej%2B9aBQA%3D%27%29%20format%28%27woff2%27%29%3B%0Aunicode%2Drange%3A%20U%2B0000%2D00FF%2C%20U%2B0131%2C%20U%2B0152%2D0153%2C%20U%2B02C6%2C%20U%2B02DA%2C%20U%2B02DC%2C%20U%2B2000%2D206F%2C%20U%2B2074%2C%20U%2B20AC%2C%20U%2B2212%2C%20U%2B2215%3B%0A%7D%0A%0A%40font%2Dface%20%7B%0Afont%2Dfamily%3A%20%27Open%20Sans%27%3B%0Afont%2Dstyle%3A%20normal%3B%0Afont%2Dweight%3A%20600%3B%0Asrc%3A%20url%28%27data%3Afont%2Fwoff2%3Bbase64%2Cd09GMgABAAAAAD8kABIAAAAAiowAAD7AAAEZmgAAAAAAAAAAAAAAAAAAAAAAAAAAGhYbDBx0BmAAgUwIgSYJjzQRDAqBrFiBlGQBNgIkA4ZsE70QC4M8AAQgBYJoB4QoDIIYG6l7Z9BbO0QSerOUWMD9%2F1cTRZXq2KKIMQ6wzSjJ%2Fv%2F%2F%2F7TkRIYSYiG1VafTff%2BDiA2TMhx6R6GCiKKipNXRGIIlEUHG3ELP2MRhdzx4LfCiOw5RpfZw4irWRaVroe2CMIx3WUxkQNxk6z461hFuVKenMJLHnEzY2FGtGIcST7Sp1cxTYd8E50vso%2FyPErfe33BNR2HDauKu3AktsDKFzxgVf7HfsTCZGph8ip%2F4Uwt9iS3xxX%2Fjfik50%2BuSSvluohaoxGhW%2BQffZ0VxQ%2FGM8sOOfD3skKRo8vC8f%2F27ju6d9yKpcgWhygSeSCgqcvLLdBLvHsBtzrwRdYwKMEHBAIxCG6PBxMBITIzIX70341Y99elDvde3%2F30frfnvzA4t8N0FHiQ%2FnyhlhYpTFKZKttIVlLGFqAtdnOXCPfh%2Fppp%2F5s%2FMptmdsGE2YZeAAAIiCELEKsEJcKJwJ%2FKynfnO1bVyn4tOV3TO9YVUOtHOcq59RemitP%2BpqmCq3alMuiDl8%2F5IMr1QhE46pskVkHI%2B0pVKL2OFsw0Pdt%2ByZtn6Fo%2BZb26vHjKL5K9xJojdAa1M3xoi2sTMDYexavi4tFLAtdy6hn5NhRHIvdLOsRxnVwW7mrbd%2FdLaMceF1hxqKaWqy1M0wnGOUpUjcZlXCIOSPyiwgRYekEwk0wQSeYETiachON3GSksRmej5eOx5AgFckz8qFxU4sFuBDwh2aNMare3AjGQ4P3L7FXIFJNjEd3EIjsBrNet%2Fjg%2FqRyg6IBQYDvgdMlk3NkNNgB%2BqwG7TqarbF%2FI8LPB7hDBogrwqc%2B2nJJCrmTE6e%2FO3AQw9WXmJicB2G0w%2BCQKLMusyiTVt%2B7VeBVQSlulYqexUqapgXzGwx058eVSam5Ez%2F%2BqsWpG8bIipC1c0vuzbiq7kJ8HXR3gQZsaCScAk2ZMEttfCnh1JcHeCS9i7uQq5uxgQkxCzfoeYlIwvhVCl0IVcNN12t9cdPdngmZbLCHVCIoxbFgSXF0Rlg1A%2FyKp6CYHaWA%2Bi8bm1dBjU8NCvvWp%2Bi8tPihQN4Xy4MWSPrDmG2TSlyfUr8c9%2BGtZUM29n7LsMByrIY8kQ1PSvN5MwN7xjeYm%2BZ6Fjs63IOyxLAcXRh0WHA3Sqhv%2FAGHf0OMAboONkkhqh6SqMber2rJnbwoSAyHiIyrZsPBhdDfcIJb1nz97ZXbZD3r3ZFlX9JDujMWp3NHVAWo4OtbwMm74D8lx9V0Y15%2FoRyh%2B3InYAAFhd436DrdGmAGD5%2BNuJDlyQOSrMzssDFPcaaerubRRgeZJJFtd9djWV1yY2p3ObD5ylFJt2%2FadoQueV%2FDg%2FXT4TExATEQOJSYnpiZmJRYvdAHH8%2Fy%2BjtWSl2ZY9ZgB1bSrGJybUT%2FcDGJ8qjlexgDmei4II%2Ff%2FX39P%2FTz7C0c2jG0c9R51H5Uf5R14frfzfuZJeMY2qWxgvm6qGecX0LG078j3V3XHJBsQFAKcMC4MEe%2F7%2FyuP9kBhfhu4hm%2F7KaGIj0k6NG9SmfP41vG3Zrkm1SRWSNuu%2Fe%2Faao7dacorBO2u0EiaE6x12ujLc4K%2FPVqeL%2BfFsemsy7svMaJWUFIM3FSaHwOESCaBWCCiq1AtWXDTiiFS1TONIcT2HKAj3o0GLG41VDRcQOcGCtdgk52DWC7r180lc4Pl0QVx4gd6WCT%2BHaQMvW%2FrMvV1qCH3fTjJoJZ5UIggyI4IgoVpSWH1R2pWcPCfPJeJLXJvrm4iEiydOtD%2BeimF%2B5HD4kheX0rA65wh6RJWAyj1SxSz2W1qlMghMHDWRluntJCyhuxbhJUQk6uLtGl6EG%2F9mC7ysmM7DgVmeLW5rBOxijW1gxT4%2FOLkQI5yW%2FObPgeqSOYxzqjBW4pJspA5LVt3PxUNI%2BUz2D1Dz1r8%2FAZsLS%2F%2BdSkBLwEMdfCVknc3u7fMqU91qa2%2F4psvks3WTyec7tZBhX%2Befc8PvvTSw%2BvUC2bz05k2zneojGQqtjgapOpXFH7C442UOzsig8vzVuvWICkgAMIC5UhBAoCx6LLoXq2AO9IITTeQS8OHQgPTdvu9TSuN9JpJXzjmAxWZUWyeomrOsmF26aMN0IYo7XNkd%2B0j%2FywvbfIXOHjbZKBEUpnQJIQsgUMCQOo2gNUva6kX4jXdyX9qbSmUPnWUUMFmtWOU%2F8ouymnsMxRHWQylQjjU4PaS4EFZWuenDmRNFvkx2U05uhSl%2BhCIngoU45VV3VKcnecajWAPomTiDKaVTeVJWHwS16yrjlt6EOf8jaZBcnhMnwKQpF6Jc0whYyp7PzqOTy1mIfJ60DMAGaBvWc0bmFrHf6R8y%2BGJGTXYwprNRzlptfQYLfBOierCgUijOYy3tEVKIqh7S2xrbTSrq%2F0pQ%2FSBzcmGbRUT1rKkPNroDpXZicoG01xAZAQ7hXE1qLs0Cr40IwceagKo1ShLC79OButaQgQm%2B5DjaNhGpUpCZ9iSLVeM2FwBTuQeEAv2GbBSqEt%2BcNM%2Bx4ZLAtzRdEBrEYAIEYjcRU%2FXYlR6oMBkw8IhfQiAfhtVQApvE2nUkrrX%2BqG%2BjkGxUZqMWschJoQCpJkB%2Bc3ymIn8LXmsOZ7RA%2FRmKctblKy1ZKs8hmCKbs1aO6gsZgS2R38s3086QF5m3NZbEkSNInPQ%2BHzg%2B3B219WZWCPF4rJcIaSlPjBu8X6Q3hRB8x0swhhdeAUuhI5E3WmzkJgswT1jwF4rzVxsIn33RIIKffNmksyqRWdBdfzDOGT1Bf9Rn0JfkAK52V%2FpC3MO9PEApajj8TZdihx6CiDFYTmIKG64AG7k11kPjxlg%2B9ZghNsRaTqpVnbT1chLyoC2oREi%2BEnHkPgCnF2km0ayUFLwzpdWmpSlQdkj9TPKA8pIAHQCLZuGkE5dzCRIyuee97L%2FsDXORLLDs5VUbh5ZuAbdtxjo6YB9i73dps1tCohcGpb3N%2Fo2lChSykdkIjUYjvG9OTk8f6PeAeeZl4RsBoOwLyHOz%2FE0A5RAStnLRutoJ1uwgiYXLr%2BE0HccEPK%2FCdjBLBFKtnFrhVBQxFIHMI0VgGb0ci4Z3ZZbMgg9AZQaF9dd6qiT1BRASK6uXNStArgxCupzRTBgjKtNNyxe1MAojJoOOa6Kkt6kTKaP2VfKjQzFXSlVy5E3XjHlt%2Bip6X4dQBZNhk4sS%2BXzgfAY6h3jmZ3nMIfSZ77GwTWveLWWz3fuSCs6xVGy6lrA75Hw83W35lLf4yOfNDUanh7xnPst5ddz7IZonglh3LlIy9zwee55J3vPavK7JvI%2BDu6%2FissBTOysy5%2BmULZZbAVsOD9ilPSn%2FQWZz%2Fr8P7Ttkj9mdcGtYwrZodSLJQ%2B6QwW7EqQrd1qYCeIoNvJiJBj%2BHUloE21dP0OZOArKgmfeqoENgiIYReCWDTpT3sjOR42oe2bZzNvekQiDdTIY3kYWQzzZk2y20TNXjMTKEmU3WNYvOQe5npVEGnBXPzeRCNNRrmWtXTDiJ88ey%2BfTQkOtB3lcYBvue6kmMQ4aBJt%2B36ZyanpCTqW7MmpnJNc5EgRIBPME5l%2BLH0xqsAgYEiMWH66keclCIIam%2F%2FSlPGhZigOzVcLRjPnRSL1G9ypYipsukjrlHnZRQYQ%2F1l%2BnjnCxKkrKsdUYHsv5BhLzFBAtlZmmEeKFj0Mll2z0B%2BekC3QSnu183K1BOP4rN5ytSUDSVUl3jTyPDYKaLA4SqRMwyq0H8nLLp%2BgGD4ox9qVaOSYG%2Bzjm7njrpFQUJ%2B1SV0oMszjTQ8aQY%2F5N8fzYDLlAVQFoyilNy7kI2Wqb%2BlNg2s7D9sWSAdYnbu5Nl0Lo%2F9IDx8VOdA0hzsrzyuCbBM8yrFPJ548FJ5PEePHVGyIDEOssj1SnSiX7r2XDD%2FMqVq0%2BWU7QiW518PVzmZGrFAUh5cSzHbuepYnJUzfVe8vUXBJ0XGSUDJPQo2vZM%2Biz3MTpUq9oasCSV9WKB51W2UnR4SP%2BLPDnkaUDV1hS4xVK5iJaKlRJNiHSbJDYpy53lq%2FKmczRL4rQkS2MVqBGwD3NZZLSejKXO8HJsWS6lfDLy8oBVIgjXlM4zrUqIalKrbIJnWX7gxPZPoMZAU%2B56EbNGQMA5VPDU9ApfLcGKKov0G0MhorJE%2FbCv%2BDhndWCyI7k7jtgtazSSe8pCs9TCNmXeXxnj9WTbvB0ue9Nd0eJTUzdGVYzG7kHcuM5Xl%2FnaqlhZE8u2preKWGqL%2BgYmvy7HDm4F8EzYDNtKWM5Exps5DwBXl7Mqq9kQ7mXC%2B3ugpiQPEueMNhYXt3YjM9kucrbbT1q1vUaJlpLcXUBRpSOyfb%2FYss49aSU3Nhj43W0xAoqiwLaKx2l0uhuryEPut4BaROoDlOFSDDjXRmkjQrB8BEeRpRyMrBsDwoL8lZzd2K6QykvH%2BeSp0XwamLEbvLa1LkVft6S40qV1LFXOis34riXFSJmcOE6T7ZOXtrN2GrO2b9K1z4L5Fb4oE%2BVLSLHVl5YeJzWNaQKVjtwu8zyRiRpCAyQw%2BoFkpUUWDFbBlnWNHkqmL2VhxHShTTlPC922JexLPaXgzXpFJv5eCp14MTrbvUH%2BWI9gica0DOFbhQxEEMO4o21dAx87XIWKzBgCAbwYEcVYWqlY8z5XGhNt2uQVRdOkVn0qTGJPbuR%2Fp8XLm2LTW%2F7KJ0A1gxMNAFRuno%2BLh4l34i2hZ6DH%2FkAyplaVVm30WOpw60ZGug0V5yDJJfjtiFcQQosvxpncSRafyoaFXT5o1l01obLuYI3uMcZsQeGYfBIM4GhoUsbpJuoQs853zYBh6HTjaJ9TxoIB6aZQU7oCGxYrDRkpjM2O0UYx7CKjpM9JJTWgm6Q2wSgZiLNrtEy5IQIJWTBvwxmtkqURTNaCVU4cg5oirAdlYdnCdoMICCI9xaug%2Fh7myP0D%2Bd8Og5yRteexX3IbNBKgHWp1zHoa8p4Lu%2FPA5P0TpFPDDmCZ1V%2BnlYzBmrgTlgQNkJLp1lxS8wtycW6XtlgwGrw2%2FejN5HICJzHBUdH19Tx0A6vb9mMEyxBSFM%2BzGsR11sUN%2FkuOKndSCrsd9OyB8XJ01p4zD%2Bm%2FeLsjFuN9Av52cimX1Bgq71KNL7WnKRlazHD057DpoZFGEydpIXfh3A%2Bqvxi0oaq%2Bl31YMubDz6WeIxmqmhb12Hm9tGgWpnfCPkzjTplElR457RnWkMKJ1QJP0da7wnxblLCrHCkho1J3mX96gA6ITIfWkGIOSPM6BZY4bGuhJGbTjm69Txi2c2WDG4MNnQH0Doni%2Fpa%2BeVjXCYjsj4RYg4hvMQJjON4RJm3cyBjWEQJIoOxDO836oQNqX2gbM9LCZEiUlCIYyiDPBkAZdX7ANZzMv92vn3b0jTZFbY1kvrV0RsV5Kv2ktHK19mfBLbd09PIflDaaRshdSal4TSIvmLGT6QKCRa%2Bz1dBisAY2CVimm%2FGQ7deOsxOK%2B%2BbpXJFBzIQy0OR3JJFFI7wClRCkxAJ4w1b%2BZ9fDyCMlugBY0ogh5xqhXIFZsFcMuYek9fyILz3Nxgb1JM7eH0J7Jzazqp67Msis1by9KNuIHsf2KSgK0SEdCvBLQHiLuQn4pdbI6DJmJkJktySDcJJxbsWarFGROOsYd3ewtXnG%2BX3APWoJ0NQ8BQQknCSI4Kb6qUx%2FcXNw61pZI2BQuC0UikBZQG1sZXkejMqwVibDbxuKGt7DagmydCvbtgzhrlr0w1t%2BdQvqCNJ1S9p2DAf3h%2FZH67r%2Fy186PptJJlHL5HtTq9yHWfd%2BUDVC7znIHuu4ArE2kTajyv400sNbYxzdWR0btCNWsNF6w1rGULjQDIzccp6hZ2flAQIPCBy80rWAu0to2zKiLQPYo4EKXbJJprR0psn5sVgoPWk%2Faanu%2FPB8HdzQfSHqK1WhV2aSISuZYaJXvFB%2B0nHcVN118WIdUtt7zlF2XW1kdHH9ZeokpJEINomYjQS7hpsbO1rDbN3t6O3px9KCU%2BKDTG1jET4kQvpWBnGx09Mj3KwaVX0wMHZrvZeMy55ocHextgvW3PliLlgzpABSLi%2FxR56gCk5oDu0Z9FXLhVShr90m39wmTZXdvbwsW88d3yztqVkW1VK5VrtM7trMmyxdvfxWtkea3i7tr9kRlaPlkklODRE8CBA611oJ7kCWI7eCT7T8hUAHcSEyyYLv44uGiqqHq4uHiiuHFeoeKk8QJW6aMV8%2FPRWBzq9RrnFnJlnCrWESdhbCmm8YDI7kUzkeBdGMPgdxjwqZlj5Jvoz6c%2Fk7OSrjMvz3t9%2FEL1HyhP85OUlU0lJJtOf%2FbQgUMkzngz3XfAJMdGdrY8pvIu9c130xFE%2Fo7A0tUk2G%2BcZGBdnXG2LtUmoTsMcO6Vvf7g%2F7Wtwqne5t%2FvuNYVQVIoHNbxkvFaUb4B7oJ9%2BTfcP5tdNm311xV9Wrtys5M2YibJU4l%2BbxxSPBPw5doxRoimtbK2N49mPG1GIfvAw%2BBtePyC6tHI8v90bcoU%2BiEzTWxwSzwiTayM8ozjbeSdCyfMu3eWCnuK%2Fq2tRRmEdro5zHoR9oqL1%2BtS8rFiTpx6qHCXedCoez3YFz%2B52f%2F6bnZlKy63HGrz77un8ChM8bTiuTxP5%2BS0ivI6cQihMRRIhlpH5h9bwZICFxfLX7tV38G5ukRNb63ufZ5pfMmX0OJTMxI%2FSHrz%2FQbE4Rchfr4Fm2Ubcimn5OU%2FvZBJJxyWlFsVhkRlaWzlaGLp7Edg%2Fsl%2BDjoCGPRJv4KsVp%2BETbOBB8tE3xFoNuPR5ZTcvOfK4fzv5jZ9Jz6bSNXHz2%2Bd4xkDyvP61KxqglIa2xJDm%2BKDGupdDTxaw2cTfn42hjVTncsh3Cq7UyBe9PeD8T9Ob%2BJDVTtmeG7P0J1eHbpadOT5WkaH3Bt5duG6gWDy0NKXq23OSnTksPwMOPUb%2BUwBQk3Jbsax2LMQuA2Ue4BHm2aCIk0QMbkW%2FvHM%2F1wOWjnYNC7d1hRp5IxQujqjIY3AZWx9ccFAq3Mw559brY5aI1I8QWj%2BaEMqlYF1u7tk3u3975AbyMGBeA8nLv8TUH2rpvNvblU1Lkdz3QG%2BiwOABpaoOefXRp33f4gWso8qd5UVnw6Pch6vYkAmLscja2wC7B%2BOEIllrUg0CQK5SLKv6ANKep1047vrmFpxp9VQIEdXJGkra9%2BhweUmIamE3N6EnkZqgRKuktXeZ4%2Fo2N5avrSWWeBy6g3K1113H3X2U1LglXF9ZkqXb5b%2BdcnIL5FecjzE0JjNB2H%2BSxsVNm8JtOB%2F2RB0czGIcVS1C7hpSjz1mwcripAdroHUxG3G935vNdyV42mT%2F6f2z1NxBF0mvSmwjD%2FvdzTje6%2FvwYSOuo4vkFnmfIfREvRATkYr0rivyOt5zQK7eQQ%2B9YJf%2FLlzwn0RlCCcp69mLAJ1rLPubr7KNjq%2BMn9WtVPsZ862guoztXQMv7VLtJO7p%2FIYrcA%2FKNigKceKo2k95xXuGku2wpCx2zmgsTh7OQbVFdgcxlOjbWD6uHf7RIfr98WgGJfNS5%2B5N7YQwYDTrB6CUjZxVAUuGykI4awjxRe%2FXvJw6kcD%2BHlodRDPnviRpG7Zm%2FXz4U7pMbHOyXAbfwzTNfwLIc8jx8cMDJzvyQ%2B8Gjx9wysLI%2Fx%2FJfuavxaNvBwfbi4Iw43kfMTalJbOvM%2F8POsBGyYImJN%2BGESpfSVl%2BQiqWzqyKRkNQS0tbYDivrv4sGQdZ7D9kF8fXZbBioGWShcIn%2F2dVVA%2BKVr9KRpndRdogbKjFqwXrVrm23dIxq%2F8ndXTf44iKyJjrOD62rbBcGLdJrNqnAm5M1Jj%2Be9W%2FDt%2Fsl0SOjQ62kL7TpY2yKon%2F6PzWMdPX1o3zrJCGSo1diNKN%2FRI9Hv3NyFvJCNLeimOCaq6xyXl4ANWtG4JXyQ8smhc2XrOJ%2B1NNP5g4vmTntVba46hns5ffZISyvHd%2BzmrqCYqUuWIp0njJTob5AvnOGOUQ6AG%2B%2BLc8xIGXmJ4JybUlT8rWgSy21CJ6o%2FUlZBJ1DreDM06nEZbq9%2FaFbycz4SifS9BEgfj0aBNzWAMuxmGbvs6Ra6e%2FEgw8ePXs%2FEBXiETTtShBBdy26j6iNSGurguNy4tjlJQ7N1O%2Fe%2BcnNLmmePjLEz%2BmuVENn69cCI7aNDrT0%2Fb1JdW2WRj%2FYJzDQoU4Veh3e5aL0QMXz3sOx5TOaptTaojSvQpoOmkofrJWTnaXifezuiTwr25nS3l18JZtc%2BiDQcZ3jZK%2B1cDNEtNfPFSV1UiyxbRCHycmpy1MJEH%2FO39QSHLxs8pQD%2BRCL6XJdb9HkyaJJUkO%2B9fabIlEpIc7dU1TcO%2B3jqGYmtljzsovZ%2FyjjMiWMke21M%2BSMVorR6%2Fs5A%2BSkrLXJ8bR5CImTEqRAx8qsefHkL%2F0Z8SV1c9uNCp9uCS%2B5OQeZgev0S2uR2YVMOd8pcokFUEX1Zpbmi%2BbR8BEo7M7Y9ExSnIzhLUdBWzuYjy%2BMRd%2FsDSptGlR63V%2B373xpV7MLrgSWspD0XBibqSub1tyUfPW%2BqRybSsILvDZwVjUydzCTdZAI7owcfrV8VxnLVCni9w%2BRi0yanwpzg2ENCob8Yz1o0dDA4Ai%2FrcehftEB2EA8LuaiOxWbHFlOGtyTPGdSx%2FmejCGsyra9TrjSCvWyc9T5lQTYzBRiVDcBG5iZGUF%2BtbS0zoPN%2BSZN2aGVvffOX%2FcNDVAH%2BD53Y0qCZnZY%2B7JOPz6I5fJ5kxqUeIa46OwH4329sio%2B9DyIi16iZxI2N2VwR%2FocNS5WwqRo0%2B8Q9B%2FVbCrIW274leHV7f3zXqJXEjYvpfeWBZarK%2FIGdrP2UtVmzCGyqEIVeleelVv5qu59PpHmJjOn4u9PvBpqSFqiIB8xUaA8c0nmgFMJFBbmfJHlakuNZlP4opnCup4qSDPWd8psGZMFqW3D4srQS0LG6sRk%2BiwY01We2ntTcjvzdnlKxupU4uLU9qkCC8u5ym5gOwLiRMdfsoTE9cUDhWvesswB7RDFciz0kOexoFZh%2F1iZCWGfyyKLTFo%2Bg3hxnc%2F6rec3nj7LMtlcdOk%2BzJD7EabvLTlrmV0WW%2FSmfnnppg18cMiSMBms4QVtNcrVSHTSx2mY9jg6CNzyIvCY2HjZVwW2ONiekb%2FrD%2BnbOdjbGQ43uq0KYtgpen15dfPe%2B15iQEoE5zqSvkCptAuYoa6O0nVbGH3p6KAGM9dzwl8CfigZ9SIqfqSpHL0u8%2FXIUgpqTj%2FUpwIx5XXOYlp6mMz0hy5zylbzI4V1bToWgtbTIrELzkyUUYMGTojpd%2FrfdAa8ULYGA1sDawODOgo4wqllscXQZSvXH9f%2BEy4%2FTnVWtLFkm4Sb9ZrdkQlQz4eSQV%2BZmYe520E%2F1XW0RCYZ5nLSXTHa9Qelh6NR1FgUSnb1jRTTG%2FF1eZQ%2FGkcxdkKxUd1nLlzJNgz0n4e5djjrV8iPKcY8gCDGnTYhKIPAxfRGalUW5YoKox59sVjdL%2BqXgk6eS0y19ze3vK1G0N%2Ba8wmpMonhd5JI13LRSDKsmQ0MJxsniaBBKVqQ%2Bcx%2BKvWrYF%2FRsbKytnLvzyqW5nA0DIawkzEc%2FBCrR6JerF%2FbEVnl%2FfVvTXhbtLextYo63cB8iqwXWJo%2Fs7BYfIsEzxZ2lLCSl1xfHEbCR1osCNtPLgtvFI66GRNtFS53WZa8hTEZkePTN6aBZ1%2Fdc5i4GwYOyMyMj01P9TXC470hmenx0emZRr74OCPv1NTY2MxUHwNcirNBekrs88lgny68T06mh3dxPguR443JzdGTyBCGVF8W%2FXhdxV%2FLX8N%2F%2BfJSsEawVrDqKO%2FHdzeQvkEFhqeGhYYl6Dil7RDpMDkyqjrtMXnCreO6j6xpC141jt9wMUwrzCZHrd%2B0oj7sFsmZZFtcdN6%2Bdz%2FL4jZCek4NeZ4hX%2BGr6SVZoJXmbhA95qWobB5qmq8dCgmAJ2IbNTzNXK05HOKMTLRUNN9ra%2F5fqpjo5updqv5qaxkbqSefdSLa9xki4pqLykIaErWThe834tTilw8%2BPX%2F45PsdUo45pChIS7tFeW0Vg1nfWMOsrmM2lhdcMLt7u5idRRfCcm83SLyru1e8t1Osp7tbQqLr9VEX6%2BgTtwCpswh5PYzRhEZFBgYHdoV30QRTwcyg5q5x2pq4YvNCUl5S8hyFvgVFKFjV2cvNDYmS10Wq%2BA50Yfinxq3Ly7d%2Fgd9vFRUAon%2Bw%2BvXLmrIDQwmiQ%2FviSkuU5lZwc2MYTMfWtDqpr9rwouDenIur60wObX9Ljgm7PqY9x0CwXEztTOy099NyZhbzSTNzpPy56VznakenqmpnC%2F8AKyt%2FLBQR4A%2BDBQSIvq%2Fq35xbNVz1jVhIMbQ%2FpN1hic85PoqOgATpa3xTx4Q4YeJJsb25lRk4tFtlbgoptVBaxv413M7DRgrD5RFmTZzIu1meYNhQYpN8Oyd5FZ8VNJ6mYaato%2BslnYmO2ibr%2BWTXE3R52g%2F5dczj%2BxTYuQ125i00OEs7%2FjwuzbMNXYxdL2VWRhWhAwtsXKjlaW9JQEyhzbk%2BNIo6D%2BiIc%2BufW576vv3Bxs%2Ff1Id%2F35opZt711D87eHuYn6uahOdhzLWOFB2G%2BNAd1TJOtlwuHoqclpNAxlK7UpzHODtF8O11gRQu%2Fdr7ZxoqB2bbegYnaqoHpj92RFiHOTvLRkRZh%2B5dhUqacPBi%2B7u8BNwEMF0Y7MAiv%2F%2FV2fxu%2FP%2BR%2FAck6a%2FRkzLBwcgKf9tEb0NvuE0IJsS1SwspiRx6Era1ezrbYykb5RAQ5YKBG3rZKn4Aa3gCRvd1mAz0YSqAfOXVVMV3Of9R5Q39Iq41rk19BLmmMS3R%2F%2BHhO7w6CySnEsgRpWulxFm3jPjfbtRXdJfLY%2Bpr6p3NHFC6qAHD2l1z86QUqDmsGxBglmZQQhLM3PSTShLyNZs%2BKLPD5BZgvIunlhI8RZertUiX1EI3n%2FzFlb8RL21zJNpQXvr5XqOt5kv2U%2Bt0idsoN7380FGwQdyEzpKT7rX4V%2B5u1eUX%2FMevy0ysL47eZU31JRcQ6wg32i2g94%2BtEJnGai5mLkIii1keYDdDRw%2F5CGjHg76t2VDIanmLiul8laGZU7xlLCwg0R5sGmihYaUFtleHZdlFELNCggrPyQvAXz%2B%2BpOoypqV3DC4GN77cuLo2RYNYXC%2FsQFp2OCntqfh%2B9qmNq32185XpDXGN3lZ8vM82YPmA9l4PLzgINQnDJM1jyB2Tt7%2FW1nUmFZcQvbJpammKvfRM2CPTSXSkw%2FToMvwSrL8YoHe1eTnUf58Lsx6f0jA9fegYjjecbq%2F7WeGUuRnroGcnhybnG8XYneQ5pU5FVuU3Jn7kIVZWZFRltTXWlLXklWeN2IGe8IzXlF%2BhACqIkQXEEAwFg00tdQ1MLP5cixoeQNOSIB14aLYLMrqwlt4PcFcSZWTmm%2BNmHZJdpYYEciTQ2UqjTuHAttRGE8SQ6TJ2jny2xC4cv%2FqCgUOrTfDOqSIz21ul7Sfh5SzXoDRu6%2BeAD5z30%2BbJ8QkUpbYNSfoIhf%2FSZgmTxgye0XMGnqhBYGN%2FzjCIa25woFMWGI%2Fh0duAFAmuCW5CIBKaew%2B4mZnv8e6loUGALeLocsTFT1rIWGC64NWkZ2OX%2B5aw6W3smb5w9ey%2Ft8RXDG3lPbXYHglPuTm0dD8IXgqeSV8oLUyfnZ7PmCUXp84Yl2yFZ5MYSJ%2Bzk4sjNPwOCbDAYCw2AdHIP7tsFEhtFDY%2Fzy%2BjPjKNTU8JDSUmYf1TksICsxMz%2FdXGlZTH1YJDlEblVDIP5exA1nKWIBBSEEdgJKWTsfLIXxzMyVYAl8yYlVaphlyZdZ9l3w7HzAPnH5kSvTDCifLn14zqBf%2BvL3l5zEePNfYIzL1mYiL3eEdrflrBjEcaG0mcvWbSIltnN7kL3HgG4tVsTp8OcJ%2B7u2HGcv34FJT9UOtBPN0NYyrxz28HeFDh6FdZNv2clFFMSMgs0XjzcrLK4uOzSjhHD%2B6RAvRXDeXu4QF8GB4TM698Mt9GN8kandf8xaiA6uW%2Fwoe7hHvWah8JPeCprskBaysUVxhuphv0fzaa4t%2B3PcvlkqSAXFZbKflL9fHL2t1O6MkaeJR87jn%2F%2FZ%2FJD84P5hLzTabVkw2HvGl8NwrQLDsw6teCtbCAlB1R7swPsJrd3AmwKsJXKHqvFff%2FxywD%2FgzvO%2BefVFrZFX%2F4fin7bZZonTwL5FVJiG%2FaJt4k1FXoRG%2FolH7oHIoXjlkonRf3PmYadmtA7%2FTMgigj7RsLyFhtEDqNn%2BeOUYsqmXxDPtX7byMOoZMkHTo1GTpH%2F7ljm6K2gFUboRMfwqz5OHesWtRn%2BZyZaZ0rtrkd8AMmOw6YfjVgzmcDxr%2Bf8uK8MXONTk1%2BMaig5QEaMDl0wBQbJ8Zm6rjfgLQUOgm10Okwce54WIzZFeVdwYes2%2BaZqwGT4wZM5x4wJ04ZL%2BhzOmObJ6A2dfmCddMV6JTxaj63%2FpOLxi8BGEyDh%2ByQT1333%2Fnc1cBA%2FK7abqD%2Fzv4%2BmokH2rCS50s8gNVyKcx6F2HRp6o0k7L%2BnH%2B%2Fnv5Yh%2FIWsNlpACwtZKucxwDQbdBGKQG6bZ1HO3tEW0ePpW3f4xGABYyc6J0%2BcPFu27QAKP9xKoDXKNEuTFUS4qLdowqIj51tZNijXwFQ7kR9ljjXx1CpuxXo9PaH%2BB0m3wU7cNFwxQKgupzypGkXMQVI99NV9YB8gRDw3AOfE7qvlNINqBNpyBWTU8wdHwOGNsITVt4AUEBDagVkwHKxOKBe3onCf8bp%2FQn%2Bw4PdGi3iFyB91OPdBuTb4%2BQYoU%2FAQ9H4xN7IH3f3MiNx5Hyw4AZw3awHY8l2awYznN%2FZWyEyOTc0IcVRsb%2FEKeyWUO7sdv2g08yQVTyG2fcUvDojgu%2BGZxuJj8rD79ucZYGRMkyVJI5LmhWjzmO6ZwSOrORcVxFesHZYhuXR2GfsHkh8Bq2r3MRtA%2B5SDGXCbohCu92u12bYcny4R9uizqGMGeu2HZoPbTYGFPHR2snMjWYngrFcYG6A%2B1Hx9RkXu71mD67bJ%2FEUT06Em0mR%2F4DiXZs5127bdLBeGhjMUK6HsWAzratL%2FWyZGcNBrkCLtzEP09XJ8rTu8xkPoYe6n52civVZ%2B%2BM5mc9X%2BK2b%2FL9vu5T3Kzy1nmXlJO3fJGEHafb6N5itdVEejsDnh3h8urT5fCHG0CzzZrzgd4dZsjphp3Oclqhedae2Cx7r2B156Q6fMK9EA4ZJiaXndz4CImHHMdgEtq3DRkVOFA0icArejq8FGXOPuMixh2%2BfI9WQSWj%2FUTs1tO4nAN%2FdVAluu3YFxpgSeio5oMO%2FiTUlDmjFgCLCJLvN5qiBkHij7%2FOl%2FIeiphD%2FdYC5LCAkOfgN4Qq8BaZZSQAgzdFfgoZHaPmZZAR0DoSJ3ITdTi1b2xakKhzLIL8i8Kh1CiumGbJ0oQPzgRFzYsOgeABesW35qMndh15WU1rXho1aE14xHr0j5O4F0q1fGgvb0vrcwdep1wCwlf1ELOboytK9SFmG02l3xdQLe1tCIvKwLdc7Q35XnYBgTcaTcwZaU8Inp6Ct%2BPMlavaWWovKlMgUBrWa8RlYHDY0DPM%2F9UzhXY7%2BVrJuBOYKAN0V1QsUQuTfCAJ0tXdUNWYShgAy8HgWZklyepHjh3ul1P5AvbW8IiMfzfbGFIACTsgbHJD%2BDkV6QyUHkaBf1%2BVYbM65GY%2BXywjg%2BYuApbuoEaGPDSJByvbHqyZSwoMFMXF%2BLNWm%2BhdRira8uiL30P8h6EpIk2yjHFvDwSXZyyRatfgVr6yuI%2BmhKhstloF28aZiIQ0trU8%2Fbf369%2Fr3DSpwOQFkmh0a4Xf4ZD2l%2FxEjsAB8FlhmK%2BYBcfAsf2MEoW0UuZIX55PJMN0dBlDq3y%2Fbl0K4E0X3IuufYTFuG%2FAWSJaWLebMOQ3wXOvwMc2m3ctMU0CYtaKG5QewbeCT2Se84n5y6wyStVicic%2F%2BfvSNMZvy4UMWpXf9Bo%2BXsB6UThiKgF2VhZUvx10qeAYjRsfmc7OhFb0JaLwAT8nJ3OtVDqxg9a4y1kW6rhXzqfGziV9pXWFvpxXA4RKgdlfCq28Fi2e%2FSFShbVhXKVxKmdQb%2BQ%2BB69fLjlkAhm64vOHI5YZZIzElZ6AxIhi43ygaboRA5%2BSGIsYbYlsSgaEUANmQYsrHqbGJVB3O3BHHC6To%2BZY2WUlTn%2Fq7mIkUNNkWQFLql0RMdoS%2BmmnrPeDAZywBEQRy8XTj%2BxKV0M1a1pSR9Co1JLOakgJGS%2BCZnsa2IhmJI4lQogqc5CqcfL2VPEta1nbst1MRBEyRgJb9ZmxL22HaKKllhcB5EdVQaJdTG6AmI6j6aZbwqgWTA%2FUk6RowmnkPi0Xpe4DoPYlI4yKZf71sKSYIOFRBfknAqN1gyulcoCBho8CWRQzqtxeZTi%2B9xOOTATq4tOWMdAc6BNboJrYRV5fETIysCJzIBgZtnnUnz56SyuZMZym4T21Pc%2BYKG0BXrwHIa2SlL7OkSjYks8Pg6l3sIwmPllsH7OVMjjDPJeXhOcNA20zYdjBBE%2BYipeBxesh0w5BAy65t%2FBSGJpH3uFgToFR1qxo%2B9s5GGgCFkQPVEgiYaDoms5Z99AWBQxj0PONNG0vJvWx5N9K8xPA%2Bk4iRc2ZyRH6gBGoJhGhKzMkt1MfkS3Y0RFUscmP0q%2BEQ6g2YxYlRDCBoJKRZbFfk4HkHjo1TNBYR%2FHiOziN6%2FY509ibuuqnCQBEheEVpzTUGf%2FtNlykCEfopFysImA4eeGCejzOhWqUBqBNNCzDq2Z5tmKr5ALljdFCMkSI7%2FdDHFOU%2FgGv9zIuaj1aSc99MfX9tcDGnfC%2BPnkdK2UPu9AGnedt1vPAuY0bKawMPNwtKg%2FEpO0uJLke%2BEZAhbZBdAF00bRXFYaJrh9ijsrNjJD%2FRFSJKKWvQuWrvzLJdoV2AOddHTGq4KDAg8m0Tdfr%2BaSVRtlOFJXYNKQ4ctWV0IMvVhGosSxC6HUqYkfxYKbSgRvOLZiVpnGUedQS%2Bsi8wjwh9hggEV3LgZQq%2BG1qM3q8RrW2bx9OSzj7DtzPZb9LTCvhS9TPxxTPx%2Fa%2Bfx%2Fd3i%2Fa%2BUl9doNTVYvHZx9cWekmfs1TFuuuKhjITF4eO5hYAeyonGBBoJYQIcV%2BocEn5hVRHgHGD3bBT2YhNBPODK0NgQBw67r21R%2F%2BpJ%2FWD%2BpG9ZR%2Fb%2F2zIrmExuvMyqp4NC3vUT8OwEJndVcVe071e6xf11%2FWn%2Bkf67%2FqFpk%2Bo%2BwqqFoEGyFQsh0PGLdUZRZWaCd0nYrEoXSXemKNL4JoSW8tYfrSiwjwv7ICoyFCgsGqbFACbbo%2FxHmfTLA5HpB6m8hE3eKxwRgtq8TDIS2R4h0tgflEFIqx5DPM8BqMjBR6KbezYG%2BDBzoXquDLUqPousQgehNLh29rJeGY8wQhq1RWaMOghdg%2BNIlt2Zposk8OQ96C6Auu6CtVRTcZ141RfSGu9C1ZLiCopw%2FXb0ryQooJO001cnCZS73jj0GG32W2tkDYK4d6AGIXPBcD7HrKsekSm0f%2BpMWYdSC5TcglPfqFxMFfE6vu2UrV5QCkFI5A3MJghtbEneGAeMSaL%2FNUvcspnoGDjyQ%2FWh9hmPczUIl5AvUtG6WfmmsDWBF4P%2BCw9KkbgUst8q%2FdtGHCo%2B5b3HcR79LegYTgVfOeGn%2FIOxjH0PRaHMQGKWtJa3k2UGJtP25vbMAuZDwjAofEuZ1nuQ8uDJ%2F7mwYbdYD9RJwPieIi4n3yK%2B%2BlFzD9Ynai0NLEtb2nZYjcylDb6dz2lt%2BiX9HcSRPFQRaETgQNDQweX3pptsuVHFEmYAHr4BOnfRo1lLvEMgO%2FxqJdNo%2BofhE%2Frt%2Bpf1n%2Bvaes6ZTjTf6TBCLPrWuG%2BSAQNE70ChjY0oCH2ObB5XnEWO%2FEkmUJJgIZ2AujyRq%2B4p%2B2ajEZHNDRAGZciwyuzyLaX0ORk53Pf24FtllN3nA27TnMzpHxMUk2jNyup2eC7Z9cb%2BNnvzLqhj4ymvRjXfpT2KqVBT10p%2Bi4qq%2FJFfHUkER0rCyCl3tkWZdULbOkf6VyFybAbS7VdM0laACch1xIL6vD2IpAHLeX%2BnM%2BUdzawMhqw74E3G17eTlmA1zFKuZjjzL3SCZvalwBqS4%2Fh%2FtCSyjxMWv2Tp1rGTchXAGROCDIkeOyqkY5UhDl44pm1e4AiaLxN39PtfHjXHTdnYPimeoBAkvZVM%2FY%2F%2BQn8bpFtTkTn%2B%2B1nPjlN29rZA%2FPxJzj7ue1lOQVMqEqFWwDXscMPXxfVtZ%2B7QK2u5w8fAExtqbWNUPksf5Qx52dDw5a30sFK7evxM9iG7CJyGbvG84bD%2F1GmVRQtIwLAnVGuCzM6%2FOf6Zowx072rLBSxOKUQuCjXlsUjXEVhqtdz6wQITJGZ%2FrZmhHvmlpshzEULFiRthq7NWXdcCG2fRtGJB%2FcVwIzV6A01pvYb90ZONjU7mVBkRpyu7od%2FAIJBXZu9kooYFO4qHRTYvOoblrL0RVyD3NAnGVrGkZL2hVz%2FH%2Bn8LPzZnSVMTmkeBStdkJxpnpMjIE5vtcDcVeZAC9C0dCheTDFN%2B4z8bJ1lQT3uk%2BDSpKpf4A9C0dvncAhJyMUPyPOi8OvKRInuVbAVTUKdYsQVlunHgXi%2FHQIsIImGJtz7KpV%2BlcDVTBjJZeLoYZCCiGOKaOnWUzICSKbFSvX9lfy0VTV3XwIeZBnf0jqwnmUTzMkCPmHBqZF81yS4idq0IBVU0acAdaS0BWKpvk66MaOAHZC5GLQ2j5hF4izrpM35nfeQjhJ29%2B69S%2FU%2B%2Fx4ldt35vm0n0Hhp2kzw9oI5B41uaET3a8xs1r%2FMbJyn5sSbNR3jeTvv0Yofw%2FLePtD6yvz7SF8k9B4epzzHf4v9WqSpMWFS0QOLAOZueZ6F8U0Yona8pDURMoNUpJcIxPpCBA8oyUCCf02hC1oJSaeRPLInpJxHyeXPcd%2FEMP2iYMC6srrKhac31vM4hHFJgLx7dQPrMXv9jD%2F89Wx0vA9M40cg%2BD8U7jVCYsET2MkVXh8O4Li%2BHplbkFHhup5lbQZtCOJjkxdT1xU9G1fK%2BpyplMtYwCx0HIqbjtwjE73sPdI0nN%2FHOwD8rzLvEXso2jcG4vCKQtoXLzPsIfSAZgpBrXBlby9WI52w24FO%2BjbG0P9PZwbiXCWnK0jWfsXv3a1m5nyVny8uOAfjDpjBoKnns%2Bo9escAxu8DQ2ptADz1awOO%2Fre931%2FGqmCru0WxupfPAeJWr%2Fj2oRpPY%2FbheRh7Ht8tnuPu3Wlszg%2FEHgG7j3VXPmJ6%2B0A3LWA3LEOqquWwiOxe5Xa57D06w4nfxxe4%2BT9d%2Bh6J70YmKW2YLh5x7n4g2xYmArSnJb%2B9KCqTaO6UWhm%2By%2FMjgoD2GcEXj4Ll%2BO%2FZTu3MZEwDillsyajV7wOTeEee%2F92e7MNChwyIOxu1XnxM43TcOLMmZMT4HRoYhnI9rO0WG6vmdW3WQvZIU0xvJcHjxQM1joctFUUYI90%2BNTYTIlj%2BrsO%2B7IWcec1U61q8rtfmAQ7QDRZVDOtg1K9W0H%2FH%2FUMdOr6%2F9wJaF5MY2pKOSgE6Rmx8pOzLZRlTMjxDEb7gC%2BKykqTYdB3amioZqUWznp1i%2BnyVZdOztPO8pZ6yzXlMOX7IDshVu6IaVysWtrcDnLPC%2BEobanCPAGbovGy5gcHkGXXOVC7R9E9obwa%2Bg8ziJFMtLvwnANdN%2FWwTrHTrSphCwMGpbzdp4RysAwwrLmpcdzAOvk09f%2FFdoYEn%2BN7%2Bv9%2FTlKY%2F9OFa%2F%2FWa%2FCnWejOwp3%2BAIAwI1w3lVnayF4iZBA98PhFPtAJRZW%2Bsm%2Fr9Pq2BHKqq5BTf%2B9W9GIQkFe5KVBfPK%2Bs%2BayVPRsfGzK1GOlVQ%2FXu8AFe%2FFZPHET88c1gH17Ogbb2utFIA5APOpo3C8z7SOJ%2Fh78xmw8sREdXxiZenCML15uCUSkQAx6GXReGktYLOHehj5FHoZvLRvkv0ftdjw8NRNqOpt5iLUTd6CVSnvlt3v%2BxYQCcXlK58CYl7kqFz6WQCVyZemvSsafXJLg4HlcFfy%2BZLTnSvl5h8MlX%2F7kCeSps8IJiMh4CqoovVXDQMUjd4%2BCTxhjZAyQcMgzmtCMfCh4%2B4mOAoJvw4OC0W3qU0x6lHvhdAAACPxahdZ7c292Q1%2BEZH%2F4OS%2BRPiXTLN9RYR%2F9v%2B7ywDL51m4gcw81NTjRKjq%2F%2BvA2aX%2BRMcEs1%2FOvOat%2Bu2hZG6MCB3V20iqyS7bvKUK1lEd8y%2BXfBKX2TlPKiRYlh9WIUbeWVx4FwGltUjW0SxrVNn8tR6XD2OHmlPjMdDtIoJjtxc1gVOBxCwrsPSjK1XFtGsAG1bC41DQnsRiRrXcSabtV0JHaWbZL%2Fwa8KLqqNg73NyZ7YeIaFeAIXdYPnVHMLtk%2BH6C9BfjwnNqeuzgHoHk9yutlQA9%2BoVQbhExJ86nYJrO9f6R3f5DjsKF1ffMp8Sr3i8jUt31lcb%2BcipZX64u%2B8EQ8n6mit08xMFn6o%2B5lMkSeNQGysM0F2Oqwbir1aA8iqzwkuxBqbDfOWghkRz4GlnJ8L0Ejji2UrppLK0kl03v%2FyFbhkMxQeaw%2FXnqUD8KmHC5FPqnaBYR0kT1t0MRemcTZOAkGJfmGxOil3XzqDzKFFtzZm23uUo1%2B8Y%2F54DpL%2Be1rRDypqbIlfJMhzU3UAI9Le0jL1ujcuZYM%2BPTI16AL3pFHnqIW06rU9gNTcFfD2x17GqRspXK8DzAxx63pRKCX0%2FV73pdW1MXqS6qIDdR90lKR%2F%2FZlkSuChCUAbJF8q61IWy8qAOeTB2p6fhRvk1nGsGmAAaj%2FQRAwOCbXc7OcqPf3Si139duThdJdsiBxG7cxQkZF%2Fifll%2B%2FN5%2F46LRf%2FHIQiAvHUtMzFlCrNk8ew7iSsyTBDKFSiuZswyVzVzOyCsoKlWmKlBVU9fQ1NLW0atfVgMYGv1ZhIo2AAAAAAAAAAAAAADA3xqjh84Oz8Pw2idf7iB0h8EbYRib1uI5hFR6i5bJrWBt01bi3P33NIigCABgAAAAAAAAfC5nEUWu7%2FPA6%2Fs26ZPvCxrE7yjSGFvKuZbGYqyVYzEWY9GW666d0DvSv40HGB69pxh3EHdHUeMmoaa%2BGcK1CLEhlLVltRd9J9tdn3v45IvGhVR6iy09yyVJkiRJkuTfHm%2F90PMgssij97gbm3NAhAll7RPeCaV6ERERERH5vM7CHa57vtZr%2BOSLwRua0cgY32mcxgtIpbdomdwK1jZtJX6UYneOzZ4ZVVVVVVVVVVX9fB4M33h0n4ZXdKzcGLsWESaUtU97J7SizczMzMzMBl2YWf%2Br6ffvofdoX1Nn8IT7POi19cmXBvFrbtB44awIQqKvKcychbJ6NvYc2XIhIBokbp68ZSUSKRkphkpLRz7LLyAoJFKGW7b0ciSvoKhUmVUFqmrqGppa2jp69StrAEOjxmiOFmhTZVvqoMo742t5D3xeJEokkSlUWgfu%2F8%2BBw3sYPve5PT8vGK8Yi7EYi9CEcCCQ0ZFMYM6CrJ6NPQdyITFPkiVTqLR0Vj7wCwgKiTT0zNCC7biez89CKiCB5Obg7tl6wNPL2Rt9FX1%2FSmNcAQAAAAAAALKi%2B5EEAKH3AwAAhD4XP%2FjCRx6c%2F%2FULRPwQGka4RSCjIzt0xsPF4nD94vAFi9%2FkTUjMlmTJFCotnZUP%2FAKCQiJl8pSFnLyCopKyiqqauoamlraO3g6yEfEXdW1hOuCdbdcDLMsadD5%2BAUEhkTPvHL5%2FvtsoPNmfU3fIPS4IQG6evBHj9n7Tvjz%2FkDWe7M8pUo6IiIiIzvsS4cl%2BjBj4hv1y8wcBc%2B73ucfnHpl7GzMzMzNz7k9NfmNMO2TbtkjRQERERGqaqqqqqn75v01%2F2n23Fw3gCGQ0K4vPRjKycvIKikrKKqpq6hqaWto6ehbti3sn5HwdcXJyBuoAAoM8jB89geTA4CxKBIZoKQEEiUCQwLY%2FUAiAQBsAgroBAAAAAAAAdcXpdDodj06n63s%2FPngF197nw%2Bvd%2B4QQQgghhBBCCCGEUX6EEEIIIYQQQgghhBBCGGOMMcYYY4wxxhhjjDEhhBBCCCGEEEIIIYQQQimllFJKKaWUUkoppZQyxhhjjDHGGGOMMcYYY%2F3c469l1mo5tZq0pmmaptVE%2ByXUb%2BuPv%2F3rqf6N%2B3Tcwe6OVuMmoaa%2BGcK1CLEhlLVltRd9J5vn4ZxzzjnnnPNB2YJzIYQQQgghhBCDsoUQUkoppZRSSikHZQsplVJKKaWUUkoNyhZKAdfr9QAAAMCgbAG9hYUFSZIkSZIWZ%2FmAR%2BMVEGFCWXvun1OgZEmSJMm2bdu2iSciIiIiosNVlvZLOvZ%2BAAAAAAAAAAAAAAAAAAAAAAD0GKFhaBiqajRhmqZltUKWbdu24ziO67qu53kecx7cMzMzc5EmhBBCCCGklFJKKaVUSimllFJKa6211lprhwQAAAAAICIiIiISEREREZ3jYV18zi%2FLMTMzM3PZYxARERGp2VRVVVXVzMzMzDoHSdCxaDdS4H0kPJzQyOanzB2Qis8u%2F5ru7T%2Ffos5IVgbM5GzeGcb1xc7UrDV%2BfbO41Os7K6re03ntaZKtSP7CiUHzFg4%2Fd%2FIXJoiPCKH8oK7kADEmTMYxnjFfPvWzCo4YRbzcErIYk6kY5GVVKi1zTB%2FFCxKRmFGlFOSl%2BOkLVpQDRbdXR9Kj7ItTlHiL7KhvhPovKRFwArAsVFC5HrwTnjIES6bM2UDbiYrUKFG5MNxwYM2yzar3Aelia89QNZ3eyIxZv8HxjTev%2BcyPHQdOXLjx4MWHnwBBQoSJECXmOhBxEiRJkSZDlhx5ipQoU6FKjToNmrRo06FLjz4DhoyAQRgzYcqMOQvQiwB%2FzlmBQ7Bmw5YdJBQ0ew4cOXHmwpUbdxgePHnxdkObTFlmVHorW5F8DXq0JypXJGr7cd8wvviqUJVcS577rFGvby591%2Bqmdav6%2BfBVws8mf2s2nMG6Z8%2B%2BAQE%2BIXvovgcCnXsvT7AgIcKECtcsQpTIZ%2F3zN0a0WHHeiUeQIFGyJONaEKVIlebCB5MeGXTLgWcODblt1Jg7ho1YlqPPrDnTicaPiTb1aZRmfktlgaxt15ZtOzV8Ehp6LebYIBUVYzP6iFP8cXjfCJw%2FtfkEF7FptYWJiqqbQ40Je1wMDh8T6Y8LisBdiepw1qB8b2%2B8sf9FXw5HXzoi3Zf6QzcfHVHdrnvrhC9etP0LV01%2FdVH3x3f1l2bTQ1%2Bl%2F8%2BMRVCxg9vjtn980fTpYL%2FEEb%2FE5qJlj0ThDt9C%2BgvzhDlnlpqmWL%2Bw%2FSN09twFkYfJl9qh%2BVIx5F8yRH1JD7Hy7%2B%2BpzxZKffweCkWYEMK4N2fhHop78QW%2Foiq8vOztRA8%2F3ePRMMw2In4zxPY7wEdHjdp13Goj%2FDgkOGl3tEN8v%2Fjw9gaL%2BzPMjmqI%2FSbD9Z%2B22f2uLBLz9GkYTj199ixsgIk%2BhT0PdCtVpwAA%27%29%20format%28%27woff2%27%29%3B%0Aunicode%2Drange%3A%20U%2B0000%2D00FF%2C%20U%2B0131%2C%20U%2B0152%2D0153%2C%20U%2B02C6%2C%20U%2B02DA%2C%20U%2B02DC%2C%20U%2B2000%2D206F%2C%20U%2B2074%2C%20U%2B20AC%2C%20U%2B2212%2C%20U%2B2215%3B%0A%7D%0A%0Ahtml%2C%20body%2C%20div%2C%20span%2C%20applet%2C%20object%2C%20iframe%2C%20h1%2C%20h2%2C%20h3%2C%20h4%2C%20h5%2C%20h6%2C%20p%2C%20blockquote%2C%20pre%2C%20a%2C%20abbr%2C%20acronym%2C%20address%2C%20big%2C%20cite%2C%20code%2C%20del%2C%20dfn%2C%20em%2C%20img%2C%20ins%2C%20kbd%2C%20q%2C%20s%2C%20samp%2C%20small%2C%20strike%2C%20strong%2C%20sub%2C%20sup%2C%20tt%2C%20var%2C%20b%2C%20u%2C%20i%2C%20center%2C%20dl%2C%20dt%2C%20dd%2C%20ol%2C%20ul%2C%20li%2C%20fieldset%2C%20form%2C%20label%2C%20legend%2C%20table%2C%20caption%2C%20tbody%2C%20tfoot%2C%20thead%2C%20tr%2C%20th%2C%20td%2C%20article%2C%20aside%2C%20canvas%2C%20details%2C%20embed%2C%20figure%2C%20figcaption%2C%20footer%2C%20header%2C%20hgroup%2C%20menu%2C%20nav%2C%20output%2C%20ruby%2C%20section%2C%20summary%2C%20time%2C%20mark%2C%20audio%2C%20video%20%7B%0Amargin%3A%200%3B%0Apadding%3A%200%3B%0Aborder%3A%200%3B%0A%7D%0A%0A%23tiHeader%20ul%20%7B%0Alist%2Dstyle%2Dtype%3A%20none%3B%0A%7D%0A%23tiHeader%20%2Enav%20%7B%0Abackground%3A%20%23c00%3B%0Aheight%3A%2041%2E375px%3B%0A%7D%0A%23tiHeader%20%23top%5Flogo%20%7B%0Aheight%3A%2036px%3B%0A%7D%0A%23content%20%7B%0Apadding%3A%201em%3B%0Amax%2Dwidth%3A%201200px%3B%0Aoverflow%3A%20auto%3B%0Amargin%3A%200%20auto%3B%0A%7D%0A%23tiFooter%20%7B%0Aclear%3A%20both%3B%0Acolor%3A%20%23b0b0b0%3B%0Afont%2Dsize%3A%20%2E9em%3B%0Apadding%3A%201em%202em%3B%0Apadding%3A%201em%202rem%3B%0Aborder%2Dtop%3A%201px%20solid%20%23e0e0e0%3B%0Abackground%3A%20%23fff%3B%0A%7D%0A%23tiFooter%20p%20%7B%0Amax%2Dwidth%3A%2060em%3B%0A%7D%0A%23tiFooter%20a%20%7B%0Acolor%3A%20%23b0b0b0%3B%0A%7D%0A%23tiFooter%20a%3Ahover%20%7B%0Acolor%3A%20%23c00%3B%0A%7D%0A%0Abody%20%7B%0Afont%2Dfamily%3A%20%27Open%20Sans%27%2C%20sans%2Dserif%3B%0Afont%2Dsize%3A%2014px%3B%0Aline%2Dheight%3A%201%2E6%3B%0Acolor%3A%20%23555%3B%0Abackground%2Dcolor%3A%20%23fff%3B%0Amargin%3A%200%20auto%3B%0A%7D%0Abody%3E%2A%3Afirst%2Dchild%20%7B%0Amargin%2Dtop%3A%200%20%21important%3B%0A%7D%0Abody%3E%2A%3Alast%2Dchild%20%7B%0Amargin%2Dbottom%3A%200%20%21important%3B%0A%7D%0A%0Ap%2C%20blockquote%2C%20ul%2C%20ol%2C%20dl%2C%20table%2C%20pre%20%7B%0Amargin%3A%2015px%200%3B%0A%7D%0A%0Ah1%2C%20h2%2C%20h3%2C%20h4%2C%20h5%2C%20h6%20%7B%0Amargin%3A%200%200%20%2E5em%200%3B%0Apadding%3A%200%3B%0Afont%2Dweight%3A%20600%3B%0Acolor%3A%20%23333%3B%0A%2Dwebkit%2Dfont%2Dsmoothing%3A%20antialiased%3B%0A%7D%0Ah1%20tt%2C%20h1%20code%2C%20h2%20tt%2C%20h2%20code%2C%20h3%20tt%2C%20h3%20code%2C%20h4%20tt%2C%20h4%20code%2C%20h5%20tt%2C%20h5%20code%2C%20h6%20tt%2C%20h6%20code%20%7B%0Afont%2Dsize%3A%20inherit%3B%0A%7D%0Ah1%20%7B%0Afont%2Dsize%3A%202em%3B%0A%7D%0Ah2%20%7B%0Afont%2Dsize%3A%201%2E6em%3B%0Aborder%2Dbottom%3A%201px%20solid%20%23ccc%3B%0A%7D%0Ah3%20%7B%0Afont%2Dsize%3A%201%2E4em%3B%0A%7D%0Ah4%20%7B%0Afont%2Dsize%3A%201%2E2em%3B%0A%7D%0Ah5%20%7B%0Afont%2Dsize%3A%201em%3B%0A%7D%0Ah6%20%7B%0Afont%2Dsize%3A%201em%3B%0A%7D%0Abody%3Eh2%3Afirst%2Dchild%2C%20body%3Eh1%3Afirst%2Dchild%2C%20body%3Eh1%3Afirst%2Dchild%2Bh2%2C%20body%3Eh3%3Afirst%2Dchild%2C%20body%3Eh4%3Afirst%2Dchild%2C%20body%3Eh5%3Afirst%2Dchild%2C%20body%3Eh6%3Afirst%2Dchild%20%7B%0Amargin%2Dtop%3A%200%3B%0Apadding%2Dtop%3A%200%3B%0A%7D%0Aa%3Afirst%2Dchild%20h1%2C%20a%3Afirst%2Dchild%20h2%2C%20a%3Afirst%2Dchild%20h3%2C%20a%3Afirst%2Dchild%20h4%2C%20a%3Afirst%2Dchild%20h5%2C%20a%3Afirst%2Dchild%20h6%20%7B%0Amargin%2Dtop%3A%200%3B%0Apadding%2Dtop%3A%200%3B%0A%7D%0Ah1%2Bp%2C%20h2%2Bp%2C%20h3%2Bp%2C%20h4%2Bp%2C%20h5%2Bp%2C%20h6%2Bp%20%7B%0Amargin%2Dtop%3A%2010px%3B%0A%7D%0A%0Aa%20%7B%0Acolor%3A%20%23189%3B%0Atext%2Ddecoration%3A%20none%3B%0A%7D%0Aa%3Ahover%20%7B%0Atext%2Ddecoration%3A%20underline%3B%0A%7D%0A%0Aul%2C%20ol%20%7B%0Apadding%2Dleft%3A%2030px%3B%0A%7D%0Aul%20li%20%3E%20%3Afirst%2Dchild%2C%0Aol%20li%20%3E%20%3Afirst%2Dchild%2C%0Aul%20li%20ul%3Afirst%2Dof%2Dtype%2C%0Aol%20li%20ol%3Afirst%2Dof%2Dtype%2C%0Aul%20li%20ol%3Afirst%2Dof%2Dtype%2C%0Aol%20li%20ul%3Afirst%2Dof%2Dtype%20%7B%0Amargin%2Dtop%3A%200px%3B%0A%7D%0Aul%20ul%2C%20ul%20ol%2C%20ol%20ol%2C%20ol%20ul%20%7B%0Amargin%2Dbottom%3A%200%3B%0A%7D%0Adl%20%7B%0Apadding%3A%200%3B%0A%7D%0Adl%20dt%20%7B%0Afont%2Dsize%3A%2014px%3B%0Afont%2Dweight%3A%20bold%3B%0Afont%2Dstyle%3A%20italic%3B%0Apadding%3A%200%3B%0Amargin%3A%2015px%200%205px%3B%0A%7D%0Adl%20dt%3Afirst%2Dchild%20%7B%0Apadding%3A%200%3B%0A%7D%0Adl%20dt%3E%3Afirst%2Dchild%20%7B%0Amargin%2Dtop%3A%200px%3B%0A%7D%0Adl%20dt%3E%3Alast%2Dchild%20%7B%0Amargin%2Dbottom%3A%200px%3B%0A%7D%0Adl%20dd%20%7B%0Amargin%3A%200%200%2015px%3B%0Apadding%3A%200%2015px%3B%0A%7D%0Adl%20dd%3E%3Afirst%2Dchild%20%7B%0Amargin%2Dtop%3A%200px%3B%0A%7D%0Adl%20dd%3E%3Alast%2Dchild%20%7B%0Amargin%2Dbottom%3A%200px%3B%0A%7D%0A%0Apre%2C%20code%2C%20tt%20%7B%0Afont%2Dsize%3A%2012px%3B%0Afont%2Dfamily%3A%20Consolas%2C%20%22Liberation%20Mono%22%2C%20Courier%2C%20monospace%3B%0A%7D%0Acode%2C%20tt%20%7B%0Amargin%3A%200%200px%3B%0Apadding%3A%200px%200px%3B%0Awhite%2Dspace%3A%20nowrap%3B%0Aborder%3A%201px%20solid%20%23eaeaea%3B%0Abackground%2Dcolor%3A%20%23f8f8f8%3B%0Aborder%2Dradius%3A%203px%3B%0A%7D%0Apre%3Ecode%20%7B%0Amargin%3A%200%3B%0Apadding%3A%200%3B%0Awhite%2Dspace%3A%20pre%3B%0Aborder%3A%20none%3B%0Abackground%3A%20transparent%3B%0A%7D%0Apre%20%7B%0Abackground%2Dcolor%3A%20%23f8f8f8%3B%0Aborder%3A%201px%20solid%20%23ccc%3B%0Afont%2Dsize%3A%2013px%3B%0Aline%2Dheight%3A%2019px%3B%0Aoverflow%3A%20auto%3B%0Apadding%3A%206px%2010px%3B%0Aborder%2Dradius%3A%203px%3B%0A%7D%0Apre%20code%2C%20pre%20tt%20%7B%0Abackground%2Dcolor%3A%20transparent%3B%0Aborder%3A%20none%3B%0A%7D%0Akbd%20%7B%0A%2Dmoz%2Dborder%2Dbottom%2Dcolors%3A%20none%3B%0A%2Dmoz%2Dborder%2Dleft%2Dcolors%3A%20none%3B%0A%2Dmoz%2Dborder%2Dright%2Dcolors%3A%20none%3B%0A%2Dmoz%2Dborder%2Dtop%2Dcolors%3A%20none%3B%0Abackground%2Dcolor%3A%20%23DDDDDD%3B%0Abackground%2Dimage%3A%20linear%2Dgradient%28%23F1F1F1%2C%20%23DDDDDD%29%3B%0Abackground%2Drepeat%3A%20repeat%2Dx%3B%0Aborder%2Dcolor%3A%20%23DDDDDD%20%23CCCCCC%20%23CCCCCC%20%23DDDDDD%3B%0Aborder%2Dimage%3A%20none%3B%0Aborder%2Dradius%3A%202px%202px%202px%202px%3B%0Aborder%2Dstyle%3A%20solid%3B%0Aborder%2Dwidth%3A%201px%3B%0Afont%2Dfamily%3A%20%22Helvetica%20Neue%22%2CHelvetica%2CArial%2Csans%2Dserif%3B%0Aline%2Dheight%3A%2010px%3B%0Apadding%3A%201px%204px%3B%0A%7D%0A%0Ablockquote%20%7B%0Aborder%2Dleft%3A%204px%20solid%20%23DDD%3B%0Apadding%3A%200%2015px%3B%0Acolor%3A%20%23777%3B%0Afont%2Dsize%3A%201em%3B%0A%7D%0Ablockquote%3E%3Afirst%2Dchild%20%7B%0Amargin%2Dtop%3A%200px%3B%0A%7D%0Ablockquote%3E%3Alast%2Dchild%20%7B%0Amargin%2Dbottom%3A%200px%3B%0A%7D%0A%0Ahr%20%7B%0Aclear%3A%20both%3B%0Amargin%3A%2015px%200%3B%0Aheight%3A%200px%3B%0Aoverflow%3A%20hidden%3B%0Aborder%3A%20none%3B%0Abackground%3A%20transparent%3B%0Aborder%2Dbottom%3A%201px%20dotted%20silver%3B%0Apadding%3A%200%3B%0A%7D%0A%0Atable%20%7B%0Aborder%2Dcollapse%3A%20collapse%3B%0Afont%2Dsize%3A%201em%3B%0A%7D%0Atable%20th%20%7B%0Abackground%3A%20%23F0F0F0%3B%0Acolor%3A%20%23555%3B%0Atext%2Dalign%3A%20left%3B%0Avertical%2Dalign%3A%20middle%3B%0A%7D%0Atable%20th%2C%20table%20td%20%7B%0Aborder%3A%201px%20solid%20%23ccc%3B%0Apadding%3A%206px%2013px%3B%0A%7D%0Atable%20tr%20%7B%0Aborder%2Dtop%3A%201px%20solid%20%23ccc%3B%0Abackground%2Dcolor%3A%20%23fff%3B%0A%7D%0Atable%20tr%3Anth%2Dchild%282n%29%20%7B%0Abackground%2Dcolor%3A%20%23f8f8f8%3B%0A%7D%0A%0Aimg%20%7B%0Amax%2Dwidth%3A%20100%25%0A%7D%0A%2Eplatform%20%7B%0Abackground%3A%20%23cc0000%3B%0Atext%2Dalign%3A%20right%3B%0A%7D%0A" rel="stylesheet" type="text/css" />
10 <meta name="viewport" content="width=device-width, initial-scale=1.0">
11
12</head><body>
13<header id="tiHeader">
14 <div class="top">
15 <ul>
16 <li id="top_logo">
17 <a href="http://www.ti.com">
18 <img src="" />
19 </a>
20 </li>
21 </ul>
22 </div>
23 <div class="nav">
24 </div>
25</header><div id="content">
26<h2 id="ProductName">
27<!-- @Start Product -->
28PRU Multi-channel ADC Interface Reference Design Demo Manifest
29<!-- @End Product -->
30</h2>
31
32<h4 id="ReleaseDate">
33<!-- @Start Date -->
3411-06-2017
35<!-- @End Date -->
36</h4>
37
38
39<h4 id="SRASID">
40<!-- @Start Date -->
41Manifest ID - SRAS00004475
42<!-- @End Date -->
43</h4>
44</div><div id="content">
45<h4>Legend</h4>
46<p>(explanation of the fields in the Manifest Table below)</p>
47<table>
48<tbody>
49<tr>
50<td>
51<b>Software Name </b>
52</td>
53<td>
54The name of the application or file
55</td>
56</tr>
57<tr>
58<td>
59<b>Version</b>
60</td>
61<td>
62Version of the application or file
63</td>
64</tr>
65<tr>
66<td>
67<b>License Type</b>
68</td>
69<td>
70Type of license(s) under which TI will be providing
71software to the licensee (e.g. BSD-3-Clause, GPL-2.0, TI Text File License, TI
72Commercial License). The license could be under Commercial terms or Open Source. See Open Source Reference License Disclaimer in
73the Disclaimers Section. Whenever possible, TI will use an <a href="http://spdx.org/licenses/"> SPDX Short Identifier </a> for an Open Source
74License. TI Commercial license terms are not usually included in the manifest and are conveyed through a variety
75of means such as a clickwrap license upon install,
76a signed license agreement and so forth.
77</td>
78</tr>
79<tr>
80<td>
81<b>Location</b>
82</td>
83<td>
84The directory name and path on the media or a specific file where the Software is located. Typically fully qualified path names
85are not used and instead the relevant top level directory of the application is given.
86A notation often used in the manifests is [as installed]/directory/*. Note that the asterisk implies that all
87files under that directory are licensed as the License Type field denotes. Any exceptions to this will
88generally be denoted as [as installed]/directory/* except as noted below which means as shown in subsequent rows of
89the manifest.
90</td>
91</tr>
92<tr>
93<td>
94<b>Delivered As</b>
95</td>
96<td>
97This field will either be &#8220;Source&#8221;, &#8220;Binary&#8221; or &#8220;Source
98and Binary&#8221; and is the primary form the content of the Software is delivered
99in. If the Software is delivered in an archive format, this field
100applies to the contents of the archive. If the word Limited is used
101with Source, as in &#8220;Limited Source&#8221; or &#8220;Limited Source and Binary&#8221; then
102only portions of the Source for the application are provided.
103</td>
104</tr>
105<tr>
106<td>
107<b>Modified by TI</b>
108</td>
109<td>
110This field will either be &#8220;Yes&#8221; or &#8220;No&#8221;. A &#8220;Yes&#8221; means
111TI has made changes to the Software. A &#8220;No&#8221; means TI has not made any
112changes. Note: This field is not applicable for Software &#8220;Obtained
113from&#8221; TI.
114</td>
115</tr>
116<tr>
117<td>
118<b>Obtained from</b>
119</td>
120<td>
121This field specifies from where or from whom TI obtained
122the Software. It may be a URL to an Open Source site, a 3<sup>rd</sup>
123party licensor, or TI. See Links Disclaimer in the Disclaimers
124Section.
125</td>
126</tr>
127</tbody>
128</table>
129</div><div id="content">
130<h3>Disclaimers</h3>
131<h4>Export Control Classification Number (ECCN)</h4>
132<p>Any use of ECCNs listed in the Manifest is at the user&#8217;s risk
133and without recourse to TI. Your
134company, as the exporter of record, is responsible for determining the
135correct classification of any item at
136the time of export. Any export classification by TI of Software is for
137TI&#8217;s internal use only and shall not be construed as a representation
138or warranty
139regarding the proper export classification for such Software or whether
140an export
141license or other documentation is required for exporting such Software</p>
142<h3>Links in the Manifest</h3>
143<p>Any
144links appearing on this Manifest
145(for example in the &#8220;Obtained from&#8221; field) were verified at the time
146the Manifest was created. TI makes no guarantee that any listed links
147will
148remain active in the future.</p>
149<h3>Open Source License References</h3>
150<p>Your company is responsible for confirming the
151applicable license terms for any open source Software
152listed in this Manifest that was not &#8220;Obtained from&#8221; TI. Any open
153source license
154specified in this Manifest for Software that was
155not &#8220;Obtained from&#8221; TI is for TI&#8217;s internal use only and shall not be
156construed as a representation or warranty regarding the proper open
157source license terms
158for such Software.</p>
159</div><div id="content">
160<h4>Export Information</h4>
161<p>ECCN for Software included in this release:</p>
162Publicly Available
163</div><div id="content">
164<!-- h3>Manifest Table</h3 -->
165
166 <table>
167 <tbody>
168
169 <h2>
170 PRU Multi-channel ADC Interface Reference Design Demo Manifest Table
171 </h2>
172
173
174 <p>
175
176 See the Legend above for a description of these columns.
177
178 </p>
179
180 <table id="targetpackages" name="targetpackages">
181 <thead>
182 <tr>
183 <td><b>Software Name</b></td>
184 <td><b>Version</b></td>
185 <td><b>License Type</b></td>
186 <td><b>Delivered As</b></td>
187 <td><b>Modified by TI</b></td>
188 <td></td>
189 <td></td>
190 </tr>
191 </thead>
192
193
194 <tbody>
195 <tr>
196 <td id="name" name="name" rowspan="2">
197 PRU_ADS8688_Interface
198 </td>
199 <td id="version" name="version" rowspan="2">
200 1.0.0
201 </td>
202 <td id="license" name="license" rowspan="2">
203 BSD-3-Clause
204 </td>
205 <td id="delivered" name="delivered" rowspan="2">
206 Source
207 </td>
208 <td id="modified" name="modified" rowspan="2">
209 Yes
210 </td>
211 <td><b>Location</b></td>
212 <td id="location" name="location">
213 tida01555/PRU_ADS8688_Interface/
214 </td>
215 </tr>
216 <tr>
217 <td><b>Obtained from</b></td>
218 <td id="obtained" name="obtained">
219 TI
220 </td>
221 </tr>
222
223 <tbody>
224 <tr>
225 <td id="name" name="name" rowspan="2">
226 PRU_ADS8688_Controller
227 </td>
228 <td id="version" name="version" rowspan="2">
229 1.0.0
230 </td>
231 <td id="license" name="license" rowspan="2">
232 BSD-3-Clause
233 </td>
234 <td id="delivered" name="delivered" rowspan="2">
235 Source
236 </td>
237 <td id="modified" name="modified" rowspan="2">
238 Yes
239 </td>
240 <td><b>Location</b></td>
241 <td id="location" name="location">
242 tida01555/PRU_ADS8688_Controller/
243 </td>
244 </tr>
245 <tr>
246 <td><b>Obtained from</b></td>
247 <td id="obtained" name="obtained">
248 TI
249 </td>
250 </tr>
251
252 <tbody>
253 <tr>
254 <td id="name" name="name" rowspan="2">
255 ARM_User_Space_App
256 </td>
257 <td id="version" name="version" rowspan="2">
258 1.0.0
259 </td>
260 <td id="license" name="license" rowspan="2">
261 BSD-3-Clause
262 </td>
263 <td id="delivered" name="delivered" rowspan="2">
264 Source
265 </td>
266 <td id="modified" name="modified" rowspan="2">
267 Yes
268 </td>
269 <td><b>Location</b></td>
270 <td id="location" name="location">
271 tida01555/ARM_User_Space_App/
272 </td>
273 </tr>
274 <tr>
275 <td><b>Obtained from</b></td>
276 <td id="obtained" name="obtained">
277 TI
278 </td>
279 </tr>
280
281 </tbody>
282 </table>
283
284 </p>
285 </p>
286 <p>
287
288</div><div id="content">
289<h4>Credits</h4>
290<BR> <BR><BR><BR><BR>
291</div><div id="content">
292<h4>Licenses</h4>
293<BR><h3><b> PRU Multi-channel ADC Interface Reference Design Demo Licenses </b></h3><BR> <BR><BR> Copyright (C) 2017 Texas Instruments Incorporated - http://www.ti.com/<BR> <BR> <BR> Redistribution and use in source and binary forms, with or without<BR> modification, are permitted provided that the following conditions<BR> are met:<BR> <BR> * Redistributions of source code must retain the above copyright<BR> notice, this list of conditions and the following disclaimer.<BR> <BR> * Redistributions in binary form must reproduce the above copyright<BR> notice, this list of conditions and the following disclaimer in the<BR> documentation and/or other materials provided with the<BR> distribution.<BR> <BR> * Neither the name of Texas Instruments Incorporated nor the names of<BR> its contributors may be used to endorse or promote products derived<BR> from this software without specific prior written permission.<BR> <BR> THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS<BR> "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT<BR> LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR<BR> A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT<BR> OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,<BR> SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT<BR> LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,<BR> DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY<BR> THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT<BR> (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE<BR> OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.<BR> <BR>
294</div>
295<footer id="tiFooter">
296 <p>TI is a global semiconductor design and manufacturing company. Innovate
297 with 100,000+ analog ICs and embedded processors, along with software, tools
298 and the industry's largest sales/support staff.</p>
299</footer>
300</body></html> \ No newline at end of file
diff --git a/PRU_ADS8688_Controller/AM335x_PRU.cmd b/PRU_ADS8688_Controller/AM335x_PRU.cmd
new file mode 100644
index 0000000..8803377
--- /dev/null
+++ b/PRU_ADS8688_Controller/AM335x_PRU.cmd
@@ -0,0 +1,121 @@
1/*
2 * Copyright (C) 2017 Texas Instruments Incorporated - http://www.ti.com/
3 *
4 *
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions
7 * are met:
8 *
9 * * Redistributions of source code must retain the above copyright
10 * notice, this list of conditions and the following disclaimer.
11 *
12 * * Redistributions in binary form must reproduce the above copyright
13 * notice, this list of conditions and the following disclaimer in the
14 * documentation and/or other materials provided with the
15 * distribution.
16 *
17 * * Neither the name of Texas Instruments Incorporated nor the names of
18 * its contributors may be used to endorse or promote products derived
19 * from this software without specific prior written permission.
20 *
21 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
22 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
23 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
24 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
25 * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
26 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
27 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
28 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
29 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
30 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
31 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
32 *
33 *
34 * AM335x_PRU.cmd
35 * Description: This file is a linker command file that can be used for
36 * linking PRU programs built with the C compiler and the
37 * resulting .out file on an AM335x device.
38 */
39
40/* Link using C conventions */
41-cr
42
43/* Specify the System Memory Map */
44MEMORY
45{
46 PAGE 0:
47 PRU_IMEM : org = 0x00000000 len = 0x00002000 /* 8kB PRU0 Instruction RAM */
48
49 PAGE 1:
50
51 /* RAM */
52
53 PRU_DMEM_0_1 : org = 0x00000000 len = 0x00002000 CREGISTER=24 /* 8kB PRU Data RAM 0_1 */
54 PRU_DMEM_1_0 : org = 0x00002000 len = 0x00002000 CREGISTER=25 /* 8kB PRU Data RAM 1_0 */
55
56 PAGE 2:
57 PRU_SHAREDMEM : org = 0x00010000 len = 0x00003000 CREGISTER=28 /* 12kB Shared RAM */
58
59 DDR : org = 0x80000000 len = 0x1F800000 CREGISTER=31
60 PRUADC_DDR_CARVEOUT : org = 0x9F800000 len = 0x00800000
61 L3OCMC : org = 0x40000000 len = 0x00010000 CREGISTER=30
62
63
64 /* Peripherals */
65
66 PRU_CFG : org = 0x00026000 len = 0x00000044 CREGISTER=4
67 PRU_ECAP : org = 0x00030000 len = 0x00000060 CREGISTER=3
68 PRU_IEP : org = 0x0002E000 len = 0x0000031C CREGISTER=26
69 PRU_INTC : org = 0x00020000 len = 0x00001504 CREGISTER=0
70 PRU_UART : org = 0x00028000 len = 0x00000038 CREGISTER=7
71
72 DCAN0 : org = 0x481CC000 len = 0x000001E8 CREGISTER=14
73 DCAN1 : org = 0x481D0000 len = 0x000001E8 CREGISTER=15
74 DMTIMER2 : org = 0x48040000 len = 0x0000005C CREGISTER=1
75 PWMSS0 : org = 0x48300000 len = 0x000002C4 CREGISTER=18
76 PWMSS1 : org = 0x48302000 len = 0x000002C4 CREGISTER=19
77 PWMSS2 : org = 0x48304000 len = 0x000002C4 CREGISTER=20
78 GEMAC : org = 0x4A100000 len = 0x0000128C CREGISTER=9
79 I2C1 : org = 0x4802A000 len = 0x000000D8 CREGISTER=2
80 I2C2 : org = 0x4819C000 len = 0x000000D8 CREGISTER=17
81 MBX0 : org = 0x480C8000 len = 0x00000140 CREGISTER=22
82 MCASP0_DMA : org = 0x46000000 len = 0x00000100 CREGISTER=8
83 MCSPI0 : org = 0x48030000 len = 0x000001A4 CREGISTER=6
84 MCSPI1 : org = 0x481A0000 len = 0x000001A4 CREGISTER=16
85 MMCHS0 : org = 0x48060000 len = 0x00000300 CREGISTER=5
86 SPINLOCK : org = 0x480CA000 len = 0x00000880 CREGISTER=23
87 TPCC : org = 0x49000000 len = 0x00001098 CREGISTER=29
88 UART1 : org = 0x48022000 len = 0x00000088 CREGISTER=11
89 UART2 : org = 0x48024000 len = 0x00000088 CREGISTER=12
90
91 RSVD10 : org = 0x48318000 len = 0x00000100 CREGISTER=10
92 RSVD13 : org = 0x48310000 len = 0x00000100 CREGISTER=13
93 RSVD21 : org = 0x00032400 len = 0x00000100 CREGISTER=21
94 RSVD27 : org = 0x00032000 len = 0x00000100 CREGISTER=27
95
96}
97
98/* Specify the sections allocation into memory */
99SECTIONS {
100 /* Forces _c_int00 to the start of PRU IRAM. Not necessary when loading
101 an ELF file, but useful when loading a binary */
102 .text:_c_int00* > 0x0, PAGE 0
103
104 .text > PRU_IMEM, PAGE 0
105 .stack > PRU_DMEM_0_1, PAGE 1
106 .bss > PRU_DMEM_0_1, PAGE 1
107 .cio > PRU_DMEM_0_1, PAGE 1
108 .data > PRU_DMEM_0_1, PAGE 1
109 .switch > PRU_DMEM_0_1, PAGE 1
110 .sysmem > PRU_DMEM_0_1, PAGE 1
111 .cinit > PRU_DMEM_0_1, PAGE 1
112 .rodata > PRU_DMEM_0_1, PAGE 1
113 .rofardata > PRU_DMEM_0_1, PAGE 1
114 .farbss > PRU_DMEM_0_1, PAGE 1
115 .fardata > PRU_DMEM_0_1, PAGE 1
116
117 .shared_mem > PRU_SHAREDMEM, PAGE 2
118 .pru1_mem > PRU_DMEM_1_0, PAGE 1
119 .pruadc_ddr_carveout > PRUADC_DDR_CARVEOUT, PAGE 2
120 .resource_table > PRU_DMEM_0_1, PAGE 1
121}
diff --git a/PRU_ADS8688_Controller/Makefile b/PRU_ADS8688_Controller/Makefile
new file mode 100644
index 0000000..f2b8cc3
--- /dev/null
+++ b/PRU_ADS8688_Controller/Makefile
@@ -0,0 +1,125 @@
1# PRU_CGT environment variable must point to the TI PRU code gen tools directory. E.g.:
2#(Desktop Linux) export PRU_CGT=/path/to/pru/code/gen/tools/ti-cgt-pru_2.x.y
3#(Windows) set PRU_CGT=C:/path/to/pru/code/gen/tools/ti-cgt-pru_2.x.y
4#(ARM Linux*) export PRU_CGT=/usr/share/ti/cgt-pru
5#
6# *ARM Linux also needs to create a symbolic link to the /usr/bin/ directory in
7# order to use the same Makefile
8#(ARM Linux) ln -s /usr/bin/ /usr/share/ti/cgt-pru/bin
9
10ifndef PRU_CGT
11define ERROR_BODY
12
13*******************************************************************************
14PRU_CGT environment variable is not set. Examples given:
15(Desktop Linux) export PRU_CGT=/path/to/pru/code/gen/tools/ti-cgt-pru_2.1.2
16(Windows) set PRU_CGT=C:/path/to/pru/code/gen/tools/ti-cgt-pru_2.1.2
17(ARM Linux*) export PRU_CGT=/usr/share/ti/cgt-pru
18
19*ARM Linux also needs to create a symbolic link to the /usr/bin/ directory in
20order to use the same Makefile
21(ARM Linux) ln -s /usr/bin/ /usr/share/ti/cgt-pru/bin
22*******************************************************************************
23
24endef
25$(error $(ERROR_BODY))
26endif
27
28# PRU_SSP environment variable must point to the PRU Software Support Package. E.g.:
29#(Desktop Linux) export PRU_SSP=/path/to/pru_software_support_package
30#(Windows) set PRU_SSP=C:/path/to/pru_software_support_package
31#(ARM Linux*) export PRU_SSP=/path/to/pru_software_support_package
32
33ifndef PRU_SSP
34define ERROR_BODY
35
36*******************************************************************************
37PRU_SSP environment variable must point to the PRU Software Support Package. E.g.:
38(Desktop Linux) export PRU_SSP=/path/to/pru_software_support_package
39(Windows) set PRU_SSP=C:/path/to/pru_software_support_package
40(ARM Linux*) export PRU_SSP=/path/to/pru_software_support_package
41PRU_CGT environment variable is not set. Examples given:
42*******************************************************************************
43
44endef
45$(error $(ERROR_BODY))
46endif
47
48MKFILE_PATH := $(abspath $(lastword $(MAKEFILE_LIST)))
49CURRENT_DIR := $(notdir $(patsubst %/,%,$(dir $(MKFILE_PATH))))
50PROJ_NAME=$(CURRENT_DIR)
51LINKER_COMMAND_FILE=./AM335x_PRU.cmd
52LIBS=--library=$(PRU_SSP)/lib/rpmsg_lib.lib
53INCLUDE=--include_path=$(PRU_SSP)/include --include_path=$(PRU_SSP)/include/am335x
54STACK_SIZE=0x100
55HEAP_SIZE=0x100
56GEN_DIR=gen
57
58#Common compiler and linker flags (Defined in 'PRU Optimizing C/C++ Compiler User's Guide)
59CFLAGS=-v3 -o2 --display_error_number --endian=little --hardware_mac=on --asm_directory=$(GEN_DIR) --obj_directory=$(GEN_DIR) --pp_directory=$(GEN_DIR) -ppd -ppa
60#Linker flags (Defined in 'PRU Optimizing C/C++ Compiler User's Guide)
61LFLAGS=--reread_libs --warn_sections --stack_size=$(STACK_SIZE) --heap_size=$(HEAP_SIZE)
62
63TARGET=$(GEN_DIR)/$(PROJ_NAME).out
64MAP=$(GEN_DIR)/$(PROJ_NAME).map
65OBJECTS=$(patsubst %.asm,$(GEN_DIR)/%.object,$(wildcard *.asm))
66OBJECTS+=$(patsubst %.c,$(GEN_DIR)/%.object,$(wildcard *.c))
67
68
69all: printStart $(TARGET) printEnd
70
71printStart:
72 @echo ''
73 @echo '************************************************************'
74 @echo 'Building project: $(PROJ_NAME)'
75
76printEnd:
77 @echo ''
78 @echo 'Output files can be found in the "$(GEN_DIR)" directory'
79 @echo ''
80 @echo 'Finished building project: $(PROJ_NAME)'
81 @echo '************************************************************'
82 @echo ''
83
84# Invokes the linker (-z flag) to make the .out file
85$(TARGET): $(OBJECTS) $(LINKER_COMMAND_FILE)
86 @echo ''
87 @echo 'Building target: $@'
88 @echo 'Invoking: PRU Linker'
89 $(PRU_CGT)/bin/clpru $(CFLAGS) -z -i$(PRU_CGT)/lib -i$(PRU_CGT)/include $(LFLAGS) -o $(TARGET) $(OBJECTS) -m$(MAP) $(LINKER_COMMAND_FILE) --library=libc.a $(LIBS)
90 @echo 'Finished building target: $@'
91
92# Invokes the compiler on all assembly files in the directory to create the object files
93$(GEN_DIR)/%.object: %.asm
94 @mkdir -p $(GEN_DIR)
95 @echo ''
96 @echo 'Building file: $<'
97 @echo 'Invoking: PRU Compiler'
98 $(PRU_CGT)/bin/clpru --include_path=$(PRU_CGT)/include $(INCLUDE) $(CFLAGS) -fe $@ $<
99
100# Invokes the compiler on all c files in the directory to create the object files
101$(GEN_DIR)/%.object: %.c
102 @mkdir -p $(GEN_DIR)
103 @echo ''
104 @echo 'Building file: $<'
105 @echo 'Invoking: PRU Compiler'
106 $(PRU_CGT)/bin/clpru -k --include_path=$(PRU_CGT)/include $(INCLUDE) $(CFLAGS) -fe $@ $<
107
108.PHONY: all clean
109
110# Remove the $(GEN_DIR) directory
111clean:
112 @echo ''
113 @echo '************************************************************'
114 @echo 'Cleaning project: $(PROJ_NAME)'
115 @echo ''
116 @echo 'Removing files in the "$(GEN_DIR)" directory'
117 @rm -rf $(GEN_DIR)
118 @echo ''
119 @echo 'Finished cleaning project: $(PROJ_NAME)'
120 @echo '************************************************************'
121 @echo ''
122
123# Includes the dependencies that the compiler creates (-ppd and -ppa flags)
124-include $(OBJECTS:%.object=%.pp)
125
diff --git a/PRU_ADS8688_Controller/PRU_ADS8688_Controller.c b/PRU_ADS8688_Controller/PRU_ADS8688_Controller.c
new file mode 100644
index 0000000..6e51031
--- /dev/null
+++ b/PRU_ADS8688_Controller/PRU_ADS8688_Controller.c
@@ -0,0 +1,391 @@
1/*
2 * Copyright (C) 2017 Texas Instruments Incorporated - http://www.ti.com/
3 *
4 *
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions
7 * are met:
8 *
9 * * Redistributions of source code must retain the above copyright
10 * notice, this list of conditions and the following disclaimer.
11 *
12 * * Redistributions in binary form must reproduce the above copyright
13 * notice, this list of conditions and the following disclaimer in the
14 * documentation and/or other materials provided with the
15 * distribution.
16 *
17 * * Neither the name of Texas Instruments Incorporated nor the names of
18 * its contributors may be used to endorse or promote products derived
19 * from this software without specific prior written permission.
20 *
21 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
22 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
23 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
24 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
25 * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
26 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
27 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
28 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
29 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
30 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
31 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
32 */
33
34#include <stdint.h>
35#include <pru_cfg.h>
36#include <pru_ctrl.h>
37#include "resource_table_empty.h"
38
39volatile register uint32_t __R30;
40volatile register uint32_t __R31;
41
42/* Scratchpad constants */
43#define SCRATCHPAD_0 10
44#define SCRATCHPAD_1 11
45#define SCRATCHPAD_2 12
46
47/* Specific register numbers shared through the Scratchpads */
48#define CONFIG_REG 15
49#define DELAY_REG 21
50#define RESULT_REG 22
51#define STATUS_REG 28
52#define REQUEST_REG 29
53
54/* Request register bit mapping */
55#define START_BIT (1 << 0)
56#define CONTINUOUS_BIT (1 << 1)
57#define RECV_READY_BIT (1 << 2)
58#define RECV_ACK_BIT (1 << 3)
59
60/* Response register bit mapping */
61#define SEND_READY_BIT (1 << 0)
62#define SEND_ACK_BIT (1 << 1)
63#define SEND_DONE_BIT (1 << 2)
64
65/* Sample/config mode */
66#define ONE_SHOT 0
67#define CONTINUOUS 1
68
69/* ADS8688 configuration definitions */
70/* Command Register formatting */
71#define CMD_REG(x) (x << 8)
72#define NOOP 0x00
73#define STDBY 0x82
74#define PWR_DN 0x83
75#define AUTO_RST 0xA0
76#define RST 0x85
77#define MAN_CH(chan) (0xC0 | (4 * chan))
78#define MAN_AUX 0xE0
79/* Program Register formatting */
80#define PROG_REG(reg, rw, data) ((reg << 9) | (rw << 8) | data)
81#define AUTO_SEQ_EN (0x01)
82#define CHAN_PWR_DN (0x02)
83#define CHAN_INPUT_RANGE(chan) (0x05 + chan)
84#define COMM_READ_BACK (0x3F)
85/* Read or write for the program register formatting */
86#define WRITE 1
87#define READ 0
88/* Channel input range constants */
89#define PLUSMINUS25VREF 0
90#define PLUSMINUS125VREF 1
91#define PLUSMINUS0625VREF 2
92#define PLUS25VREF 5
93#define PLUS125VREF 6
94
95/* Oversampling constants (must be a power of 2 to achieve timings in the PRU) */
96#define OVERSAMPLE 1
97
98/* Frequency estimation constants */
99#define FREQ_EST_DEVICE 0
100#define FREQ_EST_CHANNEL 5
101#define FREQ_EST_CYCLES 5
102#define MIN_DELAY 710 //55Hz
103#define DEFAULT_DELAY 781 //50Hz
104#define DEFAULT_COMP 2 //50Hz
105#define MAX_DELAY 868 //45Hz
106
107/* Information about devices and channels connected */
108#define CHANS_PER_DEVICE 8
109#define DEVICES 6
110#define NUM_CHANS CHANS_PER_DEVICE * DEVICES
111#define SAMPLES_PER_CYCLE 640
112
113/* Ping and Pong buffer information */
114#define PING_ADDR 0x9FFC0000
115#define PONG_ADDR 0x9FFE0000
116#define PING 0
117#define PONG 1
118#define DATA_READY 0x0000FFFF
119#define IN_PROGRESS 0x00000000
120
121
122uint32_t data_buf[DEVICES];
123uint32_t config_buf[DEVICES];
124
125/* Send cycle delay between samples value */
126send_delay(uint32_t delay_val) {
127 /* Send the cycle delay to the other PRU through Scratchpad 0 */
128 __xout(SCRATCHPAD_0, DELAY_REG, 0, delay_val);
129}
130
131/* Send configurations or commands */
132send_command(uint16_t continuous) {
133 uint32_t request, status = 0;
134 uint32_t temp;
135
136 /* Check to make sure the SPI coprocessor is ready */
137 while (!(status & SEND_READY_BIT)) {
138 __xin(SCRATCHPAD_1, STATUS_REG, 0, temp);
139 status = temp;
140 }
141 /* Push the configuration values for each ADC */
142 __xout(SCRATCHPAD_0, CONFIG_REG, 0, config_buf);
143
144 /* Send the start command to kick off the transfer */
145 request = START_BIT;
146 if (continuous)
147 request |= CONTINUOUS_BIT;
148 __xout(SCRATCHPAD_1, REQUEST_REG, 0, request);
149
150 /* Wait for SPI coprocessor to acknowledge the command */
151 while (!(status & SEND_ACK_BIT)) {
152 __xin(SCRATCHPAD_1, STATUS_REG, 0, status);
153 }
154
155 /* Clear the start bit */
156 request &= ~START_BIT;
157 __xout(SCRATCHPAD_1, REQUEST_REG, 0, request);
158}
159
160/* Receive response */
161receive_data() {
162 uint32_t request, status = 0;
163 uint32_t temp;
164
165 /* Read the current request to get start and continuous */
166 __xin(SCRATCHPAD_1, REQUEST_REG, 0, request);
167
168 /* Set the ready bit, clear the ack bit */
169 request |= RECV_READY_BIT;
170 request &= ~RECV_ACK_BIT;
171 __xout(SCRATCHPAD_1, REQUEST_REG, 0, request);
172
173 /* Clear the ready bit, set the ack bit in the temp variable
174 * Wait until after done signal is received to send
175 */
176 request &= ~RECV_READY_BIT;
177 request |= RECV_ACK_BIT;
178
179 /* Wait for the done signal */
180 while (!(status & SEND_DONE_BIT)) {
181 __xin(SCRATCHPAD_1, STATUS_REG, 0, temp);
182 status = temp;
183 }
184
185 /* Send ack bit one cycle before pulling data to save time */
186 __xout(SCRATCHPAD_1, REQUEST_REG, 0, request);
187
188 /* Pull the data into data_buf */
189 __xin(SCRATCHPAD_2, RESULT_REG, 0, data_buf);
190}
191
192/* Send intial ADC configurations */
193adc_init() {
194 uint32_t status = 0;
195 uint32_t temp;
196
197 /* Check to make sure the SPI coprocessor is ready */
198 while (!(status & SEND_READY_BIT)) {
199 __xin(SCRATCHPAD_1, STATUS_REG, 0, temp);
200 status = temp;
201 }
202
203 /* Send reset command to all devices in parallel */
204 config_buf[0] = CMD_REG(RST);
205 config_buf[1] = CMD_REG(RST);
206 config_buf[2] = CMD_REG(RST);
207 config_buf[3] = CMD_REG(RST);
208 config_buf[4] = CMD_REG(RST);
209 config_buf[5] = CMD_REG(RST);
210 send_command(ONE_SHOT);
211 receive_data();
212
213 /* Set device 0 channel 0's input range to 0-2.5vRef */
214 /*
215 config_buf[0] = PROG_REG(CHAN_INPUT_RANGE(0), WRITE, PLUS125VREF);
216 send_command(ONE_SHOT);
217 receive_data();
218 */
219
220 /* Only enable channel 6 on all devices */
221 config_buf[0] = PROG_REG(AUTO_SEQ_EN, WRITE, 0xFF);
222 config_buf[1] = PROG_REG(AUTO_SEQ_EN, WRITE, 0xFF);
223 config_buf[2] = PROG_REG(AUTO_SEQ_EN, WRITE, 0xFF);
224 config_buf[3] = PROG_REG(AUTO_SEQ_EN, WRITE, 0xFF);
225 config_buf[4] = PROG_REG(AUTO_SEQ_EN, WRITE, 0xFF);
226 config_buf[5] = PROG_REG(AUTO_SEQ_EN, WRITE, 0xFF);
227 send_command(ONE_SHOT);
228 receive_data();
229
230 __delay_cycles(200);
231
232 /* Put devices into auto reset mode in parallel */
233 config_buf[0] = CMD_REG(AUTO_RST);
234 config_buf[1] = CMD_REG(AUTO_RST);
235 config_buf[2] = CMD_REG(AUTO_RST);
236 config_buf[3] = CMD_REG(AUTO_RST);
237 config_buf[4] = CMD_REG(AUTO_RST);
238 config_buf[5] = CMD_REG(AUTO_RST);
239 send_command(ONE_SHOT);
240 receive_data();
241
242 /* Initial delay set for 50Hz */
243 send_delay(DEFAULT_DELAY);
244
245 /* Send the NOOP command to kick off the sampling */
246 config_buf[0] = CMD_REG(NOOP);
247 config_buf[1] = CMD_REG(NOOP);
248 config_buf[2] = CMD_REG(NOOP);
249 config_buf[3] = CMD_REG(NOOP);
250 config_buf[4] = CMD_REG(NOOP);
251 config_buf[5] = CMD_REG(NOOP);
252 send_command(CONTINUOUS);
253
254 /* Enable the cycle counter */
255 PRU0_CTRL.CTRL_bit.CTR_EN = 1;
256 PRU0_CTRL.CYCLE = 0;
257
258}
259
260typedef struct {
261 int32_t chan_data[CHANS_PER_DEVICE];
262} adc_device;
263
264#pragma DATA_SECTION(debug, ".shared_mem")
265volatile far int32_t debug[10];
266
267uint32_t chan_data_temp[NUM_CHANS];
268
269void main(void)
270{
271 uint32_t i, j, idx;
272 uint32_t oversample = 1;
273 int32_t last_pol = 1;
274 uint32_t zero_crossings = 0;
275 uint32_t start, stop, elapsed, delay, compensation = 0;
276 uint32_t zero = 0;
277 uint32_t curr_addr;
278 uint8_t curr_buff;
279 uint32_t num_captured = 0;
280
281 delay = DEFAULT_DELAY;
282 compensation = DEFAULT_COMP;
283
284 /* Select the ping buffer first */
285 curr_addr = PING_ADDR + 8;
286 curr_buff = PING;
287
288 /* This PRU comes up first, zero out the status registers */
289 __xout(SCRATCHPAD_1, STATUS_REG, 0, zero);
290 __xout(SCRATCHPAD_1, REQUEST_REG, 0, zero);
291
292 /* Clear SYSCFG[STANDBY_INIT] to enable OCP master port */
293 CT_CFG.SYSCFG_bit.STANDBY_INIT = 0;
294
295 /* ADC init */
296 adc_init();
297
298 while (1) {
299 for (i = 0; i < CHANS_PER_DEVICE; i++) {
300 /* receive parallel data from the ADCs */
301 if (i < compensation)
302 send_delay(delay + 1);
303 else
304 send_delay(delay);
305 receive_data();
306 for (j = 0; j < DEVICES; j++) {
307 idx = j*CHANS_PER_DEVICE+i;
308
309 /* Clear the accumulated value if first sample */
310 if (oversample == 1)
311 chan_data_temp[idx] = 0;
312
313 /* Accumulate samples until oversample value is reached */
314 chan_data_temp[idx] += (uint16_t)data_buf[j];
315
316 /* Perform oversampling */
317 if (oversample == OVERSAMPLE) {
318 chan_data_temp[idx] = (uint16_t)((chan_data_temp[idx] + (OVERSAMPLE/2)) / OVERSAMPLE);
319 /* Frequency estimation using zero crossings */
320 if (j == FREQ_EST_DEVICE && i == FREQ_EST_CHANNEL) {
321 if (((last_pol > 0) && ((int16_t)(chan_data_temp[idx] - 0x8000) < 0)) ||
322 ((last_pol < 0) && ((int16_t)(chan_data_temp[idx] - 0x8000) > 0))) {
323 zero_crossings++;
324 last_pol = ~last_pol;
325
326 /* First crossing, get the start timestamp */
327 if (zero_crossings == 1) {
328 start = PRU0_CTRL.CYCLE;
329 }
330 /* Last crossing, get the stop timestamp */
331 else if (zero_crossings == ((FREQ_EST_CYCLES * 2) + 1)) {
332 stop = PRU0_CTRL.CYCLE;
333 elapsed = stop - start;
334 delay = elapsed/(SAMPLES_PER_CYCLE * FREQ_EST_CYCLES);
335 compensation = delay % CHANS_PER_DEVICE;
336 delay = delay / CHANS_PER_DEVICE;
337 if (delay < MIN_DELAY) {
338 delay = MIN_DELAY;
339 compensation = 0;
340 }
341 else if (delay > MAX_DELAY) {
342 delay = MAX_DELAY;
343 compensation = CHANS_PER_DEVICE - 1;
344 }
345 PRU0_CTRL.CYCLE = 0;
346 zero_crossings = 0;
347 }
348 }
349 }
350 }
351 }
352 }
353 if (oversample++ == OVERSAMPLE) {
354 oversample = 1;
355 /* Copy the oversampled data from each channel to the current buffer */
356 memcpy((void *)curr_addr, chan_data_temp, CHANS_PER_DEVICE * DEVICES * 4);
357 /* Increment the address for the next set of channel data */
358 curr_addr += CHANS_PER_DEVICE * DEVICES * 4;
359
360 /* A full sample has been captured, switch buffers */
361 if (++num_captured == SAMPLES_PER_CYCLE) {
362 if (curr_buff == PING) {
363 /* Mark the first 4 bytes of the ping buffer with the ready flag */
364 *(volatile uint32_t *)PING_ADDR = DATA_READY;
365 /* Mark the next 4 bytes of the ping buffer with delay and comp values */
366 *(volatile uint32_t *)(PING_ADDR + 4) = ((uint16_t)compensation) << 16 | ((uint16_t) delay);
367 /* Mark the first 4 bytes of the pong buffer with the in progress flag */
368 *(volatile uint32_t *)PONG_ADDR = IN_PROGRESS;
369 /* Set the current address for samples to the address after the flag */
370 curr_addr = PONG_ADDR + 8;
371 /* Update the current buffer */
372 curr_buff = PONG;
373 }
374 else {
375 /* Mark the first 4 bytes of the pong buffer with the ready flag */
376 *(volatile uint32_t *)PONG_ADDR = DATA_READY;
377 /* Mark the next 4 bytes of the pong buffer with delay and comp values */
378 *(volatile uint32_t *)(PONG_ADDR + 4) = ((uint16_t)compensation) << 16 | ((uint16_t) delay);
379 /* Mark the first 4 bytes of the ping buffer with the in progress flag */
380 *(volatile uint32_t *)PING_ADDR = IN_PROGRESS;
381 /* Set the current address for samples to the address after the flag */
382 curr_addr = PING_ADDR + 8;
383 /* Update the current buffer */
384 curr_buff = PING;
385 }
386 num_captured = 0;
387 }
388 }
389 }
390}
391
diff --git a/PRU_ADS8688_Controller/gen/PRU_ADS8688_Controller.asm b/PRU_ADS8688_Controller/gen/PRU_ADS8688_Controller.asm
new file mode 100644
index 0000000..34ba3e4
--- /dev/null
+++ b/PRU_ADS8688_Controller/gen/PRU_ADS8688_Controller.asm
@@ -0,0 +1,3844 @@
1;******************************************************************************
2;* PRU C/C++ Codegen Unix v2.1.4 *
3;* Date/Time created: Wed Nov 22 12:19:17 2017 *
4;******************************************************************************
5 .compiler_opts --abi=eabi --endian=little --hll_source=on --object_format=elf --silicon_version=3 --symdebug:dwarf --symdebug:dwarf_version=3
6
7$C$DW$CU .dwtag DW_TAG_compile_unit
8 .dwattr $C$DW$CU, DW_AT_name("PRU_ADS8688_Controller.c")
9 .dwattr $C$DW$CU, DW_AT_producer("TI PRU C/C++ Codegen Unix v2.1.4 Copyright (c) 2012-2015 Texas Instruments Incorporated")
10 .dwattr $C$DW$CU, DW_AT_TI_version(0x01)
11 .dwattr $C$DW$CU, DW_AT_comp_dir("/home/a0273976local/git/tida01555/PRU_ADS8688_Controller")
12 .global __PRU_CREG_PRU_CFG
13
14$C$DW$1 .dwtag DW_TAG_subprogram, DW_AT_name("memcpy")
15 .dwattr $C$DW$1, DW_AT_TI_symbol_name("memcpy")
16 .dwattr $C$DW$1, DW_AT_type(*$C$DW$T$3)
17 .dwattr $C$DW$1, DW_AT_declaration
18 .dwattr $C$DW$1, DW_AT_external
19$C$DW$2 .dwtag DW_TAG_formal_parameter
20 .dwattr $C$DW$2, DW_AT_type(*$C$DW$T$3)
21$C$DW$3 .dwtag DW_TAG_formal_parameter
22 .dwattr $C$DW$3, DW_AT_type(*$C$DW$T$107)
23$C$DW$4 .dwtag DW_TAG_formal_parameter
24 .dwattr $C$DW$4, DW_AT_type(*$C$DW$T$11)
25 .dwendtag $C$DW$1
26
27
28$C$DW$5 .dwtag DW_TAG_subprogram, DW_AT_name("__xin")
29 .dwattr $C$DW$5, DW_AT_TI_symbol_name("__xin")
30 .dwattr $C$DW$5, DW_AT_declaration
31 .dwattr $C$DW$5, DW_AT_external
32$C$DW$6 .dwtag DW_TAG_formal_parameter
33 .dwattr $C$DW$6, DW_AT_type(*$C$DW$T$11)
34$C$DW$7 .dwtag DW_TAG_formal_parameter
35 .dwattr $C$DW$7, DW_AT_type(*$C$DW$T$11)
36$C$DW$8 .dwtag DW_TAG_formal_parameter
37 .dwattr $C$DW$8, DW_AT_type(*$C$DW$T$11)
38$C$DW$9 .dwtag DW_TAG_formal_parameter
39 .dwattr $C$DW$9, DW_AT_type(*$C$DW$T$105)
40 .dwendtag $C$DW$5
41
42
43$C$DW$10 .dwtag DW_TAG_subprogram, DW_AT_name("__xout")
44 .dwattr $C$DW$10, DW_AT_TI_symbol_name("__xout")
45 .dwattr $C$DW$10, DW_AT_declaration
46 .dwattr $C$DW$10, DW_AT_external
47$C$DW$11 .dwtag DW_TAG_formal_parameter
48 .dwattr $C$DW$11, DW_AT_type(*$C$DW$T$11)
49$C$DW$12 .dwtag DW_TAG_formal_parameter
50 .dwattr $C$DW$12, DW_AT_type(*$C$DW$T$11)
51$C$DW$13 .dwtag DW_TAG_formal_parameter
52 .dwattr $C$DW$13, DW_AT_type(*$C$DW$T$11)
53$C$DW$14 .dwtag DW_TAG_formal_parameter
54 .dwattr $C$DW$14, DW_AT_type(*$C$DW$T$105)
55 .dwendtag $C$DW$10
56
57
58$C$DW$15 .dwtag DW_TAG_subprogram, DW_AT_name("__delay_cycles")
59 .dwattr $C$DW$15, DW_AT_TI_symbol_name("__delay_cycles")
60 .dwattr $C$DW$15, DW_AT_declaration
61 .dwattr $C$DW$15, DW_AT_external
62$C$DW$16 .dwtag DW_TAG_formal_parameter
63 .dwattr $C$DW$16, DW_AT_type(*$C$DW$T$11)
64 .dwendtag $C$DW$15
65
66 .weak ||CT_CFG||
67||CT_CFG||: .usect ".creg.PRU_CFG.noload.near",68,1
68$C$DW$17 .dwtag DW_TAG_variable, DW_AT_name("CT_CFG")
69 .dwattr $C$DW$17, DW_AT_TI_symbol_name("CT_CFG")
70 .dwattr $C$DW$17, DW_AT_location[DW_OP_addr ||CT_CFG||]
71 .dwattr $C$DW$17, DW_AT_type(*$C$DW$T$99)
72 .dwattr $C$DW$17, DW_AT_external
73 .dwattr $C$DW$17, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
74 .dwattr $C$DW$17, DW_AT_decl_line(0xf2)
75 .dwattr $C$DW$17, DW_AT_decl_column(0x17)
76 .global ||pru_remoteproc_ResourceTable||
77 .sect ".resource_table:retain", RW
78 .retain
79 .align 1
80 .elfsym ||pru_remoteproc_ResourceTable||,SYM_SIZE(20)
81||pru_remoteproc_ResourceTable||:
82 .bits 1,32 ; pru_remoteproc_ResourceTable.base.ver @ 0
83 .bits 0,32 ; pru_remoteproc_ResourceTable.base.num @ 32
84 .bits 0,32 ; pru_remoteproc_ResourceTable.base.reserved[0] @ 64
85 .bits 0,32 ; pru_remoteproc_ResourceTable.base.reserved[1] @ 96
86 .bits 0,32 ; pru_remoteproc_ResourceTable.offset[0] @ 128
87
88$C$DW$18 .dwtag DW_TAG_variable, DW_AT_name("pru_remoteproc_ResourceTable")
89 .dwattr $C$DW$18, DW_AT_TI_symbol_name("pru_remoteproc_ResourceTable")
90 .dwattr $C$DW$18, DW_AT_location[DW_OP_addr ||pru_remoteproc_ResourceTable||]
91 .dwattr $C$DW$18, DW_AT_type(*$C$DW$T$93)
92 .dwattr $C$DW$18, DW_AT_external
93 .dwattr $C$DW$18, DW_AT_decl_file("resource_table_empty.h")
94 .dwattr $C$DW$18, DW_AT_decl_line(0x40)
95 .dwattr $C$DW$18, DW_AT_decl_column(0x1a)
96 .global ||data_buf||
97 .common ||data_buf||,24,1
98$C$DW$19 .dwtag DW_TAG_variable, DW_AT_name("data_buf")
99 .dwattr $C$DW$19, DW_AT_TI_symbol_name("data_buf")
100 .dwattr $C$DW$19, DW_AT_location[DW_OP_addr ||data_buf||]
101 .dwattr $C$DW$19, DW_AT_type(*$C$DW$T$132)
102 .dwattr $C$DW$19, DW_AT_external
103 .dwattr $C$DW$19, DW_AT_decl_file("PRU_ADS8688_Controller.c")
104 .dwattr $C$DW$19, DW_AT_decl_line(0x7a)
105 .dwattr $C$DW$19, DW_AT_decl_column(0x0a)
106 .global ||config_buf||
107 .common ||config_buf||,24,1
108$C$DW$20 .dwtag DW_TAG_variable, DW_AT_name("config_buf")
109 .dwattr $C$DW$20, DW_AT_TI_symbol_name("config_buf")
110 .dwattr $C$DW$20, DW_AT_location[DW_OP_addr ||config_buf||]
111 .dwattr $C$DW$20, DW_AT_type(*$C$DW$T$132)
112 .dwattr $C$DW$20, DW_AT_external
113 .dwattr $C$DW$20, DW_AT_decl_file("PRU_ADS8688_Controller.c")
114 .dwattr $C$DW$20, DW_AT_decl_line(0x7b)
115 .dwattr $C$DW$20, DW_AT_decl_column(0x0a)
116 .global ||debug||
117||debug||: .usect ".shared_mem",40,1
118$C$DW$21 .dwtag DW_TAG_variable, DW_AT_name("debug")
119 .dwattr $C$DW$21, DW_AT_TI_symbol_name("debug")
120 .dwattr $C$DW$21, DW_AT_location[DW_OP_addr ||debug||]
121 .dwattr $C$DW$21, DW_AT_type(*$C$DW$T$125)
122 .dwattr $C$DW$21, DW_AT_external
123 .dwattr $C$DW$21, DW_AT_decl_file("PRU_ADS8688_Controller.c")
124 .dwattr $C$DW$21, DW_AT_decl_line(0x109)
125 .dwattr $C$DW$21, DW_AT_decl_column(0x16)
126 .global ||chan_data_temp||
127 .common ||chan_data_temp||,192,1
128$C$DW$22 .dwtag DW_TAG_variable, DW_AT_name("chan_data_temp")
129 .dwattr $C$DW$22, DW_AT_TI_symbol_name("chan_data_temp")
130 .dwattr $C$DW$22, DW_AT_location[DW_OP_addr ||chan_data_temp||]
131 .dwattr $C$DW$22, DW_AT_type(*$C$DW$T$133)
132 .dwattr $C$DW$22, DW_AT_external
133 .dwattr $C$DW$22, DW_AT_decl_file("PRU_ADS8688_Controller.c")
134 .dwattr $C$DW$22, DW_AT_decl_line(0x10b)
135 .dwattr $C$DW$22, DW_AT_decl_column(0x0a)
136; /home/a0273976local/ti-cgt-pru_2.1.4/bin/optpru /tmp/16837JLdgNL /tmp/168373AbKQP
137; /home/a0273976local/ti-cgt-pru_2.1.4/bin/acpiapru -@/tmp/168375urK45
138 .sect ".text:send_delay"
139 .clink
140 .global ||send_delay||
141
142$C$DW$23 .dwtag DW_TAG_subprogram, DW_AT_name("send_delay")
143 .dwattr $C$DW$23, DW_AT_low_pc(||send_delay||)
144 .dwattr $C$DW$23, DW_AT_high_pc(0x00)
145 .dwattr $C$DW$23, DW_AT_TI_symbol_name("send_delay")
146 .dwattr $C$DW$23, DW_AT_external
147 .dwattr $C$DW$23, DW_AT_type(*$C$DW$T$10)
148 .dwattr $C$DW$23, DW_AT_TI_begin_file("PRU_ADS8688_Controller.c")
149 .dwattr $C$DW$23, DW_AT_TI_begin_line(0x7e)
150 .dwattr $C$DW$23, DW_AT_TI_begin_column(0x01)
151 .dwattr $C$DW$23, DW_AT_decl_file("PRU_ADS8688_Controller.c")
152 .dwattr $C$DW$23, DW_AT_decl_line(0x7e)
153 .dwattr $C$DW$23, DW_AT_decl_column(0x01)
154 .dwattr $C$DW$23, DW_AT_TI_max_frame_size(0x00)
155 .dwpsn file "PRU_ADS8688_Controller.c",line 126,column 32,is_stmt,address ||send_delay||,isa 0
156
157 .dwfde $C$DW$CIE, ||send_delay||
158$C$DW$24 .dwtag DW_TAG_formal_parameter, DW_AT_name("delay_val")
159 .dwattr $C$DW$24, DW_AT_TI_symbol_name("delay_val")
160 .dwattr $C$DW$24, DW_AT_type(*$C$DW$T$33)
161 .dwattr $C$DW$24, DW_AT_location[DW_OP_regx 0x38]
162
163;***************************************************************
164;* FNAME: send_delay FR SIZE: 0 *
165;* *
166;* FUNCTION ENVIRONMENT *
167;* *
168;* FUNCTION PROPERTIES *
169;* 0 Auto, 0 SOE *
170;***************************************************************
171
172||send_delay||:
173;* --------------------------------------------------------------------------*
174;* r14_0 assigned to delay_val
175$C$DW$25 .dwtag DW_TAG_variable, DW_AT_name("delay_val")
176 .dwattr $C$DW$25, DW_AT_TI_symbol_name("delay_val")
177 .dwattr $C$DW$25, DW_AT_type(*$C$DW$T$33)
178 .dwattr $C$DW$25, DW_AT_location[DW_OP_regx 0x38]
179 .dwcfi cfa_offset, 0
180 .dwpsn file "PRU_ADS8688_Controller.c",line 128,column 2,is_stmt,isa 0
181 MOV r21, r14 ; [ALU_PRU] |128| delay_val
182 XOUT 0x0a, &r21.b0, 0x04 ; [ALU_PRU] |128|
183$C$DW$26 .dwtag DW_TAG_TI_branch
184 .dwattr $C$DW$26, DW_AT_low_pc(0x00)
185 .dwattr $C$DW$26, DW_AT_TI_return
186 JMP r3.w2 ; [ALU_PRU]
187 .dwattr $C$DW$23, DW_AT_TI_end_file("PRU_ADS8688_Controller.c")
188 .dwattr $C$DW$23, DW_AT_TI_end_line(0x81)
189 .dwattr $C$DW$23, DW_AT_TI_end_column(0x01)
190 .dwendentry
191 .dwendtag $C$DW$23
192
193 .sect ".text:send_command"
194 .clink
195 .global ||send_command||
196
197$C$DW$27 .dwtag DW_TAG_subprogram, DW_AT_name("send_command")
198 .dwattr $C$DW$27, DW_AT_low_pc(||send_command||)
199 .dwattr $C$DW$27, DW_AT_high_pc(0x00)
200 .dwattr $C$DW$27, DW_AT_TI_symbol_name("send_command")
201 .dwattr $C$DW$27, DW_AT_external
202 .dwattr $C$DW$27, DW_AT_type(*$C$DW$T$10)
203 .dwattr $C$DW$27, DW_AT_TI_begin_file("PRU_ADS8688_Controller.c")
204 .dwattr $C$DW$27, DW_AT_TI_begin_line(0x84)
205 .dwattr $C$DW$27, DW_AT_TI_begin_column(0x01)
206 .dwattr $C$DW$27, DW_AT_decl_file("PRU_ADS8688_Controller.c")
207 .dwattr $C$DW$27, DW_AT_decl_line(0x84)
208 .dwattr $C$DW$27, DW_AT_decl_column(0x01)
209 .dwattr $C$DW$27, DW_AT_TI_max_frame_size(0x00)
210 .dwpsn file "PRU_ADS8688_Controller.c",line 132,column 35,is_stmt,address ||send_command||,isa 0
211
212 .dwfde $C$DW$CIE, ||send_command||
213$C$DW$28 .dwtag DW_TAG_formal_parameter, DW_AT_name("continuous")
214 .dwattr $C$DW$28, DW_AT_TI_symbol_name("continuous")
215 .dwattr $C$DW$28, DW_AT_type(*$C$DW$T$115)
216 .dwattr $C$DW$28, DW_AT_location[DW_OP_regx 0x38]
217
218;***************************************************************
219;* FNAME: send_command FR SIZE: 0 *
220;* *
221;* FUNCTION ENVIRONMENT *
222;* *
223;* FUNCTION PROPERTIES *
224;* 0 Auto, 0 SOE *
225;***************************************************************
226
227||send_command||:
228;* --------------------------------------------------------------------------*
229;* r28_0 assigned to status
230$C$DW$29 .dwtag DW_TAG_variable, DW_AT_name("status")
231 .dwattr $C$DW$29, DW_AT_TI_symbol_name("status")
232 .dwattr $C$DW$29, DW_AT_type(*$C$DW$T$33)
233 .dwattr $C$DW$29, DW_AT_location[DW_OP_regx 0x70]
234;* r29_0 assigned to request
235$C$DW$30 .dwtag DW_TAG_variable, DW_AT_name("request")
236 .dwattr $C$DW$30, DW_AT_TI_symbol_name("request")
237 .dwattr $C$DW$30, DW_AT_type(*$C$DW$T$33)
238 .dwattr $C$DW$30, DW_AT_location[DW_OP_regx 0x74]
239;* r14_0 assigned to continuous
240$C$DW$31 .dwtag DW_TAG_variable, DW_AT_name("continuous")
241 .dwattr $C$DW$31, DW_AT_TI_symbol_name("continuous")
242 .dwattr $C$DW$31, DW_AT_type(*$C$DW$T$116)
243 .dwattr $C$DW$31, DW_AT_location[DW_OP_regx 0x38]
244 .dwcfi cfa_offset, 0
245 .dwpsn file "PRU_ADS8688_Controller.c",line 133,column 27,is_stmt,isa 0
246 ZERO &r28, 4 ; [ALU_PRU] |133| status
247 .dwpsn file "PRU_ADS8688_Controller.c",line 137,column 2,is_stmt,isa 0
248 JMP ||$C$L2|| ; [ALU_PRU] |137|
249;* --------------------------------------------------------------------------*
250||$C$L1||:
251 .dwpsn file "PRU_ADS8688_Controller.c",line 138,column 3,is_stmt,isa 0
252 XIN 0x0b, &r28.b0, 0x04 ; [ALU_PRU] |138|
253;* --------------------------------------------------------------------------*
254;* BEGIN LOOP ||$C$L2||
255;* --------------------------------------------------------------------------*
256||$C$L2||:
257 .dwpsn file "PRU_ADS8688_Controller.c",line 137,column 9,is_stmt,isa 0
258 QBBC ||$C$L1||, r28, 0x00 ; [ALU_PRU] |137| status
259;* --------------------------------------------------------------------------*
260 .dwpsn file "PRU_ADS8688_Controller.c",line 142,column 2,is_stmt,isa 0
261 LDI r0, ||config_buf|| ; [ALU_PRU] |142| config_buf
262 LBBO &r15.b0, r0, 0, 24 ; [ALU_PRU] |142|
263 XOUT 0x0a, &r15.b0, 0x18 ; [ALU_PRU] |142|
264 .dwpsn file "PRU_ADS8688_Controller.c",line 147,column 3,is_stmt,isa 0
265 QBEQ ||$C$L3||, r14.w0, 0x00 ; [ALU_PRU] |147| continuous
266;* --------------------------------------------------------------------------*
267 LDI r29, 0x0003 ; [ALU_PRU] |147| request
268 JMP ||$C$L4|| ; [ALU_PRU] |147|
269;* --------------------------------------------------------------------------*
270||$C$L3||:
271 LDI r29, 0x0001 ; [ALU_PRU] |147| request
272;* --------------------------------------------------------------------------*
273||$C$L4||:
274 .dwpsn file "PRU_ADS8688_Controller.c",line 148,column 2,is_stmt,isa 0
275 XOUT 0x0b, &r29.b0, 0x04 ; [ALU_PRU] |148|
276 .dwpsn file "PRU_ADS8688_Controller.c",line 151,column 2,is_stmt,isa 0
277 JMP ||$C$L6|| ; [ALU_PRU] |151|
278;* --------------------------------------------------------------------------*
279||$C$L5||:
280 .dwpsn file "PRU_ADS8688_Controller.c",line 152,column 3,is_stmt,isa 0
281 XIN 0x0b, &r28.b0, 0x04 ; [ALU_PRU] |152|
282;* --------------------------------------------------------------------------*
283;* BEGIN LOOP ||$C$L6||
284;* --------------------------------------------------------------------------*
285||$C$L6||:
286 .dwpsn file "PRU_ADS8688_Controller.c",line 151,column 9,is_stmt,isa 0
287 QBBC ||$C$L5||, r28, 0x01 ; [ALU_PRU] |151| status
288;* --------------------------------------------------------------------------*
289 .dwpsn file "PRU_ADS8688_Controller.c",line 156,column 2,is_stmt,isa 0
290 CLR r29, r29, 0x00000000 ; [ALU_PRU] |156| request,request
291 .dwpsn file "PRU_ADS8688_Controller.c",line 157,column 2,is_stmt,isa 0
292 XOUT 0x0b, &r29.b0, 0x04 ; [ALU_PRU] |157|
293$C$DW$32 .dwtag DW_TAG_TI_branch
294 .dwattr $C$DW$32, DW_AT_low_pc(0x00)
295 .dwattr $C$DW$32, DW_AT_TI_return
296 JMP r3.w2 ; [ALU_PRU]
297 .dwattr $C$DW$27, DW_AT_TI_end_file("PRU_ADS8688_Controller.c")
298 .dwattr $C$DW$27, DW_AT_TI_end_line(0x9e)
299 .dwattr $C$DW$27, DW_AT_TI_end_column(0x01)
300 .dwendentry
301 .dwendtag $C$DW$27
302
303 .sect ".text:receive_data"
304 .clink
305 .global ||receive_data||
306
307$C$DW$33 .dwtag DW_TAG_subprogram, DW_AT_name("receive_data")
308 .dwattr $C$DW$33, DW_AT_low_pc(||receive_data||)
309 .dwattr $C$DW$33, DW_AT_high_pc(0x00)
310 .dwattr $C$DW$33, DW_AT_TI_symbol_name("receive_data")
311 .dwattr $C$DW$33, DW_AT_external
312 .dwattr $C$DW$33, DW_AT_type(*$C$DW$T$10)
313 .dwattr $C$DW$33, DW_AT_TI_begin_file("PRU_ADS8688_Controller.c")
314 .dwattr $C$DW$33, DW_AT_TI_begin_line(0xa1)
315 .dwattr $C$DW$33, DW_AT_TI_begin_column(0x01)
316 .dwattr $C$DW$33, DW_AT_decl_file("PRU_ADS8688_Controller.c")
317 .dwattr $C$DW$33, DW_AT_decl_line(0xa1)
318 .dwattr $C$DW$33, DW_AT_decl_column(0x01)
319 .dwattr $C$DW$33, DW_AT_TI_max_frame_size(0x00)
320 .dwpsn file "PRU_ADS8688_Controller.c",line 161,column 16,is_stmt,address ||receive_data||,isa 0
321
322 .dwfde $C$DW$CIE, ||receive_data||
323
324;***************************************************************
325;* FNAME: receive_data FR SIZE: 0 *
326;* *
327;* FUNCTION ENVIRONMENT *
328;* *
329;* FUNCTION PROPERTIES *
330;* 0 Auto, 0 SOE *
331;***************************************************************
332
333||receive_data||:
334;* --------------------------------------------------------------------------*
335;* r28_0 assigned to status
336$C$DW$34 .dwtag DW_TAG_variable, DW_AT_name("status")
337 .dwattr $C$DW$34, DW_AT_TI_symbol_name("status")
338 .dwattr $C$DW$34, DW_AT_type(*$C$DW$T$33)
339 .dwattr $C$DW$34, DW_AT_location[DW_OP_regx 0x70]
340;* r29_0 assigned to request
341$C$DW$35 .dwtag DW_TAG_variable, DW_AT_name("request")
342 .dwattr $C$DW$35, DW_AT_TI_symbol_name("request")
343 .dwattr $C$DW$35, DW_AT_type(*$C$DW$T$33)
344 .dwattr $C$DW$35, DW_AT_location[DW_OP_regx 0x74]
345 .dwcfi cfa_offset, 0
346 .dwpsn file "PRU_ADS8688_Controller.c",line 166,column 2,is_stmt,isa 0
347 XIN 0x0b, &r29.b0, 0x04 ; [ALU_PRU] |166|
348 .dwpsn file "PRU_ADS8688_Controller.c",line 169,column 2,is_stmt,isa 0
349 SET r29, r29, 0x00000002 ; [ALU_PRU] |169| request,request
350 .dwpsn file "PRU_ADS8688_Controller.c",line 170,column 2,is_stmt,isa 0
351 CLR r29, r29, 0x00000003 ; [ALU_PRU] |170| request,request
352 .dwpsn file "PRU_ADS8688_Controller.c",line 171,column 2,is_stmt,isa 0
353 XOUT 0x0b, &r29.b0, 0x04 ; [ALU_PRU] |171|
354 .dwpsn file "PRU_ADS8688_Controller.c",line 162,column 27,is_stmt,isa 0
355 ZERO &r28, 4 ; [ALU_PRU] |162| status
356 .dwpsn file "PRU_ADS8688_Controller.c",line 176,column 2,is_stmt,isa 0
357 CLR r29, r29, 0x00000002 ; [ALU_PRU] |176| request,request
358 .dwpsn file "PRU_ADS8688_Controller.c",line 177,column 2,is_stmt,isa 0
359 SET r29, r29, 0x00000003 ; [ALU_PRU] |177| request,request
360 .dwpsn file "PRU_ADS8688_Controller.c",line 180,column 2,is_stmt,isa 0
361 JMP ||$C$L8|| ; [ALU_PRU] |180|
362;* --------------------------------------------------------------------------*
363||$C$L7||:
364 .dwpsn file "PRU_ADS8688_Controller.c",line 181,column 3,is_stmt,isa 0
365 XIN 0x0b, &r28.b0, 0x04 ; [ALU_PRU] |181|
366;* --------------------------------------------------------------------------*
367;* BEGIN LOOP ||$C$L8||
368;* --------------------------------------------------------------------------*
369||$C$L8||:
370 .dwpsn file "PRU_ADS8688_Controller.c",line 180,column 9,is_stmt,isa 0
371 QBBC ||$C$L7||, r28, 0x02 ; [ALU_PRU] |180| status
372;* --------------------------------------------------------------------------*
373 .dwpsn file "PRU_ADS8688_Controller.c",line 186,column 2,is_stmt,isa 0
374 XOUT 0x0b, &r29.b0, 0x04 ; [ALU_PRU] |186|
375 .dwpsn file "PRU_ADS8688_Controller.c",line 189,column 2,is_stmt,isa 0
376 XIN 0x0c, &r22.b0, 0x18 ; [ALU_PRU] |189|
377 LDI r0, ||data_buf|| ; [ALU_PRU] |189| data_buf
378 SBBO &r22.b0, r0, 0, 24 ; [ALU_PRU] |189|
379$C$DW$36 .dwtag DW_TAG_TI_branch
380 .dwattr $C$DW$36, DW_AT_low_pc(0x00)
381 .dwattr $C$DW$36, DW_AT_TI_return
382 JMP r3.w2 ; [ALU_PRU]
383 .dwattr $C$DW$33, DW_AT_TI_end_file("PRU_ADS8688_Controller.c")
384 .dwattr $C$DW$33, DW_AT_TI_end_line(0xbe)
385 .dwattr $C$DW$33, DW_AT_TI_end_column(0x01)
386 .dwendentry
387 .dwendtag $C$DW$33
388
389 .sect ".text:adc_init"
390 .clink
391 .global ||adc_init||
392
393$C$DW$37 .dwtag DW_TAG_subprogram, DW_AT_name("adc_init")
394 .dwattr $C$DW$37, DW_AT_low_pc(||adc_init||)
395 .dwattr $C$DW$37, DW_AT_high_pc(0x00)
396 .dwattr $C$DW$37, DW_AT_TI_symbol_name("adc_init")
397 .dwattr $C$DW$37, DW_AT_external
398 .dwattr $C$DW$37, DW_AT_type(*$C$DW$T$10)
399 .dwattr $C$DW$37, DW_AT_TI_begin_file("PRU_ADS8688_Controller.c")
400 .dwattr $C$DW$37, DW_AT_TI_begin_line(0xc1)
401 .dwattr $C$DW$37, DW_AT_TI_begin_column(0x01)
402 .dwattr $C$DW$37, DW_AT_decl_file("PRU_ADS8688_Controller.c")
403 .dwattr $C$DW$37, DW_AT_decl_line(0xc1)
404 .dwattr $C$DW$37, DW_AT_decl_column(0x01)
405 .dwattr $C$DW$37, DW_AT_TI_max_frame_size(0x16)
406 .dwpsn file "PRU_ADS8688_Controller.c",line 193,column 12,is_stmt,address ||adc_init||,isa 0
407
408 .dwfde $C$DW$CIE, ||adc_init||
409
410;***************************************************************
411;* FNAME: adc_init FR SIZE: 22 *
412;* *
413;* FUNCTION ENVIRONMENT *
414;* *
415;* FUNCTION PROPERTIES *
416;* 0 Auto, 22 SOE *
417;***************************************************************
418
419||adc_init||:
420;* --------------------------------------------------------------------------*
421;* r0_0 assigned to $O$C1
422;* r21_0 assigned to $O$C2
423;* r8_0 assigned to $O$C3
424;* r7_0 assigned to $O$C4
425;* r6_0 assigned to $O$C5
426;* r5_0 assigned to $O$C6
427;* r4_0 assigned to $O$C7
428;* r1_0 assigned to $O$C8
429;* r0_0 assigned to $O$C9
430;* r0_0 assigned to $O$C10
431;* r0_0 assigned to $O$C11
432;* r28_0 assigned to status
433$C$DW$38 .dwtag DW_TAG_variable, DW_AT_name("status")
434 .dwattr $C$DW$38, DW_AT_TI_symbol_name("status")
435 .dwattr $C$DW$38, DW_AT_type(*$C$DW$T$33)
436 .dwattr $C$DW$38, DW_AT_location[DW_OP_regx 0x70]
437 .dwcfi cfa_offset, 0
438 SUB r2, r2, 0x16 ; [ALU_PRU]
439 .dwcfi cfa_offset, 22
440 .dwpsn file "PRU_ADS8688_Controller.c",line 194,column 18,is_stmt,isa 0
441 ZERO &r28, 4 ; [ALU_PRU] |194| status
442 SBBO &r3.b2, r2, 0, 22 ; [ALU_PRU]
443 .dwcfi save_reg_to_mem, 14, -22
444 .dwcfi save_reg_to_mem, 15, -21
445 .dwcfi save_reg_to_mem, 16, -20
446 .dwcfi save_reg_to_mem, 17, -19
447 .dwcfi save_reg_to_mem, 18, -18
448 .dwcfi save_reg_to_mem, 19, -17
449 .dwcfi save_reg_to_mem, 20, -16
450 .dwcfi save_reg_to_mem, 21, -15
451 .dwcfi save_reg_to_mem, 22, -14
452 .dwcfi save_reg_to_mem, 23, -13
453 .dwcfi save_reg_to_mem, 24, -12
454 .dwcfi save_reg_to_mem, 25, -11
455 .dwcfi save_reg_to_mem, 26, -10
456 .dwcfi save_reg_to_mem, 27, -9
457 .dwcfi save_reg_to_mem, 28, -8
458 .dwcfi save_reg_to_mem, 29, -7
459 .dwcfi save_reg_to_mem, 30, -6
460 .dwcfi save_reg_to_mem, 31, -5
461 .dwcfi save_reg_to_mem, 32, -4
462 .dwcfi save_reg_to_mem, 33, -3
463 .dwcfi save_reg_to_mem, 34, -2
464 .dwcfi save_reg_to_mem, 35, -1
465 .dwpsn file "PRU_ADS8688_Controller.c",line 198,column 2,is_stmt,isa 0
466 JMP ||$C$L10|| ; [ALU_PRU] |198|
467;* --------------------------------------------------------------------------*
468||$C$L9||:
469 .dwpsn file "PRU_ADS8688_Controller.c",line 199,column 3,is_stmt,isa 0
470 XIN 0x0b, &r28.b0, 0x04 ; [ALU_PRU] |199|
471;* --------------------------------------------------------------------------*
472;* BEGIN LOOP ||$C$L10||
473;* --------------------------------------------------------------------------*
474||$C$L10||:
475 .dwpsn file "PRU_ADS8688_Controller.c",line 198,column 9,is_stmt,isa 0
476 QBBC ||$C$L9||, r28, 0x00 ; [ALU_PRU] |198| status
477;* --------------------------------------------------------------------------*
478 .dwpsn file "PRU_ADS8688_Controller.c",line 204,column 2,is_stmt,isa 0
479 LDI r1, ||config_buf|| ; [ALU_PRU] |204| $O$C8,config_buf
480 LDI r0, 0x8500 ; [ALU_PRU] |204| $O$C11
481 .dwpsn file "PRU_ADS8688_Controller.c",line 205,column 2,is_stmt,isa 0
482 ADD r4, r1, 0x04 ; [ALU_PRU] |205| $O$C7,$O$C8
483 .dwpsn file "PRU_ADS8688_Controller.c",line 210,column 2,is_stmt,isa 0
484 LDI r14.w0, 0x0000 ; [ALU_PRU] |210|
485 .dwpsn file "PRU_ADS8688_Controller.c",line 204,column 2,is_stmt,isa 0
486 SBBO &r0, r1, 0, 4 ; [ALU_PRU] |204| $O$C8,$O$C11
487 .dwpsn file "PRU_ADS8688_Controller.c",line 206,column 2,is_stmt,isa 0
488 ADD r5, r1, 0x08 ; [ALU_PRU] |206| $O$C6,$O$C8
489 .dwpsn file "PRU_ADS8688_Controller.c",line 207,column 2,is_stmt,isa 0
490 ADD r6, r1, 0x0c ; [ALU_PRU] |207| $O$C5,$O$C8
491 .dwpsn file "PRU_ADS8688_Controller.c",line 205,column 2,is_stmt,isa 0
492 SBBO &r0, r4, 0, 4 ; [ALU_PRU] |205| $O$C7,$O$C11
493 .dwpsn file "PRU_ADS8688_Controller.c",line 208,column 2,is_stmt,isa 0
494 ADD r7, r1, 0x10 ; [ALU_PRU] |208| $O$C4,$O$C8
495 .dwpsn file "PRU_ADS8688_Controller.c",line 209,column 2,is_stmt,isa 0
496 ADD r8, r1, 0x14 ; [ALU_PRU] |209| $O$C3,$O$C8
497 .dwpsn file "PRU_ADS8688_Controller.c",line 206,column 2,is_stmt,isa 0
498 SBBO &r0, r5, 0, 4 ; [ALU_PRU] |206| $O$C6,$O$C11
499 .dwpsn file "PRU_ADS8688_Controller.c",line 207,column 2,is_stmt,isa 0
500 SBBO &r0, r6, 0, 4 ; [ALU_PRU] |207| $O$C5,$O$C11
501 .dwpsn file "PRU_ADS8688_Controller.c",line 208,column 2,is_stmt,isa 0
502 SBBO &r0, r7, 0, 4 ; [ALU_PRU] |208| $O$C4,$O$C11
503 .dwpsn file "PRU_ADS8688_Controller.c",line 209,column 2,is_stmt,isa 0
504 SBBO &r0, r8, 0, 4 ; [ALU_PRU] |209| $O$C3,$O$C11
505 .dwpsn file "PRU_ADS8688_Controller.c",line 210,column 2,is_stmt,isa 0
506$C$DW$39 .dwtag DW_TAG_TI_branch
507 .dwattr $C$DW$39, DW_AT_low_pc(0x00)
508 .dwattr $C$DW$39, DW_AT_name("send_command")
509 .dwattr $C$DW$39, DW_AT_TI_call
510 JAL r3.w2, ||send_command|| ; [ALU_PRU] |210| send_command
511 .dwpsn file "PRU_ADS8688_Controller.c",line 211,column 2,is_stmt,isa 0
512$C$DW$40 .dwtag DW_TAG_TI_branch
513 .dwattr $C$DW$40, DW_AT_low_pc(0x00)
514 .dwattr $C$DW$40, DW_AT_name("receive_data")
515 .dwattr $C$DW$40, DW_AT_TI_call
516 JAL r3.w2, ||receive_data|| ; [ALU_PRU] |211| receive_data
517 .dwpsn file "PRU_ADS8688_Controller.c",line 221,column 2,is_stmt,isa 0
518 LDI r0, 0x03ff ; [ALU_PRU] |221| $O$C10
519 SBBO &r0, r1, 0, 4 ; [ALU_PRU] |221| $O$C8,$O$C10
520 .dwpsn file "PRU_ADS8688_Controller.c",line 222,column 2,is_stmt,isa 0
521 SBBO &r0, r4, 0, 4 ; [ALU_PRU] |222| $O$C7,$O$C10
522 .dwpsn file "PRU_ADS8688_Controller.c",line 223,column 2,is_stmt,isa 0
523 SBBO &r0, r5, 0, 4 ; [ALU_PRU] |223| $O$C6,$O$C10
524 .dwpsn file "PRU_ADS8688_Controller.c",line 224,column 2,is_stmt,isa 0
525 SBBO &r0, r6, 0, 4 ; [ALU_PRU] |224| $O$C5,$O$C10
526 .dwpsn file "PRU_ADS8688_Controller.c",line 225,column 2,is_stmt,isa 0
527 SBBO &r0, r7, 0, 4 ; [ALU_PRU] |225| $O$C4,$O$C10
528 .dwpsn file "PRU_ADS8688_Controller.c",line 226,column 2,is_stmt,isa 0
529 SBBO &r0, r8, 0, 4 ; [ALU_PRU] |226| $O$C3,$O$C10
530 .dwpsn file "PRU_ADS8688_Controller.c",line 227,column 2,is_stmt,isa 0
531$C$DW$41 .dwtag DW_TAG_TI_branch
532 .dwattr $C$DW$41, DW_AT_low_pc(0x00)
533 .dwattr $C$DW$41, DW_AT_name("send_command")
534 .dwattr $C$DW$41, DW_AT_TI_call
535 JAL r3.w2, ||send_command|| ; [ALU_PRU] |227| send_command
536 .dwpsn file "PRU_ADS8688_Controller.c",line 228,column 2,is_stmt,isa 0
537$C$DW$42 .dwtag DW_TAG_TI_branch
538 .dwattr $C$DW$42, DW_AT_low_pc(0x00)
539 .dwattr $C$DW$42, DW_AT_name("receive_data")
540 .dwattr $C$DW$42, DW_AT_TI_call
541 JAL r3.w2, ||receive_data|| ; [ALU_PRU] |228| receive_data
542 .dwpsn file "PRU_ADS8688_Controller.c",line 230,column 2,is_stmt,isa 0
543 .newblock
544 LDI32 r21, 99
545$1: SUB r21, r21, 1
546 QBNE $1, r21, 0 ; [ALU_PRU] |230|
547 .dwpsn file "PRU_ADS8688_Controller.c",line 233,column 2,is_stmt,isa 0
548 LDI r0, 0xa000 ; [ALU_PRU] |233| $O$C9
549 SBBO &r0, r1, 0, 4 ; [ALU_PRU] |233| $O$C8,$O$C9
550 .dwpsn file "PRU_ADS8688_Controller.c",line 234,column 2,is_stmt,isa 0
551 SBBO &r0, r4, 0, 4 ; [ALU_PRU] |234| $O$C7,$O$C9
552 .dwpsn file "PRU_ADS8688_Controller.c",line 235,column 2,is_stmt,isa 0
553 SBBO &r0, r5, 0, 4 ; [ALU_PRU] |235| $O$C6,$O$C9
554 .dwpsn file "PRU_ADS8688_Controller.c",line 236,column 2,is_stmt,isa 0
555 SBBO &r0, r6, 0, 4 ; [ALU_PRU] |236| $O$C5,$O$C9
556 .dwpsn file "PRU_ADS8688_Controller.c",line 237,column 2,is_stmt,isa 0
557 SBBO &r0, r7, 0, 4 ; [ALU_PRU] |237| $O$C4,$O$C9
558 .dwpsn file "PRU_ADS8688_Controller.c",line 238,column 2,is_stmt,isa 0
559 SBBO &r0, r8, 0, 4 ; [ALU_PRU] |238| $O$C3,$O$C9
560 .dwpsn file "PRU_ADS8688_Controller.c",line 239,column 2,is_stmt,isa 0
561$C$DW$43 .dwtag DW_TAG_TI_branch
562 .dwattr $C$DW$43, DW_AT_low_pc(0x00)
563 .dwattr $C$DW$43, DW_AT_name("send_command")
564 .dwattr $C$DW$43, DW_AT_TI_call
565 JAL r3.w2, ||send_command|| ; [ALU_PRU] |239| send_command
566 .dwpsn file "PRU_ADS8688_Controller.c",line 240,column 2,is_stmt,isa 0
567$C$DW$44 .dwtag DW_TAG_TI_branch
568 .dwattr $C$DW$44, DW_AT_low_pc(0x00)
569 .dwattr $C$DW$44, DW_AT_name("receive_data")
570 .dwattr $C$DW$44, DW_AT_TI_call
571 JAL r3.w2, ||receive_data|| ; [ALU_PRU] |240| receive_data
572 .dwpsn file "PRU_ADS8688_Controller.c",line 243,column 2,is_stmt,isa 0
573 LDI r14, 0x030d ; [ALU_PRU] |243|
574$C$DW$45 .dwtag DW_TAG_TI_branch
575 .dwattr $C$DW$45, DW_AT_low_pc(0x00)
576 .dwattr $C$DW$45, DW_AT_name("send_delay")
577 .dwattr $C$DW$45, DW_AT_TI_call
578 JAL r3.w2, ||send_delay|| ; [ALU_PRU] |243| send_delay
579 .dwpsn file "PRU_ADS8688_Controller.c",line 246,column 2,is_stmt,isa 0
580 ZERO &r21, 4 ; [ALU_PRU] |246| $O$C2
581 .dwpsn file "PRU_ADS8688_Controller.c",line 252,column 2,is_stmt,isa 0
582 LDI r14.w0, 0x0001 ; [ALU_PRU] |252|
583 .dwpsn file "PRU_ADS8688_Controller.c",line 246,column 2,is_stmt,isa 0
584 SBBO &r21, r1, 0, 4 ; [ALU_PRU] |246| $O$C8,$O$C2
585 .dwpsn file "PRU_ADS8688_Controller.c",line 247,column 2,is_stmt,isa 0
586 SBBO &r21, r4, 0, 4 ; [ALU_PRU] |247| $O$C7,$O$C2
587 .dwpsn file "PRU_ADS8688_Controller.c",line 248,column 2,is_stmt,isa 0
588 SBBO &r21, r5, 0, 4 ; [ALU_PRU] |248| $O$C6,$O$C2
589 .dwpsn file "PRU_ADS8688_Controller.c",line 249,column 2,is_stmt,isa 0
590 SBBO &r21, r6, 0, 4 ; [ALU_PRU] |249| $O$C5,$O$C2
591 .dwpsn file "PRU_ADS8688_Controller.c",line 250,column 2,is_stmt,isa 0
592 SBBO &r21, r7, 0, 4 ; [ALU_PRU] |250| $O$C4,$O$C2
593 .dwpsn file "PRU_ADS8688_Controller.c",line 251,column 2,is_stmt,isa 0
594 SBBO &r21, r8, 0, 4 ; [ALU_PRU] |251| $O$C3,$O$C2
595 .dwpsn file "PRU_ADS8688_Controller.c",line 252,column 2,is_stmt,isa 0
596$C$DW$46 .dwtag DW_TAG_TI_branch
597 .dwattr $C$DW$46, DW_AT_low_pc(0x00)
598 .dwattr $C$DW$46, DW_AT_name("send_command")
599 .dwattr $C$DW$46, DW_AT_TI_call
600 JAL r3.w2, ||send_command|| ; [ALU_PRU] |252| send_command
601 .dwpsn file "PRU_ADS8688_Controller.c",line 255,column 2,is_stmt,isa 0
602 LDI32 r0, 0x00022000 ; [ALU_PRU] |255| $O$C1
603 LBBO &r1, r0, 0, 4 ; [ALU_PRU] |255|
604 SET r1, r1, 0x00000003 ; [ALU_PRU] |255|
605 SBBO &r1, r0, 0, 4 ; [ALU_PRU] |255|
606 .dwpsn file "PRU_ADS8688_Controller.c",line 256,column 2,is_stmt,isa 0
607 SBBO &r21, r0, 12, 4 ; [ALU_PRU] |256| $O$C1,$O$C2
608 LBBO &r3.b2, r2, 0, 22 ; [ALU_PRU]
609 .dwcfi restore_reg, 14
610 .dwcfi restore_reg, 15
611 .dwcfi restore_reg, 16
612 .dwcfi restore_reg, 17
613 .dwcfi restore_reg, 18
614 .dwcfi restore_reg, 19
615 .dwcfi restore_reg, 20
616 .dwcfi restore_reg, 21
617 .dwcfi restore_reg, 22
618 .dwcfi restore_reg, 23
619 .dwcfi restore_reg, 24
620 .dwcfi restore_reg, 25
621 .dwcfi restore_reg, 26
622 .dwcfi restore_reg, 27
623 .dwcfi restore_reg, 28
624 .dwcfi restore_reg, 29
625 .dwcfi restore_reg, 30
626 .dwcfi restore_reg, 31
627 .dwcfi restore_reg, 32
628 .dwcfi restore_reg, 33
629 .dwcfi restore_reg, 34
630 .dwcfi restore_reg, 35
631 ADD r2, r2, 0x16 ; [ALU_PRU]
632 .dwcfi cfa_offset, 0
633$C$DW$47 .dwtag DW_TAG_TI_branch
634 .dwattr $C$DW$47, DW_AT_low_pc(0x00)
635 .dwattr $C$DW$47, DW_AT_TI_return
636 JMP r3.w2 ; [ALU_PRU]
637 .dwattr $C$DW$37, DW_AT_TI_end_file("PRU_ADS8688_Controller.c")
638 .dwattr $C$DW$37, DW_AT_TI_end_line(0x102)
639 .dwattr $C$DW$37, DW_AT_TI_end_column(0x01)
640 .dwendentry
641 .dwendtag $C$DW$37
642
643 .sect ".text:main"
644 .clink
645 .global ||main||
646
647$C$DW$48 .dwtag DW_TAG_subprogram, DW_AT_name("main")
648 .dwattr $C$DW$48, DW_AT_low_pc(||main||)
649 .dwattr $C$DW$48, DW_AT_high_pc(0x00)
650 .dwattr $C$DW$48, DW_AT_TI_symbol_name("main")
651 .dwattr $C$DW$48, DW_AT_external
652 .dwattr $C$DW$48, DW_AT_TI_begin_file("PRU_ADS8688_Controller.c")
653 .dwattr $C$DW$48, DW_AT_TI_begin_line(0x10d)
654 .dwattr $C$DW$48, DW_AT_TI_begin_column(0x06)
655 .dwattr $C$DW$48, DW_AT_decl_file("PRU_ADS8688_Controller.c")
656 .dwattr $C$DW$48, DW_AT_decl_line(0x10d)
657 .dwattr $C$DW$48, DW_AT_decl_column(0x06)
658 .dwattr $C$DW$48, DW_AT_TI_max_frame_size(0x4b)
659 .dwpsn file "PRU_ADS8688_Controller.c",line 270,column 1,is_stmt,address ||main||,isa 0
660
661 .dwfde $C$DW$CIE, ||main||
662
663;***************************************************************
664;* FNAME: main FR SIZE: 75 *
665;* *
666;* FUNCTION ENVIRONMENT *
667;* *
668;* FUNCTION PROPERTIES *
669;* 33 Auto, 42 SOE *
670;***************************************************************
671
672||main||:
673;* --------------------------------------------------------------------------*
674;* r15_0 assigned to $O$C1
675;* r0_0 assigned to $O$C2
676;* r5_0 assigned to i
677$C$DW$49 .dwtag DW_TAG_variable, DW_AT_name("i")
678 .dwattr $C$DW$49, DW_AT_TI_symbol_name("i")
679 .dwattr $C$DW$49, DW_AT_type(*$C$DW$T$33)
680 .dwattr $C$DW$49, DW_AT_location[DW_OP_reg20]
681;* r12_0 assigned to j
682$C$DW$50 .dwtag DW_TAG_variable, DW_AT_name("j")
683 .dwattr $C$DW$50, DW_AT_TI_symbol_name("j")
684 .dwattr $C$DW$50, DW_AT_type(*$C$DW$T$33)
685 .dwattr $C$DW$50, DW_AT_location[DW_OP_regx 0x30]
686;* r0_0 assigned to idx
687$C$DW$51 .dwtag DW_TAG_variable, DW_AT_name("idx")
688 .dwattr $C$DW$51, DW_AT_TI_symbol_name("idx")
689 .dwattr $C$DW$51, DW_AT_type(*$C$DW$T$33)
690 .dwattr $C$DW$51, DW_AT_location[DW_OP_reg0]
691;* r6_0 assigned to oversample
692$C$DW$52 .dwtag DW_TAG_variable, DW_AT_name("oversample")
693 .dwattr $C$DW$52, DW_AT_TI_symbol_name("oversample")
694 .dwattr $C$DW$52, DW_AT_type(*$C$DW$T$33)
695 .dwattr $C$DW$52, DW_AT_location[DW_OP_reg24]
696$C$DW$53 .dwtag DW_TAG_variable, DW_AT_name("last_pol")
697 .dwattr $C$DW$53, DW_AT_TI_symbol_name("last_pol")
698 .dwattr $C$DW$53, DW_AT_type(*$C$DW$T$123)
699 .dwattr $C$DW$53, DW_AT_location[DW_OP_breg8 9]
700;* r7_0 assigned to zero_crossings
701$C$DW$54 .dwtag DW_TAG_variable, DW_AT_name("zero_crossings")
702 .dwattr $C$DW$54, DW_AT_TI_symbol_name("zero_crossings")
703 .dwattr $C$DW$54, DW_AT_type(*$C$DW$T$33)
704 .dwattr $C$DW$54, DW_AT_location[DW_OP_reg28]
705$C$DW$55 .dwtag DW_TAG_variable, DW_AT_name("start")
706 .dwattr $C$DW$55, DW_AT_TI_symbol_name("start")
707 .dwattr $C$DW$55, DW_AT_type(*$C$DW$T$33)
708 .dwattr $C$DW$55, DW_AT_location[DW_OP_breg8 13]
709;* r1_0 assigned to stop
710$C$DW$56 .dwtag DW_TAG_variable, DW_AT_name("stop")
711 .dwattr $C$DW$56, DW_AT_TI_symbol_name("stop")
712 .dwattr $C$DW$56, DW_AT_type(*$C$DW$T$33)
713 .dwattr $C$DW$56, DW_AT_location[DW_OP_reg4]
714;* r4_0 assigned to delay
715$C$DW$57 .dwtag DW_TAG_variable, DW_AT_name("delay")
716 .dwattr $C$DW$57, DW_AT_TI_symbol_name("delay")
717 .dwattr $C$DW$57, DW_AT_type(*$C$DW$T$33)
718 .dwattr $C$DW$57, DW_AT_location[DW_OP_reg16]
719;* r8_0 assigned to compensation
720$C$DW$58 .dwtag DW_TAG_variable, DW_AT_name("compensation")
721 .dwattr $C$DW$58, DW_AT_TI_symbol_name("compensation")
722 .dwattr $C$DW$58, DW_AT_type(*$C$DW$T$33)
723 .dwattr $C$DW$58, DW_AT_location[DW_OP_regx 0x20]
724;* r9_0 assigned to curr_addr
725$C$DW$59 .dwtag DW_TAG_variable, DW_AT_name("curr_addr")
726 .dwattr $C$DW$59, DW_AT_TI_symbol_name("curr_addr")
727 .dwattr $C$DW$59, DW_AT_type(*$C$DW$T$33)
728 .dwattr $C$DW$59, DW_AT_location[DW_OP_regx 0x24]
729$C$DW$60 .dwtag DW_TAG_variable, DW_AT_name("curr_buff")
730 .dwattr $C$DW$60, DW_AT_TI_symbol_name("curr_buff")
731 .dwattr $C$DW$60, DW_AT_type(*$C$DW$T$112)
732 .dwattr $C$DW$60, DW_AT_location[DW_OP_breg8 0]
733;* r11_0 assigned to num_captured
734$C$DW$61 .dwtag DW_TAG_variable, DW_AT_name("num_captured")
735 .dwattr $C$DW$61, DW_AT_TI_symbol_name("num_captured")
736 .dwattr $C$DW$61, DW_AT_type(*$C$DW$T$33)
737 .dwattr $C$DW$61, DW_AT_location[DW_OP_regx 0x2c]
738;* r14_0 assigned to $O$U116
739;* r1_0 assigned to $O$U45
740;* r13_0 assigned to $O$U41
741;* r10_0 assigned to $O$K32
742 .dwcfi cfa_offset, 0
743 SUB r2, r2, 0x4b ; [ALU_PRU]
744 .dwcfi cfa_offset, 75
745 .dwpsn file "PRU_ADS8688_Controller.c",line 289,column 2,is_stmt,isa 0
746 ZERO &r28, 4 ; [ALU_PRU] |289|
747 SBBO &r3.b2, r2, 33, 42 ; [ALU_PRU]
748 .dwcfi save_reg_to_mem, 14, -42
749 .dwcfi save_reg_to_mem, 15, -41
750 .dwcfi save_reg_to_mem, 16, -40
751 .dwcfi save_reg_to_mem, 17, -39
752 .dwcfi save_reg_to_mem, 18, -38
753 .dwcfi save_reg_to_mem, 19, -37
754 .dwcfi save_reg_to_mem, 20, -36
755 .dwcfi save_reg_to_mem, 21, -35
756 .dwcfi save_reg_to_mem, 22, -34
757 .dwcfi save_reg_to_mem, 23, -33
758 .dwcfi save_reg_to_mem, 24, -32
759 .dwcfi save_reg_to_mem, 25, -31
760 .dwcfi save_reg_to_mem, 26, -30
761 .dwcfi save_reg_to_mem, 27, -29
762 .dwcfi save_reg_to_mem, 28, -28
763 .dwcfi save_reg_to_mem, 29, -27
764 .dwcfi save_reg_to_mem, 30, -26
765 .dwcfi save_reg_to_mem, 31, -25
766 .dwcfi save_reg_to_mem, 32, -24
767 .dwcfi save_reg_to_mem, 33, -23
768 .dwcfi save_reg_to_mem, 34, -22
769 .dwcfi save_reg_to_mem, 35, -21
770 .dwcfi save_reg_to_mem, 36, -20
771 .dwcfi save_reg_to_mem, 37, -19
772 .dwcfi save_reg_to_mem, 38, -18
773 .dwcfi save_reg_to_mem, 39, -17
774 .dwcfi save_reg_to_mem, 40, -16
775 .dwcfi save_reg_to_mem, 41, -15
776 .dwcfi save_reg_to_mem, 42, -14
777 .dwcfi save_reg_to_mem, 43, -13
778 .dwcfi save_reg_to_mem, 44, -12
779 .dwcfi save_reg_to_mem, 45, -11
780 .dwcfi save_reg_to_mem, 46, -10
781 .dwcfi save_reg_to_mem, 47, -9
782 .dwcfi save_reg_to_mem, 48, -8
783 .dwcfi save_reg_to_mem, 49, -7
784 .dwcfi save_reg_to_mem, 50, -6
785 .dwcfi save_reg_to_mem, 51, -5
786 .dwcfi save_reg_to_mem, 52, -4
787 .dwcfi save_reg_to_mem, 53, -3
788 .dwcfi save_reg_to_mem, 54, -2
789 .dwcfi save_reg_to_mem, 55, -1
790 XOUT 0x0b, &r28.b0, 0x04 ; [ALU_PRU] |289|
791 .dwpsn file "PRU_ADS8688_Controller.c",line 290,column 2,is_stmt,isa 0
792 ZERO &r29, 4 ; [ALU_PRU] |290|
793 XOUT 0x0b, &r29.b0, 0x04 ; [ALU_PRU] |290|
794 .dwpsn file "PRU_ADS8688_Controller.c",line 293,column 2,is_stmt,isa 0
795 LBCO &r0, __PRU_CREG_PRU_CFG, $CSBREL(||CT_CFG||+4), 4 ; [ALU_PRU] |293| CT_CFG
796 CLR r0, r0, 0x00000004 ; [ALU_PRU] |293|
797 SBCO &r0, __PRU_CREG_PRU_CFG, $CSBREL(||CT_CFG||+4), 4 ; [ALU_PRU] |293| CT_CFG
798 .dwpsn file "PRU_ADS8688_Controller.c",line 296,column 2,is_stmt,isa 0
799$C$DW$62 .dwtag DW_TAG_TI_branch
800 .dwattr $C$DW$62, DW_AT_low_pc(0x00)
801 .dwattr $C$DW$62, DW_AT_name("adc_init")
802 .dwattr $C$DW$62, DW_AT_TI_call
803 JAL r3.w2, ||adc_init|| ; [ALU_PRU] |296| adc_init
804 ZERO &r10, 4 ; [ALU_PRU] $O$K32
805 .dwpsn file "PRU_ADS8688_Controller.c",line 272,column 22,is_stmt,isa 0
806 LDI r6, 0x0001 ; [ALU_PRU] |272| oversample
807 .dwpsn file "PRU_ADS8688_Controller.c",line 274,column 26,is_stmt,isa 0
808 ZERO &r7, 4 ; [ALU_PRU] |274| zero_crossings
809 .dwpsn file "PRU_ADS8688_Controller.c",line 279,column 24,is_stmt,isa 0
810 ZERO &r11, 4 ; [ALU_PRU] |279| num_captured
811 .dwpsn file "PRU_ADS8688_Controller.c",line 281,column 2,is_stmt,isa 0
812 LDI r4, 0x030d ; [ALU_PRU] |281| delay
813 .dwpsn file "PRU_ADS8688_Controller.c",line 282,column 2,is_stmt,isa 0
814 LDI r8, 0x0002 ; [ALU_PRU] |282| compensation
815 .dwpsn file "PRU_ADS8688_Controller.c",line 285,column 2,is_stmt,isa 0
816 LDI32 r9, 0x9ffc0008 ; [ALU_PRU] |285| curr_addr
817 LDI32 r0, 0x00022000 ; [ALU_PRU] $O$K73
818 SBBO &r0, r2, 21, 4 ; [ALU_PRU] $C$SP6,$O$K73
819 LDI32 r0, 0x9ffc0000 ; [ALU_PRU] $O$Q1
820 SBBO &r0, r2, 1, 4 ; [ALU_PRU] $C$SP1,$O$Q1
821 LDI32 r0, 0x9ffe0000 ; [ALU_PRU] $O$Q2
822 SBBO &r0, r2, 5, 4 ; [ALU_PRU] $C$SP2,$O$Q2
823 LDI r0, 0xffff ; [ALU_PRU] $O$K108
824 SBBO &r0, r2, 17, 4 ; [ALU_PRU] $C$SP5,$O$K108
825 LDI r0, ||chan_data_temp|| ; [ALU_PRU] $O$K35,chan_data_temp
826 SBBO &r0, r2, 29, 4 ; [ALU_PRU] $C$SP8,$O$K35
827 .dwpsn file "PRU_ADS8688_Controller.c",line 273,column 19,is_stmt,isa 0
828 LDI r0, 0x0001 ; [ALU_PRU] |273| last_pol
829 SBBO &r0, r2, 9, 4 ; [ALU_PRU] |273| $C$SP3,last_pol
830 .dwpsn file "PRU_ADS8688_Controller.c",line 286,column 2,is_stmt,isa 0
831 LDI r0.b0, 0x00 ; [ALU_PRU] |286| curr_buff
832 SBBO &r0.b0, r2, 0, 1 ; [ALU_PRU] |286| $C$SP0,curr_buff
833;* --------------------------------------------------------------------------*
834;* BEGIN LOOP ||$C$L11||
835;*
836;* Loop source line : 298
837;* Loop closing brace source line : 389
838;* Known Minimum Trip Count : 1
839;* Known Maximum Trip Count : 4294967295
840;* Known Max Trip Count Factor : 1
841;* --------------------------------------------------------------------------*
842||$C$L11||:
843 .dwpsn file "PRU_ADS8688_Controller.c",line 299,column 8,is_stmt,isa 0
844 ZERO &r5, 4 ; [ALU_PRU] |299| i
845;* --------------------------------------------------------------------------*
846;* BEGIN LOOP ||$C$L12||
847;*
848;* Loop source line : 299
849;* Loop closing brace source line : 352
850;* Known Minimum Trip Count : 8
851;* Known Maximum Trip Count : 8
852;* Known Max Trip Count Factor : 8
853;* --------------------------------------------------------------------------*
854||$C$L12||:
855 .dwpsn file "PRU_ADS8688_Controller.c",line 301,column 4,is_stmt,isa 0
856 QBLT ||$C$L13||, r8, r5 ; [ALU_PRU] |301| i,compensation
857;* --------------------------------------------------------------------------*
858 MOV r14, r4 ; [ALU_PRU] delay
859 .dwpsn file "PRU_ADS8688_Controller.c",line 304,column 5,is_stmt,isa 0
860 JMP ||$C$L14|| ; [ALU_PRU] |304|
861;* --------------------------------------------------------------------------*
862||$C$L13||:
863 .dwpsn file "PRU_ADS8688_Controller.c",line 302,column 5,is_stmt,isa 0
864 ADD r14, r4, 0x01 ; [ALU_PRU] |302| delay
865;* --------------------------------------------------------------------------*
866||$C$L14||:
867$C$DW$63 .dwtag DW_TAG_TI_branch
868 .dwattr $C$DW$63, DW_AT_low_pc(0x00)
869 .dwattr $C$DW$63, DW_AT_name("send_delay")
870 .dwattr $C$DW$63, DW_AT_TI_call
871 JAL r3.w2, ||send_delay|| ; [ALU_PRU] |302| send_delay
872 .dwpsn file "PRU_ADS8688_Controller.c",line 305,column 4,is_stmt,isa 0
873$C$DW$64 .dwtag DW_TAG_TI_branch
874 .dwattr $C$DW$64, DW_AT_low_pc(0x00)
875 .dwattr $C$DW$64, DW_AT_name("receive_data")
876 .dwattr $C$DW$64, DW_AT_TI_call
877 JAL r3.w2, ||receive_data|| ; [ALU_PRU] |305| receive_data
878 LDI r13, ||data_buf|| ; [ALU_PRU] $O$U41,data_buf
879 .dwpsn file "PRU_ADS8688_Controller.c",line 306,column 9,is_stmt,isa 0
880 ZERO &r12, 4 ; [ALU_PRU] |306| j
881 SBBO &r5, r2, 25, 4 ; [ALU_PRU] $C$SP7,$O$U28
882;* --------------------------------------------------------------------------*
883;* BEGIN LOOP ||$C$L15||
884;*
885;* Loop source line : 306
886;* Loop closing brace source line : 351
887;* Known Minimum Trip Count : 6
888;* Known Maximum Trip Count : 6
889;* Known Max Trip Count Factor : 6
890;* --------------------------------------------------------------------------*
891||$C$L15||:
892 LBBO &r0, r2, 25, 4 ; [ALU_PRU] $O$U28,$C$SP7
893 .dwpsn file "PRU_ADS8688_Controller.c",line 310,column 5,is_stmt,isa 0
894 QBNE ||$C$L16||, r6, 0x01 ; [ALU_PRU] |310| oversample
895;* --------------------------------------------------------------------------*
896 .dwpsn file "PRU_ADS8688_Controller.c",line 311,column 6,is_stmt,isa 0
897 LSL r14, r0, 0x02 ; [ALU_PRU] |311| idx
898 LBBO &r1, r2, 29, 4 ; [ALU_PRU] |311| $O$K35,$C$SP8
899 SBBO &r10, r1, r14, 4 ; [ALU_PRU] |311| $O$K35,$O$K32
900;* --------------------------------------------------------------------------*
901||$C$L16||:
902 .dwpsn file "PRU_ADS8688_Controller.c",line 314,column 5,is_stmt,isa 0
903 LSL r1, r0, 0x02 ; [ALU_PRU] |314| idx
904 LBBO &r0, r2, 29, 4 ; [ALU_PRU] |314| $O$K35,$C$SP8
905 ADD r1, r1, r0 ; [ALU_PRU] |314| $O$U45,$O$K35
906 LBBO &r0.w0, r13, 0, 2 ; [ALU_PRU] |314| $O$U41
907 LBBO &r14, r1, 0, 4 ; [ALU_PRU] |314| $O$U45
908 ADD r0, r14, r0.w0 ; [ALU_PRU] |314|
909 SBBO &r0, r1, 0, 4 ; [ALU_PRU] |314| $O$U45
910 .dwpsn file "PRU_ADS8688_Controller.c",line 317,column 5,is_stmt,isa 0
911 QBNE ||$C$L22||, r6, 0x01 ; [ALU_PRU] |317| oversample
912;* --------------------------------------------------------------------------*
913 .dwpsn file "PRU_ADS8688_Controller.c",line 318,column 6,is_stmt,isa 0
914 MOV r15, r0.w0 ; [ALU_PRU] |318| $O$C1,$O$C2
915 SBBO &r15, r1, 0, 4 ; [ALU_PRU] |318| $O$U45,$O$C1
916 .dwpsn file "PRU_ADS8688_Controller.c",line 320,column 6,is_stmt,isa 0
917 QBNE ||$C$L22||, r12, 0x00 ; [ALU_PRU] |320| j
918;* --------------------------------------------------------------------------*
919 QBNE ||$C$L22||, r5, 0x05 ; [ALU_PRU] |320| i
920;* --------------------------------------------------------------------------*
921 LBBO &r0, r2, 9, 4 ; [ALU_PRU] last_pol,$C$SP3
922 LDI r14, 0x0000 ; [ALU_PRU] |320|
923 XOR r0.b3, r0.b3, 0x80 ; [ALU_PRU] |320|
924 XOR r14.b3, r14.b3, 0x80 ; [ALU_PRU] |320|
925 QBGE ||$C$L17||, r0, r14 ; [ALU_PRU] |320|
926;* --------------------------------------------------------------------------*
927 LDI r0.w2, 0x00 ; [ALU_PRU] |320|
928 LDI r0.w0, 0x8000 ; [ALU_PRU] |320|
929 XOR r0.b3, r0.b3, 0x80 ; [ALU_PRU] |320|
930 ADD r0.w0, r15.w0, r0.w0 ; [ALU_PRU] |320| $O$C1
931 XOR r0.b1, r0.b1, 0x80 ; [ALU_PRU] |320|
932 QBLE ||$C$L17||, r0.w0, r0.w2 ; [ALU_PRU] |320|
933;* --------------------------------------------------------------------------*
934 JMP ||$C$L18|| ; [ALU_PRU] |320|
935;* --------------------------------------------------------------------------*
936||$C$L17||:
937 LBBO &r0, r2, 9, 4 ; [ALU_PRU] last_pol,$C$SP3
938 LDI r14, 0x0000 ; [ALU_PRU] |320|
939 XOR r0.b3, r0.b3, 0x80 ; [ALU_PRU] |320|
940 XOR r14.b3, r14.b3, 0x80 ; [ALU_PRU] |320|
941 QBLE ||$C$L22||, r0, r14 ; [ALU_PRU] |320|
942;* --------------------------------------------------------------------------*
943 LBBO &r0.w2, r1, 0, 2 ; [ALU_PRU] |320| $O$U45
944 LDI r0.w0, 0x8000 ; [ALU_PRU] |320|
945 ADD r0.w0, r0.w2, r0.w0 ; [ALU_PRU] |320|
946 XOR r0.b1, r0.b1, 0x80 ; [ALU_PRU] |320|
947 LDI r0.w2, 0x00 ; [ALU_PRU] |320|
948 XOR r0.b3, r0.b3, 0x80 ; [ALU_PRU] |320|
949 QBGE ||$C$L22||, r0.w0, r0.w2 ; [ALU_PRU] |320|
950;* --------------------------------------------------------------------------*
951||$C$L18||:
952 LBBO &r0, r2, 9, 4 ; [ALU_PRU] last_pol,$C$SP3
953 .dwpsn file "PRU_ADS8688_Controller.c",line 327,column 8,is_stmt,isa 0
954 ADD r7, r7, 0x01 ; [ALU_PRU] |327| zero_crossings,zero_crossings
955 .dwpsn file "PRU_ADS8688_Controller.c",line 324,column 8,is_stmt,isa 0
956 NOT r0, r0 ; [ALU_PRU] |324| last_pol,last_pol
957 SBBO &r0, r2, 9, 4 ; [ALU_PRU] |324| $C$SP3,last_pol
958 .dwpsn file "PRU_ADS8688_Controller.c",line 327,column 8,is_stmt,isa 0
959 QBEQ ||$C$L21||, r7, 0x01 ; [ALU_PRU] |327| zero_crossings
960;* --------------------------------------------------------------------------*
961 .dwpsn file "PRU_ADS8688_Controller.c",line 331,column 13,is_stmt,isa 0
962 QBNE ||$C$L22||, r7, 0x0b ; [ALU_PRU] |331| zero_crossings
963;* --------------------------------------------------------------------------*
964 LBBO &r0, r2, 21, 4 ; [ALU_PRU] $O$K73,$C$SP6
965 .dwpsn file "PRU_ADS8688_Controller.c",line 334,column 9,is_stmt,isa 0
966 LDI r15, 0x0c80 ; [ALU_PRU] |334|
967 .dwpsn file "PRU_ADS8688_Controller.c",line 332,column 9,is_stmt,isa 0
968 LBBO &r1, r0, 12, 4 ; [ALU_PRU] |332| stop,$O$K73
969 LBBO &r0, r2, 13, 4 ; [ALU_PRU] |332| start,$C$SP4
970 .dwpsn file "PRU_ADS8688_Controller.c",line 334,column 9,is_stmt,isa 0
971 RSB r14, r0, r1 ; [ALU_PRU] |334| start,stop
972$C$DW$65 .dwtag DW_TAG_TI_branch
973 .dwattr $C$DW$65, DW_AT_low_pc(0x00)
974 .dwattr $C$DW$65, DW_AT_name("__pruabi_divu")
975 .dwattr $C$DW$65, DW_AT_TI_call
976 JAL r3.w2, ||__pruabi_divu|| ; [ALU_PRU] |334| __pruabi_divu
977 MOV r4, r14 ; [ALU_PRU] |334| delay
978 .dwpsn file "PRU_ADS8688_Controller.c",line 337,column 9,is_stmt,isa 0
979 LDI r0, 0x02c6 ; [ALU_PRU] |337|
980 .dwpsn file "PRU_ADS8688_Controller.c",line 335,column 9,is_stmt,isa 0
981 AND r8, r4, 0x07 ; [ALU_PRU] |335| compensation,delay
982 .dwpsn file "PRU_ADS8688_Controller.c",line 337,column 9,is_stmt,isa 0
983 LSR r4, r4, 0x03 ; [ALU_PRU] |337| delay,delay
984 QBLT ||$C$L19||, r0, r4 ; [ALU_PRU] |337| delay
985;* --------------------------------------------------------------------------*
986 .dwpsn file "PRU_ADS8688_Controller.c",line 341,column 14,is_stmt,isa 0
987 LDI r0, 0x0364 ; [ALU_PRU] |341|
988 QBLE ||$C$L20||, r0, r4 ; [ALU_PRU] |341| delay
989;* --------------------------------------------------------------------------*
990 .dwpsn file "PRU_ADS8688_Controller.c",line 342,column 10,is_stmt,isa 0
991 LDI r4, 0x0364 ; [ALU_PRU] |342| delay
992 .dwpsn file "PRU_ADS8688_Controller.c",line 343,column 10,is_stmt,isa 0
993 LDI r8, 0x0007 ; [ALU_PRU] |343| compensation
994 JMP ||$C$L20|| ; [ALU_PRU] |343|
995;* --------------------------------------------------------------------------*
996||$C$L19||:
997 .dwpsn file "PRU_ADS8688_Controller.c",line 338,column 10,is_stmt,isa 0
998 LDI r4, 0x02c6 ; [ALU_PRU] |338| delay
999 .dwpsn file "PRU_ADS8688_Controller.c",line 339,column 10,is_stmt,isa 0
1000 ZERO &r8, 4 ; [ALU_PRU] |339| compensation
1001;* --------------------------------------------------------------------------*
1002||$C$L20||:
1003 LBBO &r0, r2, 21, 4 ; [ALU_PRU] $O$K73,$C$SP6
1004 .dwpsn file "PRU_ADS8688_Controller.c",line 346,column 9,is_stmt,isa 0
1005 ZERO &r7, 4 ; [ALU_PRU] |346| zero_crossings
1006 .dwpsn file "PRU_ADS8688_Controller.c",line 345,column 9,is_stmt,isa 0
1007 SBBO &r10, r0, 12, 4 ; [ALU_PRU] |345| $O$K73,$O$K32
1008 .dwpsn file "PRU_ADS8688_Controller.c",line 346,column 9,is_stmt,isa 0
1009 JMP ||$C$L22|| ; [ALU_PRU] |346|
1010;* --------------------------------------------------------------------------*
1011||$C$L21||:
1012 LBBO &r0, r2, 21, 4 ; [ALU_PRU] $O$K73,$C$SP6
1013 .dwpsn file "PRU_ADS8688_Controller.c",line 328,column 9,is_stmt,isa 0
1014 LBBO &r0, r0, 12, 4 ; [ALU_PRU] |328| start,$O$K73
1015 SBBO &r0, r2, 13, 4 ; [ALU_PRU] |328| $C$SP4,start
1016;* --------------------------------------------------------------------------*
1017||$C$L22||:
1018 LBBO &r0, r2, 25, 4 ; [ALU_PRU] $O$U28,$C$SP7
1019 .dwpsn file "PRU_ADS8688_Controller.c",line 306,column 16,is_stmt,isa 0
1020 ADD r0, r0, 0x08 ; [ALU_PRU] |306| $O$U28,$O$U28
1021 ADD r13, r13, 0x04 ; [ALU_PRU] |306| $O$U41,$O$U41
1022 ADD r12, r12, 0x01 ; [ALU_PRU] |306| j,j
1023 SBBO &r0, r2, 25, 4 ; [ALU_PRU] |306| $C$SP7,$O$U28
1024 QBGT ||$C$L15||, r12, 0x06 ; [ALU_PRU] |306| j
1025;* --------------------------------------------------------------------------*
1026 .dwpsn file "PRU_ADS8688_Controller.c",line 299,column 15,is_stmt,isa 0
1027 ADD r5, r5, 0x01 ; [ALU_PRU] |299| i,i
1028 QBGT ||$C$L12||, r5, 0x08 ; [ALU_PRU] |299| i
1029;* --------------------------------------------------------------------------*
1030 .dwpsn file "PRU_ADS8688_Controller.c",line 353,column 3,is_stmt,isa 0
1031 ADD r6, r6, 0x01 ; [ALU_PRU] |353| oversample,oversample
1032 QBNE ||$C$L11||, r6, 0x02 ; [ALU_PRU] |353| oversample
1033;* --------------------------------------------------------------------------*
1034 .dwpsn file "PRU_ADS8688_Controller.c",line 356,column 4,is_stmt,isa 0
1035 MOV r14, r9 ; [ALU_PRU] |356| curr_addr
1036 LBBO &r15, r2, 29, 4 ; [ALU_PRU] |356| $O$K35,$C$SP8
1037 LDI r16, 0x00c0 ; [ALU_PRU] |356|
1038$C$DW$66 .dwtag DW_TAG_TI_branch
1039 .dwattr $C$DW$66, DW_AT_low_pc(0x00)
1040 .dwattr $C$DW$66, DW_AT_name("memcpy")
1041 .dwattr $C$DW$66, DW_AT_TI_call
1042 JAL r3.w2, ||memcpy|| ; [ALU_PRU] |356| memcpy
1043 .dwpsn file "PRU_ADS8688_Controller.c",line 354,column 4,is_stmt,isa 0
1044 LDI r6, 0x0001 ; [ALU_PRU] |354| oversample
1045 .dwpsn file "PRU_ADS8688_Controller.c",line 358,column 4,is_stmt,isa 0
1046 ADD r9, r9, 0xc0 ; [ALU_PRU] |358| curr_addr,curr_addr
1047 .dwpsn file "PRU_ADS8688_Controller.c",line 361,column 4,is_stmt,isa 0
1048 ADD r11, r11, 0x01 ; [ALU_PRU] |361| num_captured,num_captured
1049 LDI r0, 0x0280 ; [ALU_PRU] |361|
1050 QBNE ||$C$L11||, r0, r11 ; [ALU_PRU] |361| num_captured
1051;* --------------------------------------------------------------------------*
1052 LSL r0, r8.w0, 0x10 ; [ALU_PRU] compensation
1053 OR r14, r0, r4.w0 ; [ALU_PRU] $O$U116,delay
1054 LBBO &r0.b0, r2, 0, 1 ; [ALU_PRU] curr_buff,$C$SP0
1055 .dwpsn file "PRU_ADS8688_Controller.c",line 362,column 5,is_stmt,isa 0
1056 QBNE ||$C$L23||, r0.b0, 0x00 ; [ALU_PRU] |362| curr_buff
1057;* --------------------------------------------------------------------------*
1058 LBBO &r0, r2, 1, 4 ; [ALU_PRU] $O$Q1,$C$SP1
1059 LBBO &r1, r2, 17, 4 ; [ALU_PRU] $O$K108,$C$SP5
1060 .dwpsn file "PRU_ADS8688_Controller.c",line 370,column 6,is_stmt,isa 0
1061 LDI32 r9, 0x9ffe0008 ; [ALU_PRU] |370| curr_addr
1062 .dwpsn file "PRU_ADS8688_Controller.c",line 364,column 6,is_stmt,isa 0
1063 SBBO &r1, r0, 0, 4 ; [ALU_PRU] |364| $O$Q1,$O$K108
1064 .dwpsn file "PRU_ADS8688_Controller.c",line 366,column 6,is_stmt,isa 0
1065 SBBO &r14, r0, 4, 4 ; [ALU_PRU] |366| $O$Q1,$O$U116
1066 LBBO &r0, r2, 5, 4 ; [ALU_PRU] |366| $O$Q2,$C$SP2
1067 .dwpsn file "PRU_ADS8688_Controller.c",line 368,column 6,is_stmt,isa 0
1068 SBBO &r10, r0, 0, 4 ; [ALU_PRU] |368| $O$Q2,$O$K32
1069 .dwpsn file "PRU_ADS8688_Controller.c",line 372,column 6,is_stmt,isa 0
1070 LDI r0.b0, 0x01 ; [ALU_PRU] |372| curr_buff
1071 .dwpsn file "PRU_ADS8688_Controller.c",line 373,column 5,is_stmt,isa 0
1072 JMP ||$C$L24|| ; [ALU_PRU] |373|
1073;* --------------------------------------------------------------------------*
1074||$C$L23||:
1075 LBBO &r0, r2, 5, 4 ; [ALU_PRU] $O$Q2,$C$SP2
1076 LBBO &r1, r2, 17, 4 ; [ALU_PRU] $O$K108,$C$SP5
1077 .dwpsn file "PRU_ADS8688_Controller.c",line 382,column 6,is_stmt,isa 0
1078 LDI32 r9, 0x9ffc0008 ; [ALU_PRU] |382| curr_addr
1079 .dwpsn file "PRU_ADS8688_Controller.c",line 376,column 6,is_stmt,isa 0
1080 SBBO &r1, r0, 0, 4 ; [ALU_PRU] |376| $O$Q2,$O$K108
1081 .dwpsn file "PRU_ADS8688_Controller.c",line 378,column 6,is_stmt,isa 0
1082 SBBO &r14, r0, 4, 4 ; [ALU_PRU] |378| $O$Q2,$O$U116
1083 LBBO &r0, r2, 1, 4 ; [ALU_PRU] |378| $O$Q1,$C$SP1
1084 .dwpsn file "PRU_ADS8688_Controller.c",line 380,column 6,is_stmt,isa 0
1085 SBBO &r10, r0, 0, 4 ; [ALU_PRU] |380| $O$Q1,$O$K32
1086 .dwpsn file "PRU_ADS8688_Controller.c",line 384,column 6,is_stmt,isa 0
1087 LDI r0.b0, 0x00 ; [ALU_PRU] |384| curr_buff
1088;* --------------------------------------------------------------------------*
1089||$C$L24||:
1090 SBBO &r0.b0, r2, 0, 1 ; [ALU_PRU] |384| $C$SP0,curr_buff
1091 .dwpsn file "PRU_ADS8688_Controller.c",line 386,column 5,is_stmt,isa 0
1092 ZERO &r11, 4 ; [ALU_PRU] |386| num_captured
1093 JMP ||$C$L11|| ; [ALU_PRU] |386|
1094 .dwattr $C$DW$48, DW_AT_TI_end_file("PRU_ADS8688_Controller.c")
1095 .dwattr $C$DW$48, DW_AT_TI_end_line(0x186)
1096 .dwattr $C$DW$48, DW_AT_TI_end_column(0x01)
1097 .dwendentry
1098 .dwendtag $C$DW$48
1099
1100;*****************************************************************************
1101;* UNDEFINED EXTERNAL REFERENCES *
1102;*****************************************************************************
1103 .global ||__pruabi_divu||
1104 .global ||memcpy||
1105
1106;******************************************************************************
1107;* TYPE INFORMATION *
1108;******************************************************************************
1109
1110$C$DW$T$20 .dwtag DW_TAG_structure_type
1111 .dwattr $C$DW$T$20, DW_AT_byte_size(0x04)
1112$C$DW$67 .dwtag DW_TAG_member
1113 .dwattr $C$DW$67, DW_AT_type(*$C$DW$T$11)
1114 .dwattr $C$DW$67, DW_AT_name("REVID")
1115 .dwattr $C$DW$67, DW_AT_TI_symbol_name("REVID")
1116 .dwattr $C$DW$67, DW_AT_bit_offset(0x00), DW_AT_bit_size(0x20)
1117 .dwattr $C$DW$67, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
1118 .dwattr $C$DW$67, DW_AT_accessibility(DW_ACCESS_public)
1119 .dwattr $C$DW$67, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
1120 .dwattr $C$DW$67, DW_AT_decl_line(0x2d)
1121 .dwattr $C$DW$67, DW_AT_decl_column(0x0d)
1122 .dwendtag $C$DW$T$20
1123
1124 .dwattr $C$DW$T$20, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
1125 .dwattr $C$DW$T$20, DW_AT_decl_line(0x2c)
1126 .dwattr $C$DW$T$20, DW_AT_decl_column(0x13)
1127$C$DW$T$49 .dwtag DW_TAG_volatile_type
1128 .dwattr $C$DW$T$49, DW_AT_type(*$C$DW$T$20)
1129
1130$C$DW$T$21 .dwtag DW_TAG_structure_type
1131 .dwattr $C$DW$T$21, DW_AT_byte_size(0x04)
1132$C$DW$68 .dwtag DW_TAG_member
1133 .dwattr $C$DW$68, DW_AT_type(*$C$DW$T$11)
1134 .dwattr $C$DW$68, DW_AT_name("IDLE_MODE")
1135 .dwattr $C$DW$68, DW_AT_TI_symbol_name("IDLE_MODE")
1136 .dwattr $C$DW$68, DW_AT_bit_offset(0x1e), DW_AT_bit_size(0x02)
1137 .dwattr $C$DW$68, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
1138 .dwattr $C$DW$68, DW_AT_accessibility(DW_ACCESS_public)
1139 .dwattr $C$DW$68, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
1140 .dwattr $C$DW$68, DW_AT_decl_line(0x37)
1141 .dwattr $C$DW$68, DW_AT_decl_column(0x0d)
1142$C$DW$69 .dwtag DW_TAG_member
1143 .dwattr $C$DW$69, DW_AT_type(*$C$DW$T$11)
1144 .dwattr $C$DW$69, DW_AT_name("STANDBY_MODE")
1145 .dwattr $C$DW$69, DW_AT_TI_symbol_name("STANDBY_MODE")
1146 .dwattr $C$DW$69, DW_AT_bit_offset(0x1c), DW_AT_bit_size(0x02)
1147 .dwattr $C$DW$69, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
1148 .dwattr $C$DW$69, DW_AT_accessibility(DW_ACCESS_public)
1149 .dwattr $C$DW$69, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
1150 .dwattr $C$DW$69, DW_AT_decl_line(0x38)
1151 .dwattr $C$DW$69, DW_AT_decl_column(0x0d)
1152$C$DW$70 .dwtag DW_TAG_member
1153 .dwattr $C$DW$70, DW_AT_type(*$C$DW$T$11)
1154 .dwattr $C$DW$70, DW_AT_name("STANDBY_INIT")
1155 .dwattr $C$DW$70, DW_AT_TI_symbol_name("STANDBY_INIT")
1156 .dwattr $C$DW$70, DW_AT_bit_offset(0x1b), DW_AT_bit_size(0x01)
1157 .dwattr $C$DW$70, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
1158 .dwattr $C$DW$70, DW_AT_accessibility(DW_ACCESS_public)
1159 .dwattr $C$DW$70, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
1160 .dwattr $C$DW$70, DW_AT_decl_line(0x39)
1161 .dwattr $C$DW$70, DW_AT_decl_column(0x0d)
1162$C$DW$71 .dwtag DW_TAG_member
1163 .dwattr $C$DW$71, DW_AT_type(*$C$DW$T$11)
1164 .dwattr $C$DW$71, DW_AT_name("SUB_MWAIT")
1165 .dwattr $C$DW$71, DW_AT_TI_symbol_name("SUB_MWAIT")
1166 .dwattr $C$DW$71, DW_AT_bit_offset(0x1a), DW_AT_bit_size(0x01)
1167 .dwattr $C$DW$71, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
1168 .dwattr $C$DW$71, DW_AT_accessibility(DW_ACCESS_public)
1169 .dwattr $C$DW$71, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
1170 .dwattr $C$DW$71, DW_AT_decl_line(0x3a)
1171 .dwattr $C$DW$71, DW_AT_decl_column(0x0d)
1172$C$DW$72 .dwtag DW_TAG_member
1173 .dwattr $C$DW$72, DW_AT_type(*$C$DW$T$11)
1174 .dwattr $C$DW$72, DW_AT_name("rsvd6")
1175 .dwattr $C$DW$72, DW_AT_TI_symbol_name("rsvd6")
1176 .dwattr $C$DW$72, DW_AT_bit_offset(0x00), DW_AT_bit_size(0x1a)
1177 .dwattr $C$DW$72, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
1178 .dwattr $C$DW$72, DW_AT_accessibility(DW_ACCESS_public)
1179 .dwattr $C$DW$72, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
1180 .dwattr $C$DW$72, DW_AT_decl_line(0x3b)
1181 .dwattr $C$DW$72, DW_AT_decl_column(0x0d)
1182 .dwendtag $C$DW$T$21
1183
1184 .dwattr $C$DW$T$21, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
1185 .dwattr $C$DW$T$21, DW_AT_decl_line(0x36)
1186 .dwattr $C$DW$T$21, DW_AT_decl_column(0x13)
1187$C$DW$T$51 .dwtag DW_TAG_volatile_type
1188 .dwattr $C$DW$T$51, DW_AT_type(*$C$DW$T$21)
1189
1190$C$DW$T$22 .dwtag DW_TAG_structure_type
1191 .dwattr $C$DW$T$22, DW_AT_byte_size(0x04)
1192$C$DW$73 .dwtag DW_TAG_member
1193 .dwattr $C$DW$73, DW_AT_type(*$C$DW$T$11)
1194 .dwattr $C$DW$73, DW_AT_name("PRU0_GPI_MODE")
1195 .dwattr $C$DW$73, DW_AT_TI_symbol_name("PRU0_GPI_MODE")
1196 .dwattr $C$DW$73, DW_AT_bit_offset(0x1e), DW_AT_bit_size(0x02)
1197 .dwattr $C$DW$73, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
1198 .dwattr $C$DW$73, DW_AT_accessibility(DW_ACCESS_public)
1199 .dwattr $C$DW$73, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
1200 .dwattr $C$DW$73, DW_AT_decl_line(0x45)
1201 .dwattr $C$DW$73, DW_AT_decl_column(0x0d)
1202$C$DW$74 .dwtag DW_TAG_member
1203 .dwattr $C$DW$74, DW_AT_type(*$C$DW$T$11)
1204 .dwattr $C$DW$74, DW_AT_name("PRU0_GPI_CLK_MODE")
1205 .dwattr $C$DW$74, DW_AT_TI_symbol_name("PRU0_GPI_CLK_MODE")
1206 .dwattr $C$DW$74, DW_AT_bit_offset(0x1d), DW_AT_bit_size(0x01)
1207 .dwattr $C$DW$74, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
1208 .dwattr $C$DW$74, DW_AT_accessibility(DW_ACCESS_public)
1209 .dwattr $C$DW$74, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
1210 .dwattr $C$DW$74, DW_AT_decl_line(0x46)
1211 .dwattr $C$DW$74, DW_AT_decl_column(0x0d)
1212$C$DW$75 .dwtag DW_TAG_member
1213 .dwattr $C$DW$75, DW_AT_type(*$C$DW$T$11)
1214 .dwattr $C$DW$75, DW_AT_name("PRU0_GPI_DIV0")
1215 .dwattr $C$DW$75, DW_AT_TI_symbol_name("PRU0_GPI_DIV0")
1216 .dwattr $C$DW$75, DW_AT_bit_offset(0x18), DW_AT_bit_size(0x05)
1217 .dwattr $C$DW$75, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
1218 .dwattr $C$DW$75, DW_AT_accessibility(DW_ACCESS_public)
1219 .dwattr $C$DW$75, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
1220 .dwattr $C$DW$75, DW_AT_decl_line(0x47)
1221 .dwattr $C$DW$75, DW_AT_decl_column(0x0d)
1222$C$DW$76 .dwtag DW_TAG_member
1223 .dwattr $C$DW$76, DW_AT_type(*$C$DW$T$11)
1224 .dwattr $C$DW$76, DW_AT_name("PRU0_GPI_DIV1")
1225 .dwattr $C$DW$76, DW_AT_TI_symbol_name("PRU0_GPI_DIV1")
1226 .dwattr $C$DW$76, DW_AT_bit_offset(0x13), DW_AT_bit_size(0x05)
1227 .dwattr $C$DW$76, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
1228 .dwattr $C$DW$76, DW_AT_accessibility(DW_ACCESS_public)
1229 .dwattr $C$DW$76, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
1230 .dwattr $C$DW$76, DW_AT_decl_line(0x48)
1231 .dwattr $C$DW$76, DW_AT_decl_column(0x0d)
1232$C$DW$77 .dwtag DW_TAG_member
1233 .dwattr $C$DW$77, DW_AT_type(*$C$DW$T$11)
1234 .dwattr $C$DW$77, DW_AT_name("PRU0_GPI_SB")
1235 .dwattr $C$DW$77, DW_AT_TI_symbol_name("PRU0_GPI_SB")
1236 .dwattr $C$DW$77, DW_AT_bit_offset(0x12), DW_AT_bit_size(0x01)
1237 .dwattr $C$DW$77, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
1238 .dwattr $C$DW$77, DW_AT_accessibility(DW_ACCESS_public)
1239 .dwattr $C$DW$77, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
1240 .dwattr $C$DW$77, DW_AT_decl_line(0x49)
1241 .dwattr $C$DW$77, DW_AT_decl_column(0x0d)
1242$C$DW$78 .dwtag DW_TAG_member
1243 .dwattr $C$DW$78, DW_AT_type(*$C$DW$T$11)
1244 .dwattr $C$DW$78, DW_AT_name("PRU0_GPO_MODE")
1245 .dwattr $C$DW$78, DW_AT_TI_symbol_name("PRU0_GPO_MODE")
1246 .dwattr $C$DW$78, DW_AT_bit_offset(0x11), DW_AT_bit_size(0x01)
1247 .dwattr $C$DW$78, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
1248 .dwattr $C$DW$78, DW_AT_accessibility(DW_ACCESS_public)
1249 .dwattr $C$DW$78, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
1250 .dwattr $C$DW$78, DW_AT_decl_line(0x4a)
1251 .dwattr $C$DW$78, DW_AT_decl_column(0x0d)
1252$C$DW$79 .dwtag DW_TAG_member
1253 .dwattr $C$DW$79, DW_AT_type(*$C$DW$T$11)
1254 .dwattr $C$DW$79, DW_AT_name("PRU0_GPO_DIV0")
1255 .dwattr $C$DW$79, DW_AT_TI_symbol_name("PRU0_GPO_DIV0")
1256 .dwattr $C$DW$79, DW_AT_bit_offset(0x0c), DW_AT_bit_size(0x05)
1257 .dwattr $C$DW$79, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
1258 .dwattr $C$DW$79, DW_AT_accessibility(DW_ACCESS_public)
1259 .dwattr $C$DW$79, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
1260 .dwattr $C$DW$79, DW_AT_decl_line(0x4b)
1261 .dwattr $C$DW$79, DW_AT_decl_column(0x0d)
1262$C$DW$80 .dwtag DW_TAG_member
1263 .dwattr $C$DW$80, DW_AT_type(*$C$DW$T$11)
1264 .dwattr $C$DW$80, DW_AT_name("PRU0_GPO_DIV1")
1265 .dwattr $C$DW$80, DW_AT_TI_symbol_name("PRU0_GPO_DIV1")
1266 .dwattr $C$DW$80, DW_AT_bit_offset(0x07), DW_AT_bit_size(0x05)
1267 .dwattr $C$DW$80, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
1268 .dwattr $C$DW$80, DW_AT_accessibility(DW_ACCESS_public)
1269 .dwattr $C$DW$80, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
1270 .dwattr $C$DW$80, DW_AT_decl_line(0x4c)
1271 .dwattr $C$DW$80, DW_AT_decl_column(0x0d)
1272$C$DW$81 .dwtag DW_TAG_member
1273 .dwattr $C$DW$81, DW_AT_type(*$C$DW$T$11)
1274 .dwattr $C$DW$81, DW_AT_name("PRU0_GPO_SH_SEL")
1275 .dwattr $C$DW$81, DW_AT_TI_symbol_name("PRU0_GPO_SH_SEL")
1276 .dwattr $C$DW$81, DW_AT_bit_offset(0x06), DW_AT_bit_size(0x01)
1277 .dwattr $C$DW$81, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
1278 .dwattr $C$DW$81, DW_AT_accessibility(DW_ACCESS_public)
1279 .dwattr $C$DW$81, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
1280 .dwattr $C$DW$81, DW_AT_decl_line(0x4d)
1281 .dwattr $C$DW$81, DW_AT_decl_column(0x0d)
1282$C$DW$82 .dwtag DW_TAG_member
1283 .dwattr $C$DW$82, DW_AT_type(*$C$DW$T$11)
1284 .dwattr $C$DW$82, DW_AT_name("rsvd26")
1285 .dwattr $C$DW$82, DW_AT_TI_symbol_name("rsvd26")
1286 .dwattr $C$DW$82, DW_AT_bit_offset(0x00), DW_AT_bit_size(0x06)
1287 .dwattr $C$DW$82, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
1288 .dwattr $C$DW$82, DW_AT_accessibility(DW_ACCESS_public)
1289 .dwattr $C$DW$82, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
1290 .dwattr $C$DW$82, DW_AT_decl_line(0x4e)
1291 .dwattr $C$DW$82, DW_AT_decl_column(0x0d)
1292 .dwendtag $C$DW$T$22
1293
1294 .dwattr $C$DW$T$22, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
1295 .dwattr $C$DW$T$22, DW_AT_decl_line(0x44)
1296 .dwattr $C$DW$T$22, DW_AT_decl_column(0x13)
1297$C$DW$T$53 .dwtag DW_TAG_volatile_type
1298 .dwattr $C$DW$T$53, DW_AT_type(*$C$DW$T$22)
1299
1300$C$DW$T$23 .dwtag DW_TAG_structure_type
1301 .dwattr $C$DW$T$23, DW_AT_byte_size(0x04)
1302$C$DW$83 .dwtag DW_TAG_member
1303 .dwattr $C$DW$83, DW_AT_type(*$C$DW$T$11)
1304 .dwattr $C$DW$83, DW_AT_name("PRU1_GPI_MODE")
1305 .dwattr $C$DW$83, DW_AT_TI_symbol_name("PRU1_GPI_MODE")
1306 .dwattr $C$DW$83, DW_AT_bit_offset(0x1e), DW_AT_bit_size(0x02)
1307 .dwattr $C$DW$83, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
1308 .dwattr $C$DW$83, DW_AT_accessibility(DW_ACCESS_public)
1309 .dwattr $C$DW$83, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
1310 .dwattr $C$DW$83, DW_AT_decl_line(0x58)
1311 .dwattr $C$DW$83, DW_AT_decl_column(0x0d)
1312$C$DW$84 .dwtag DW_TAG_member
1313 .dwattr $C$DW$84, DW_AT_type(*$C$DW$T$11)
1314 .dwattr $C$DW$84, DW_AT_name("PRU1_GPI_CLK_MODE")
1315 .dwattr $C$DW$84, DW_AT_TI_symbol_name("PRU1_GPI_CLK_MODE")
1316 .dwattr $C$DW$84, DW_AT_bit_offset(0x1d), DW_AT_bit_size(0x01)
1317 .dwattr $C$DW$84, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
1318 .dwattr $C$DW$84, DW_AT_accessibility(DW_ACCESS_public)
1319 .dwattr $C$DW$84, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
1320 .dwattr $C$DW$84, DW_AT_decl_line(0x59)
1321 .dwattr $C$DW$84, DW_AT_decl_column(0x0d)
1322$C$DW$85 .dwtag DW_TAG_member
1323 .dwattr $C$DW$85, DW_AT_type(*$C$DW$T$11)
1324 .dwattr $C$DW$85, DW_AT_name("PRU1_GPI_DIV0")
1325 .dwattr $C$DW$85, DW_AT_TI_symbol_name("PRU1_GPI_DIV0")
1326 .dwattr $C$DW$85, DW_AT_bit_offset(0x18), DW_AT_bit_size(0x05)
1327 .dwattr $C$DW$85, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
1328 .dwattr $C$DW$85, DW_AT_accessibility(DW_ACCESS_public)
1329 .dwattr $C$DW$85, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
1330 .dwattr $C$DW$85, DW_AT_decl_line(0x5a)
1331 .dwattr $C$DW$85, DW_AT_decl_column(0x0d)
1332$C$DW$86 .dwtag DW_TAG_member
1333 .dwattr $C$DW$86, DW_AT_type(*$C$DW$T$11)
1334 .dwattr $C$DW$86, DW_AT_name("PRU1_GPI_DIV1")
1335 .dwattr $C$DW$86, DW_AT_TI_symbol_name("PRU1_GPI_DIV1")
1336 .dwattr $C$DW$86, DW_AT_bit_offset(0x13), DW_AT_bit_size(0x05)
1337 .dwattr $C$DW$86, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
1338 .dwattr $C$DW$86, DW_AT_accessibility(DW_ACCESS_public)
1339 .dwattr $C$DW$86, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
1340 .dwattr $C$DW$86, DW_AT_decl_line(0x5b)
1341 .dwattr $C$DW$86, DW_AT_decl_column(0x0d)
1342$C$DW$87 .dwtag DW_TAG_member
1343 .dwattr $C$DW$87, DW_AT_type(*$C$DW$T$11)
1344 .dwattr $C$DW$87, DW_AT_name("PRU1_GPI_SB")
1345 .dwattr $C$DW$87, DW_AT_TI_symbol_name("PRU1_GPI_SB")
1346 .dwattr $C$DW$87, DW_AT_bit_offset(0x12), DW_AT_bit_size(0x01)
1347 .dwattr $C$DW$87, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
1348 .dwattr $C$DW$87, DW_AT_accessibility(DW_ACCESS_public)
1349 .dwattr $C$DW$87, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
1350 .dwattr $C$DW$87, DW_AT_decl_line(0x5c)
1351 .dwattr $C$DW$87, DW_AT_decl_column(0x0d)
1352$C$DW$88 .dwtag DW_TAG_member
1353 .dwattr $C$DW$88, DW_AT_type(*$C$DW$T$11)
1354 .dwattr $C$DW$88, DW_AT_name("PRU1_GPO_MODE")
1355 .dwattr $C$DW$88, DW_AT_TI_symbol_name("PRU1_GPO_MODE")
1356 .dwattr $C$DW$88, DW_AT_bit_offset(0x11), DW_AT_bit_size(0x01)
1357 .dwattr $C$DW$88, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
1358 .dwattr $C$DW$88, DW_AT_accessibility(DW_ACCESS_public)
1359 .dwattr $C$DW$88, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
1360 .dwattr $C$DW$88, DW_AT_decl_line(0x5d)
1361 .dwattr $C$DW$88, DW_AT_decl_column(0x0d)
1362$C$DW$89 .dwtag DW_TAG_member
1363 .dwattr $C$DW$89, DW_AT_type(*$C$DW$T$11)
1364 .dwattr $C$DW$89, DW_AT_name("PRU1_GPO_DIV0")
1365 .dwattr $C$DW$89, DW_AT_TI_symbol_name("PRU1_GPO_DIV0")
1366 .dwattr $C$DW$89, DW_AT_bit_offset(0x0c), DW_AT_bit_size(0x05)
1367 .dwattr $C$DW$89, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
1368 .dwattr $C$DW$89, DW_AT_accessibility(DW_ACCESS_public)
1369 .dwattr $C$DW$89, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
1370 .dwattr $C$DW$89, DW_AT_decl_line(0x5e)
1371 .dwattr $C$DW$89, DW_AT_decl_column(0x0d)
1372$C$DW$90 .dwtag DW_TAG_member
1373 .dwattr $C$DW$90, DW_AT_type(*$C$DW$T$11)
1374 .dwattr $C$DW$90, DW_AT_name("PRU1_GPO_DIV1")
1375 .dwattr $C$DW$90, DW_AT_TI_symbol_name("PRU1_GPO_DIV1")
1376 .dwattr $C$DW$90, DW_AT_bit_offset(0x07), DW_AT_bit_size(0x05)
1377 .dwattr $C$DW$90, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
1378 .dwattr $C$DW$90, DW_AT_accessibility(DW_ACCESS_public)
1379 .dwattr $C$DW$90, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
1380 .dwattr $C$DW$90, DW_AT_decl_line(0x5f)
1381 .dwattr $C$DW$90, DW_AT_decl_column(0x0d)
1382$C$DW$91 .dwtag DW_TAG_member
1383 .dwattr $C$DW$91, DW_AT_type(*$C$DW$T$11)
1384 .dwattr $C$DW$91, DW_AT_name("PRU1_GPO_SH_SEL")
1385 .dwattr $C$DW$91, DW_AT_TI_symbol_name("PRU1_GPO_SH_SEL")
1386 .dwattr $C$DW$91, DW_AT_bit_offset(0x06), DW_AT_bit_size(0x01)
1387 .dwattr $C$DW$91, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
1388 .dwattr $C$DW$91, DW_AT_accessibility(DW_ACCESS_public)
1389 .dwattr $C$DW$91, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
1390 .dwattr $C$DW$91, DW_AT_decl_line(0x60)
1391 .dwattr $C$DW$91, DW_AT_decl_column(0x0d)
1392$C$DW$92 .dwtag DW_TAG_member
1393 .dwattr $C$DW$92, DW_AT_type(*$C$DW$T$11)
1394 .dwattr $C$DW$92, DW_AT_name("rsvd26")
1395 .dwattr $C$DW$92, DW_AT_TI_symbol_name("rsvd26")
1396 .dwattr $C$DW$92, DW_AT_bit_offset(0x00), DW_AT_bit_size(0x06)
1397 .dwattr $C$DW$92, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
1398 .dwattr $C$DW$92, DW_AT_accessibility(DW_ACCESS_public)
1399 .dwattr $C$DW$92, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
1400 .dwattr $C$DW$92, DW_AT_decl_line(0x61)
1401 .dwattr $C$DW$92, DW_AT_decl_column(0x0d)
1402 .dwendtag $C$DW$T$23
1403
1404 .dwattr $C$DW$T$23, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
1405 .dwattr $C$DW$T$23, DW_AT_decl_line(0x57)
1406 .dwattr $C$DW$T$23, DW_AT_decl_column(0x13)
1407$C$DW$T$55 .dwtag DW_TAG_volatile_type
1408 .dwattr $C$DW$T$55, DW_AT_type(*$C$DW$T$23)
1409
1410$C$DW$T$24 .dwtag DW_TAG_structure_type
1411 .dwattr $C$DW$T$24, DW_AT_byte_size(0x04)
1412$C$DW$93 .dwtag DW_TAG_member
1413 .dwattr $C$DW$93, DW_AT_type(*$C$DW$T$11)
1414 .dwattr $C$DW$93, DW_AT_name("PRU0_CLK_STOP_REQ")
1415 .dwattr $C$DW$93, DW_AT_TI_symbol_name("PRU0_CLK_STOP_REQ")
1416 .dwattr $C$DW$93, DW_AT_bit_offset(0x1f), DW_AT_bit_size(0x01)
1417 .dwattr $C$DW$93, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
1418 .dwattr $C$DW$93, DW_AT_accessibility(DW_ACCESS_public)
1419 .dwattr $C$DW$93, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
1420 .dwattr $C$DW$93, DW_AT_decl_line(0x6b)
1421 .dwattr $C$DW$93, DW_AT_decl_column(0x0d)
1422$C$DW$94 .dwtag DW_TAG_member
1423 .dwattr $C$DW$94, DW_AT_type(*$C$DW$T$11)
1424 .dwattr $C$DW$94, DW_AT_name("PRU0_CLK_STOP_ACK")
1425 .dwattr $C$DW$94, DW_AT_TI_symbol_name("PRU0_CLK_STOP_ACK")
1426 .dwattr $C$DW$94, DW_AT_bit_offset(0x1e), DW_AT_bit_size(0x01)
1427 .dwattr $C$DW$94, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
1428 .dwattr $C$DW$94, DW_AT_accessibility(DW_ACCESS_public)
1429 .dwattr $C$DW$94, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
1430 .dwattr $C$DW$94, DW_AT_decl_line(0x6c)
1431 .dwattr $C$DW$94, DW_AT_decl_column(0x0d)
1432$C$DW$95 .dwtag DW_TAG_member
1433 .dwattr $C$DW$95, DW_AT_type(*$C$DW$T$11)
1434 .dwattr $C$DW$95, DW_AT_name("PRU0_CLK_EN")
1435 .dwattr $C$DW$95, DW_AT_TI_symbol_name("PRU0_CLK_EN")
1436 .dwattr $C$DW$95, DW_AT_bit_offset(0x1d), DW_AT_bit_size(0x01)
1437 .dwattr $C$DW$95, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
1438 .dwattr $C$DW$95, DW_AT_accessibility(DW_ACCESS_public)
1439 .dwattr $C$DW$95, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
1440 .dwattr $C$DW$95, DW_AT_decl_line(0x6d)
1441 .dwattr $C$DW$95, DW_AT_decl_column(0x0d)
1442$C$DW$96 .dwtag DW_TAG_member
1443 .dwattr $C$DW$96, DW_AT_type(*$C$DW$T$11)
1444 .dwattr $C$DW$96, DW_AT_name("PRU1_CLK_STOP_REQ")
1445 .dwattr $C$DW$96, DW_AT_TI_symbol_name("PRU1_CLK_STOP_REQ")
1446 .dwattr $C$DW$96, DW_AT_bit_offset(0x1c), DW_AT_bit_size(0x01)
1447 .dwattr $C$DW$96, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
1448 .dwattr $C$DW$96, DW_AT_accessibility(DW_ACCESS_public)
1449 .dwattr $C$DW$96, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
1450 .dwattr $C$DW$96, DW_AT_decl_line(0x6e)
1451 .dwattr $C$DW$96, DW_AT_decl_column(0x0d)
1452$C$DW$97 .dwtag DW_TAG_member
1453 .dwattr $C$DW$97, DW_AT_type(*$C$DW$T$11)
1454 .dwattr $C$DW$97, DW_AT_name("PRU1_CLK_STOP_ACK")
1455 .dwattr $C$DW$97, DW_AT_TI_symbol_name("PRU1_CLK_STOP_ACK")
1456 .dwattr $C$DW$97, DW_AT_bit_offset(0x1b), DW_AT_bit_size(0x01)
1457 .dwattr $C$DW$97, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
1458 .dwattr $C$DW$97, DW_AT_accessibility(DW_ACCESS_public)
1459 .dwattr $C$DW$97, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
1460 .dwattr $C$DW$97, DW_AT_decl_line(0x6f)
1461 .dwattr $C$DW$97, DW_AT_decl_column(0x0d)
1462$C$DW$98 .dwtag DW_TAG_member
1463 .dwattr $C$DW$98, DW_AT_type(*$C$DW$T$11)
1464 .dwattr $C$DW$98, DW_AT_name("PRU1_CLK_EN")
1465 .dwattr $C$DW$98, DW_AT_TI_symbol_name("PRU1_CLK_EN")
1466 .dwattr $C$DW$98, DW_AT_bit_offset(0x1a), DW_AT_bit_size(0x01)
1467 .dwattr $C$DW$98, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
1468 .dwattr $C$DW$98, DW_AT_accessibility(DW_ACCESS_public)
1469 .dwattr $C$DW$98, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
1470 .dwattr $C$DW$98, DW_AT_decl_line(0x70)
1471 .dwattr $C$DW$98, DW_AT_decl_column(0x0d)
1472$C$DW$99 .dwtag DW_TAG_member
1473 .dwattr $C$DW$99, DW_AT_type(*$C$DW$T$11)
1474 .dwattr $C$DW$99, DW_AT_name("INTC_CLK_STOP_REQ")
1475 .dwattr $C$DW$99, DW_AT_TI_symbol_name("INTC_CLK_STOP_REQ")
1476 .dwattr $C$DW$99, DW_AT_bit_offset(0x19), DW_AT_bit_size(0x01)
1477 .dwattr $C$DW$99, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
1478 .dwattr $C$DW$99, DW_AT_accessibility(DW_ACCESS_public)
1479 .dwattr $C$DW$99, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
1480 .dwattr $C$DW$99, DW_AT_decl_line(0x71)
1481 .dwattr $C$DW$99, DW_AT_decl_column(0x0d)
1482$C$DW$100 .dwtag DW_TAG_member
1483 .dwattr $C$DW$100, DW_AT_type(*$C$DW$T$11)
1484 .dwattr $C$DW$100, DW_AT_name("INTC_CLK_STOP_ACK")
1485 .dwattr $C$DW$100, DW_AT_TI_symbol_name("INTC_CLK_STOP_ACK")
1486 .dwattr $C$DW$100, DW_AT_bit_offset(0x18), DW_AT_bit_size(0x01)
1487 .dwattr $C$DW$100, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
1488 .dwattr $C$DW$100, DW_AT_accessibility(DW_ACCESS_public)
1489 .dwattr $C$DW$100, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
1490 .dwattr $C$DW$100, DW_AT_decl_line(0x72)
1491 .dwattr $C$DW$100, DW_AT_decl_column(0x0d)
1492$C$DW$101 .dwtag DW_TAG_member
1493 .dwattr $C$DW$101, DW_AT_type(*$C$DW$T$11)
1494 .dwattr $C$DW$101, DW_AT_name("INTC_CLK_EN")
1495 .dwattr $C$DW$101, DW_AT_TI_symbol_name("INTC_CLK_EN")
1496 .dwattr $C$DW$101, DW_AT_bit_offset(0x17), DW_AT_bit_size(0x01)
1497 .dwattr $C$DW$101, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
1498 .dwattr $C$DW$101, DW_AT_accessibility(DW_ACCESS_public)
1499 .dwattr $C$DW$101, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
1500 .dwattr $C$DW$101, DW_AT_decl_line(0x73)
1501 .dwattr $C$DW$101, DW_AT_decl_column(0x0d)
1502$C$DW$102 .dwtag DW_TAG_member
1503 .dwattr $C$DW$102, DW_AT_type(*$C$DW$T$11)
1504 .dwattr $C$DW$102, DW_AT_name("UART_CLK_STOP_REQ")
1505 .dwattr $C$DW$102, DW_AT_TI_symbol_name("UART_CLK_STOP_REQ")
1506 .dwattr $C$DW$102, DW_AT_bit_offset(0x16), DW_AT_bit_size(0x01)
1507 .dwattr $C$DW$102, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
1508 .dwattr $C$DW$102, DW_AT_accessibility(DW_ACCESS_public)
1509 .dwattr $C$DW$102, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
1510 .dwattr $C$DW$102, DW_AT_decl_line(0x74)
1511 .dwattr $C$DW$102, DW_AT_decl_column(0x0d)
1512$C$DW$103 .dwtag DW_TAG_member
1513 .dwattr $C$DW$103, DW_AT_type(*$C$DW$T$11)
1514 .dwattr $C$DW$103, DW_AT_name("UART_CLK_STOP_ACK")
1515 .dwattr $C$DW$103, DW_AT_TI_symbol_name("UART_CLK_STOP_ACK")
1516 .dwattr $C$DW$103, DW_AT_bit_offset(0x15), DW_AT_bit_size(0x01)
1517 .dwattr $C$DW$103, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
1518 .dwattr $C$DW$103, DW_AT_accessibility(DW_ACCESS_public)
1519 .dwattr $C$DW$103, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
1520 .dwattr $C$DW$103, DW_AT_decl_line(0x75)
1521 .dwattr $C$DW$103, DW_AT_decl_column(0x0d)
1522$C$DW$104 .dwtag DW_TAG_member
1523 .dwattr $C$DW$104, DW_AT_type(*$C$DW$T$11)
1524 .dwattr $C$DW$104, DW_AT_name("UART_CLK_EN")
1525 .dwattr $C$DW$104, DW_AT_TI_symbol_name("UART_CLK_EN")
1526 .dwattr $C$DW$104, DW_AT_bit_offset(0x14), DW_AT_bit_size(0x01)
1527 .dwattr $C$DW$104, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
1528 .dwattr $C$DW$104, DW_AT_accessibility(DW_ACCESS_public)
1529 .dwattr $C$DW$104, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
1530 .dwattr $C$DW$104, DW_AT_decl_line(0x76)
1531 .dwattr $C$DW$104, DW_AT_decl_column(0x0d)
1532$C$DW$105 .dwtag DW_TAG_member
1533 .dwattr $C$DW$105, DW_AT_type(*$C$DW$T$11)
1534 .dwattr $C$DW$105, DW_AT_name("ECAP_CLK_STOP_REQ")
1535 .dwattr $C$DW$105, DW_AT_TI_symbol_name("ECAP_CLK_STOP_REQ")
1536 .dwattr $C$DW$105, DW_AT_bit_offset(0x13), DW_AT_bit_size(0x01)
1537 .dwattr $C$DW$105, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
1538 .dwattr $C$DW$105, DW_AT_accessibility(DW_ACCESS_public)
1539 .dwattr $C$DW$105, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
1540 .dwattr $C$DW$105, DW_AT_decl_line(0x77)
1541 .dwattr $C$DW$105, DW_AT_decl_column(0x0d)
1542$C$DW$106 .dwtag DW_TAG_member
1543 .dwattr $C$DW$106, DW_AT_type(*$C$DW$T$11)
1544 .dwattr $C$DW$106, DW_AT_name("ECAP_CLK_STOP_ACK")
1545 .dwattr $C$DW$106, DW_AT_TI_symbol_name("ECAP_CLK_STOP_ACK")
1546 .dwattr $C$DW$106, DW_AT_bit_offset(0x12), DW_AT_bit_size(0x01)
1547 .dwattr $C$DW$106, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
1548 .dwattr $C$DW$106, DW_AT_accessibility(DW_ACCESS_public)
1549 .dwattr $C$DW$106, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
1550 .dwattr $C$DW$106, DW_AT_decl_line(0x78)
1551 .dwattr $C$DW$106, DW_AT_decl_column(0x0d)
1552$C$DW$107 .dwtag DW_TAG_member
1553 .dwattr $C$DW$107, DW_AT_type(*$C$DW$T$11)
1554 .dwattr $C$DW$107, DW_AT_name("ECAP_CLK_EN")
1555 .dwattr $C$DW$107, DW_AT_TI_symbol_name("ECAP_CLK_EN")
1556 .dwattr $C$DW$107, DW_AT_bit_offset(0x11), DW_AT_bit_size(0x01)
1557 .dwattr $C$DW$107, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
1558 .dwattr $C$DW$107, DW_AT_accessibility(DW_ACCESS_public)
1559 .dwattr $C$DW$107, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
1560 .dwattr $C$DW$107, DW_AT_decl_line(0x79)
1561 .dwattr $C$DW$107, DW_AT_decl_column(0x0d)
1562$C$DW$108 .dwtag DW_TAG_member
1563 .dwattr $C$DW$108, DW_AT_type(*$C$DW$T$11)
1564 .dwattr $C$DW$108, DW_AT_name("IEP_CLK_STOP_REQ")
1565 .dwattr $C$DW$108, DW_AT_TI_symbol_name("IEP_CLK_STOP_REQ")
1566 .dwattr $C$DW$108, DW_AT_bit_offset(0x10), DW_AT_bit_size(0x01)
1567 .dwattr $C$DW$108, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
1568 .dwattr $C$DW$108, DW_AT_accessibility(DW_ACCESS_public)
1569 .dwattr $C$DW$108, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
1570 .dwattr $C$DW$108, DW_AT_decl_line(0x7a)
1571 .dwattr $C$DW$108, DW_AT_decl_column(0x0d)
1572$C$DW$109 .dwtag DW_TAG_member
1573 .dwattr $C$DW$109, DW_AT_type(*$C$DW$T$11)
1574 .dwattr $C$DW$109, DW_AT_name("IEP_CLK_STOP_ACK")
1575 .dwattr $C$DW$109, DW_AT_TI_symbol_name("IEP_CLK_STOP_ACK")
1576 .dwattr $C$DW$109, DW_AT_bit_offset(0x0f), DW_AT_bit_size(0x01)
1577 .dwattr $C$DW$109, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
1578 .dwattr $C$DW$109, DW_AT_accessibility(DW_ACCESS_public)
1579 .dwattr $C$DW$109, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
1580 .dwattr $C$DW$109, DW_AT_decl_line(0x7b)
1581 .dwattr $C$DW$109, DW_AT_decl_column(0x0d)
1582$C$DW$110 .dwtag DW_TAG_member
1583 .dwattr $C$DW$110, DW_AT_type(*$C$DW$T$11)
1584 .dwattr $C$DW$110, DW_AT_name("IEP_CLK_EN")
1585 .dwattr $C$DW$110, DW_AT_TI_symbol_name("IEP_CLK_EN")
1586 .dwattr $C$DW$110, DW_AT_bit_offset(0x0e), DW_AT_bit_size(0x01)
1587 .dwattr $C$DW$110, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
1588 .dwattr $C$DW$110, DW_AT_accessibility(DW_ACCESS_public)
1589 .dwattr $C$DW$110, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
1590 .dwattr $C$DW$110, DW_AT_decl_line(0x7c)
1591 .dwattr $C$DW$110, DW_AT_decl_column(0x0d)
1592$C$DW$111 .dwtag DW_TAG_member
1593 .dwattr $C$DW$111, DW_AT_type(*$C$DW$T$11)
1594 .dwattr $C$DW$111, DW_AT_name("rsvd18")
1595 .dwattr $C$DW$111, DW_AT_TI_symbol_name("rsvd18")
1596 .dwattr $C$DW$111, DW_AT_bit_offset(0x00), DW_AT_bit_size(0x0e)
1597 .dwattr $C$DW$111, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
1598 .dwattr $C$DW$111, DW_AT_accessibility(DW_ACCESS_public)
1599 .dwattr $C$DW$111, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
1600 .dwattr $C$DW$111, DW_AT_decl_line(0x7d)
1601 .dwattr $C$DW$111, DW_AT_decl_column(0x0d)
1602 .dwendtag $C$DW$T$24
1603
1604 .dwattr $C$DW$T$24, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
1605 .dwattr $C$DW$T$24, DW_AT_decl_line(0x6a)
1606 .dwattr $C$DW$T$24, DW_AT_decl_column(0x13)
1607$C$DW$T$57 .dwtag DW_TAG_volatile_type
1608 .dwattr $C$DW$T$57, DW_AT_type(*$C$DW$T$24)
1609
1610$C$DW$T$25 .dwtag DW_TAG_structure_type
1611 .dwattr $C$DW$T$25, DW_AT_byte_size(0x04)
1612$C$DW$112 .dwtag DW_TAG_member
1613 .dwattr $C$DW$112, DW_AT_type(*$C$DW$T$11)
1614 .dwattr $C$DW$112, DW_AT_name("PRU0_IMEM_PE_RAW")
1615 .dwattr $C$DW$112, DW_AT_TI_symbol_name("PRU0_IMEM_PE_RAW")
1616 .dwattr $C$DW$112, DW_AT_bit_offset(0x1c), DW_AT_bit_size(0x04)
1617 .dwattr $C$DW$112, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
1618 .dwattr $C$DW$112, DW_AT_accessibility(DW_ACCESS_public)
1619 .dwattr $C$DW$112, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
1620 .dwattr $C$DW$112, DW_AT_decl_line(0x87)
1621 .dwattr $C$DW$112, DW_AT_decl_column(0x0d)
1622$C$DW$113 .dwtag DW_TAG_member
1623 .dwattr $C$DW$113, DW_AT_type(*$C$DW$T$11)
1624 .dwattr $C$DW$113, DW_AT_name("PRU0_DMEM_PE_RAW")
1625 .dwattr $C$DW$113, DW_AT_TI_symbol_name("PRU0_DMEM_PE_RAW")
1626 .dwattr $C$DW$113, DW_AT_bit_offset(0x18), DW_AT_bit_size(0x04)
1627 .dwattr $C$DW$113, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
1628 .dwattr $C$DW$113, DW_AT_accessibility(DW_ACCESS_public)
1629 .dwattr $C$DW$113, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
1630 .dwattr $C$DW$113, DW_AT_decl_line(0x88)
1631 .dwattr $C$DW$113, DW_AT_decl_column(0x0d)
1632$C$DW$114 .dwtag DW_TAG_member
1633 .dwattr $C$DW$114, DW_AT_type(*$C$DW$T$11)
1634 .dwattr $C$DW$114, DW_AT_name("PRU1_IMEM_PE_RAW")
1635 .dwattr $C$DW$114, DW_AT_TI_symbol_name("PRU1_IMEM_PE_RAW")
1636 .dwattr $C$DW$114, DW_AT_bit_offset(0x14), DW_AT_bit_size(0x04)
1637 .dwattr $C$DW$114, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
1638 .dwattr $C$DW$114, DW_AT_accessibility(DW_ACCESS_public)
1639 .dwattr $C$DW$114, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
1640 .dwattr $C$DW$114, DW_AT_decl_line(0x89)
1641 .dwattr $C$DW$114, DW_AT_decl_column(0x0d)
1642$C$DW$115 .dwtag DW_TAG_member
1643 .dwattr $C$DW$115, DW_AT_type(*$C$DW$T$11)
1644 .dwattr $C$DW$115, DW_AT_name("PRU1_DMEM_PE_RAW")
1645 .dwattr $C$DW$115, DW_AT_TI_symbol_name("PRU1_DMEM_PE_RAW")
1646 .dwattr $C$DW$115, DW_AT_bit_offset(0x10), DW_AT_bit_size(0x04)
1647 .dwattr $C$DW$115, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
1648 .dwattr $C$DW$115, DW_AT_accessibility(DW_ACCESS_public)
1649 .dwattr $C$DW$115, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
1650 .dwattr $C$DW$115, DW_AT_decl_line(0x8a)
1651 .dwattr $C$DW$115, DW_AT_decl_column(0x0d)
1652$C$DW$116 .dwtag DW_TAG_member
1653 .dwattr $C$DW$116, DW_AT_type(*$C$DW$T$11)
1654 .dwattr $C$DW$116, DW_AT_name("RAM_PE_RAW")
1655 .dwattr $C$DW$116, DW_AT_TI_symbol_name("RAM_PE_RAW")
1656 .dwattr $C$DW$116, DW_AT_bit_offset(0x0c), DW_AT_bit_size(0x04)
1657 .dwattr $C$DW$116, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
1658 .dwattr $C$DW$116, DW_AT_accessibility(DW_ACCESS_public)
1659 .dwattr $C$DW$116, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
1660 .dwattr $C$DW$116, DW_AT_decl_line(0x8b)
1661 .dwattr $C$DW$116, DW_AT_decl_column(0x0d)
1662$C$DW$117 .dwtag DW_TAG_member
1663 .dwattr $C$DW$117, DW_AT_type(*$C$DW$T$11)
1664 .dwattr $C$DW$117, DW_AT_name("rsvd20")
1665 .dwattr $C$DW$117, DW_AT_TI_symbol_name("rsvd20")
1666 .dwattr $C$DW$117, DW_AT_bit_offset(0x00), DW_AT_bit_size(0x0c)
1667 .dwattr $C$DW$117, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
1668 .dwattr $C$DW$117, DW_AT_accessibility(DW_ACCESS_public)
1669 .dwattr $C$DW$117, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
1670 .dwattr $C$DW$117, DW_AT_decl_line(0x8c)
1671 .dwattr $C$DW$117, DW_AT_decl_column(0x0d)
1672 .dwendtag $C$DW$T$25
1673
1674 .dwattr $C$DW$T$25, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
1675 .dwattr $C$DW$T$25, DW_AT_decl_line(0x86)
1676 .dwattr $C$DW$T$25, DW_AT_decl_column(0x14)
1677$C$DW$T$59 .dwtag DW_TAG_volatile_type
1678 .dwattr $C$DW$T$59, DW_AT_type(*$C$DW$T$25)
1679
1680$C$DW$T$26 .dwtag DW_TAG_structure_type
1681 .dwattr $C$DW$T$26, DW_AT_byte_size(0x04)
1682$C$DW$118 .dwtag DW_TAG_member
1683 .dwattr $C$DW$118, DW_AT_type(*$C$DW$T$11)
1684 .dwattr $C$DW$118, DW_AT_name("PRU0_IMEM_PE")
1685 .dwattr $C$DW$118, DW_AT_TI_symbol_name("PRU0_IMEM_PE")
1686 .dwattr $C$DW$118, DW_AT_bit_offset(0x1c), DW_AT_bit_size(0x04)
1687 .dwattr $C$DW$118, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
1688 .dwattr $C$DW$118, DW_AT_accessibility(DW_ACCESS_public)
1689 .dwattr $C$DW$118, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
1690 .dwattr $C$DW$118, DW_AT_decl_line(0x96)
1691 .dwattr $C$DW$118, DW_AT_decl_column(0x0d)
1692$C$DW$119 .dwtag DW_TAG_member
1693 .dwattr $C$DW$119, DW_AT_type(*$C$DW$T$11)
1694 .dwattr $C$DW$119, DW_AT_name("PRU0_DMEM_PE")
1695 .dwattr $C$DW$119, DW_AT_TI_symbol_name("PRU0_DMEM_PE")
1696 .dwattr $C$DW$119, DW_AT_bit_offset(0x18), DW_AT_bit_size(0x04)
1697 .dwattr $C$DW$119, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
1698 .dwattr $C$DW$119, DW_AT_accessibility(DW_ACCESS_public)
1699 .dwattr $C$DW$119, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
1700 .dwattr $C$DW$119, DW_AT_decl_line(0x97)
1701 .dwattr $C$DW$119, DW_AT_decl_column(0x0d)
1702$C$DW$120 .dwtag DW_TAG_member
1703 .dwattr $C$DW$120, DW_AT_type(*$C$DW$T$11)
1704 .dwattr $C$DW$120, DW_AT_name("PRU1_IMEM_PE")
1705 .dwattr $C$DW$120, DW_AT_TI_symbol_name("PRU1_IMEM_PE")
1706 .dwattr $C$DW$120, DW_AT_bit_offset(0x14), DW_AT_bit_size(0x04)
1707 .dwattr $C$DW$120, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
1708 .dwattr $C$DW$120, DW_AT_accessibility(DW_ACCESS_public)
1709 .dwattr $C$DW$120, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
1710 .dwattr $C$DW$120, DW_AT_decl_line(0x98)
1711 .dwattr $C$DW$120, DW_AT_decl_column(0x0d)
1712$C$DW$121 .dwtag DW_TAG_member
1713 .dwattr $C$DW$121, DW_AT_type(*$C$DW$T$11)
1714 .dwattr $C$DW$121, DW_AT_name("PRU1_DMEM_PE")
1715 .dwattr $C$DW$121, DW_AT_TI_symbol_name("PRU1_DMEM_PE")
1716 .dwattr $C$DW$121, DW_AT_bit_offset(0x10), DW_AT_bit_size(0x04)
1717 .dwattr $C$DW$121, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
1718 .dwattr $C$DW$121, DW_AT_accessibility(DW_ACCESS_public)
1719 .dwattr $C$DW$121, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
1720 .dwattr $C$DW$121, DW_AT_decl_line(0x99)
1721 .dwattr $C$DW$121, DW_AT_decl_column(0x0d)
1722$C$DW$122 .dwtag DW_TAG_member
1723 .dwattr $C$DW$122, DW_AT_type(*$C$DW$T$11)
1724 .dwattr $C$DW$122, DW_AT_name("RAM_PE")
1725 .dwattr $C$DW$122, DW_AT_TI_symbol_name("RAM_PE")
1726 .dwattr $C$DW$122, DW_AT_bit_offset(0x0c), DW_AT_bit_size(0x04)
1727 .dwattr $C$DW$122, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
1728 .dwattr $C$DW$122, DW_AT_accessibility(DW_ACCESS_public)
1729 .dwattr $C$DW$122, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
1730 .dwattr $C$DW$122, DW_AT_decl_line(0x9a)
1731 .dwattr $C$DW$122, DW_AT_decl_column(0x0d)
1732$C$DW$123 .dwtag DW_TAG_member
1733 .dwattr $C$DW$123, DW_AT_type(*$C$DW$T$11)
1734 .dwattr $C$DW$123, DW_AT_name("rsvd20")
1735 .dwattr $C$DW$123, DW_AT_TI_symbol_name("rsvd20")
1736 .dwattr $C$DW$123, DW_AT_bit_offset(0x00), DW_AT_bit_size(0x0c)
1737 .dwattr $C$DW$123, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
1738 .dwattr $C$DW$123, DW_AT_accessibility(DW_ACCESS_public)
1739 .dwattr $C$DW$123, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
1740 .dwattr $C$DW$123, DW_AT_decl_line(0x9b)
1741 .dwattr $C$DW$123, DW_AT_decl_column(0x0d)
1742 .dwendtag $C$DW$T$26
1743
1744 .dwattr $C$DW$T$26, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
1745 .dwattr $C$DW$T$26, DW_AT_decl_line(0x95)
1746 .dwattr $C$DW$T$26, DW_AT_decl_column(0x14)
1747$C$DW$T$61 .dwtag DW_TAG_volatile_type
1748 .dwattr $C$DW$T$61, DW_AT_type(*$C$DW$T$26)
1749
1750$C$DW$T$27 .dwtag DW_TAG_structure_type
1751 .dwattr $C$DW$T$27, DW_AT_byte_size(0x04)
1752$C$DW$124 .dwtag DW_TAG_member
1753 .dwattr $C$DW$124, DW_AT_type(*$C$DW$T$11)
1754 .dwattr $C$DW$124, DW_AT_name("PRU0_IMEM_PE_SET")
1755 .dwattr $C$DW$124, DW_AT_TI_symbol_name("PRU0_IMEM_PE_SET")
1756 .dwattr $C$DW$124, DW_AT_bit_offset(0x1c), DW_AT_bit_size(0x04)
1757 .dwattr $C$DW$124, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
1758 .dwattr $C$DW$124, DW_AT_accessibility(DW_ACCESS_public)
1759 .dwattr $C$DW$124, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
1760 .dwattr $C$DW$124, DW_AT_decl_line(0xa4)
1761 .dwattr $C$DW$124, DW_AT_decl_column(0x0d)
1762$C$DW$125 .dwtag DW_TAG_member
1763 .dwattr $C$DW$125, DW_AT_type(*$C$DW$T$11)
1764 .dwattr $C$DW$125, DW_AT_name("PRU0_DMEM_PE_SET")
1765 .dwattr $C$DW$125, DW_AT_TI_symbol_name("PRU0_DMEM_PE_SET")
1766 .dwattr $C$DW$125, DW_AT_bit_offset(0x18), DW_AT_bit_size(0x04)
1767 .dwattr $C$DW$125, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
1768 .dwattr $C$DW$125, DW_AT_accessibility(DW_ACCESS_public)
1769 .dwattr $C$DW$125, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
1770 .dwattr $C$DW$125, DW_AT_decl_line(0xa5)
1771 .dwattr $C$DW$125, DW_AT_decl_column(0x0d)
1772$C$DW$126 .dwtag DW_TAG_member
1773 .dwattr $C$DW$126, DW_AT_type(*$C$DW$T$11)
1774 .dwattr $C$DW$126, DW_AT_name("PRU1_IMEM_PE_SET")
1775 .dwattr $C$DW$126, DW_AT_TI_symbol_name("PRU1_IMEM_PE_SET")
1776 .dwattr $C$DW$126, DW_AT_bit_offset(0x14), DW_AT_bit_size(0x04)
1777 .dwattr $C$DW$126, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
1778 .dwattr $C$DW$126, DW_AT_accessibility(DW_ACCESS_public)
1779 .dwattr $C$DW$126, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
1780 .dwattr $C$DW$126, DW_AT_decl_line(0xa6)
1781 .dwattr $C$DW$126, DW_AT_decl_column(0x0d)
1782$C$DW$127 .dwtag DW_TAG_member
1783 .dwattr $C$DW$127, DW_AT_type(*$C$DW$T$11)
1784 .dwattr $C$DW$127, DW_AT_name("PRU1_DMEM_PE_SET")
1785 .dwattr $C$DW$127, DW_AT_TI_symbol_name("PRU1_DMEM_PE_SET")
1786 .dwattr $C$DW$127, DW_AT_bit_offset(0x10), DW_AT_bit_size(0x04)
1787 .dwattr $C$DW$127, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
1788 .dwattr $C$DW$127, DW_AT_accessibility(DW_ACCESS_public)
1789 .dwattr $C$DW$127, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
1790 .dwattr $C$DW$127, DW_AT_decl_line(0xa7)
1791 .dwattr $C$DW$127, DW_AT_decl_column(0x0d)
1792$C$DW$128 .dwtag DW_TAG_member
1793 .dwattr $C$DW$128, DW_AT_type(*$C$DW$T$11)
1794 .dwattr $C$DW$128, DW_AT_name("RAM_PE_SET")
1795 .dwattr $C$DW$128, DW_AT_TI_symbol_name("RAM_PE_SET")
1796 .dwattr $C$DW$128, DW_AT_bit_offset(0x0c), DW_AT_bit_size(0x04)
1797 .dwattr $C$DW$128, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
1798 .dwattr $C$DW$128, DW_AT_accessibility(DW_ACCESS_public)
1799 .dwattr $C$DW$128, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
1800 .dwattr $C$DW$128, DW_AT_decl_line(0xa8)
1801 .dwattr $C$DW$128, DW_AT_decl_column(0x0d)
1802$C$DW$129 .dwtag DW_TAG_member
1803 .dwattr $C$DW$129, DW_AT_type(*$C$DW$T$11)
1804 .dwattr $C$DW$129, DW_AT_name("rsvd20")
1805 .dwattr $C$DW$129, DW_AT_TI_symbol_name("rsvd20")
1806 .dwattr $C$DW$129, DW_AT_bit_offset(0x00), DW_AT_bit_size(0x0c)
1807 .dwattr $C$DW$129, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
1808 .dwattr $C$DW$129, DW_AT_accessibility(DW_ACCESS_public)
1809 .dwattr $C$DW$129, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
1810 .dwattr $C$DW$129, DW_AT_decl_line(0xa9)
1811 .dwattr $C$DW$129, DW_AT_decl_column(0x0d)
1812 .dwendtag $C$DW$T$27
1813
1814 .dwattr $C$DW$T$27, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
1815 .dwattr $C$DW$T$27, DW_AT_decl_line(0xa3)
1816 .dwattr $C$DW$T$27, DW_AT_decl_column(0x13)
1817$C$DW$T$63 .dwtag DW_TAG_volatile_type
1818 .dwattr $C$DW$T$63, DW_AT_type(*$C$DW$T$27)
1819
1820$C$DW$T$28 .dwtag DW_TAG_structure_type
1821 .dwattr $C$DW$T$28, DW_AT_byte_size(0x04)
1822$C$DW$130 .dwtag DW_TAG_member
1823 .dwattr $C$DW$130, DW_AT_type(*$C$DW$T$11)
1824 .dwattr $C$DW$130, DW_AT_name("PRU0_IMEM_PE_CLR")
1825 .dwattr $C$DW$130, DW_AT_TI_symbol_name("PRU0_IMEM_PE_CLR")
1826 .dwattr $C$DW$130, DW_AT_bit_offset(0x1c), DW_AT_bit_size(0x04)
1827 .dwattr $C$DW$130, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
1828 .dwattr $C$DW$130, DW_AT_accessibility(DW_ACCESS_public)
1829 .dwattr $C$DW$130, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
1830 .dwattr $C$DW$130, DW_AT_decl_line(0xb3)
1831 .dwattr $C$DW$130, DW_AT_decl_column(0x0d)
1832$C$DW$131 .dwtag DW_TAG_member
1833 .dwattr $C$DW$131, DW_AT_type(*$C$DW$T$11)
1834 .dwattr $C$DW$131, DW_AT_name("PRU0_DMEM_PE_CLR")
1835 .dwattr $C$DW$131, DW_AT_TI_symbol_name("PRU0_DMEM_PE_CLR")
1836 .dwattr $C$DW$131, DW_AT_bit_offset(0x18), DW_AT_bit_size(0x04)
1837 .dwattr $C$DW$131, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
1838 .dwattr $C$DW$131, DW_AT_accessibility(DW_ACCESS_public)
1839 .dwattr $C$DW$131, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
1840 .dwattr $C$DW$131, DW_AT_decl_line(0xb4)
1841 .dwattr $C$DW$131, DW_AT_decl_column(0x0d)
1842$C$DW$132 .dwtag DW_TAG_member
1843 .dwattr $C$DW$132, DW_AT_type(*$C$DW$T$11)
1844 .dwattr $C$DW$132, DW_AT_name("PRU1_IMEM_PE_CLR")
1845 .dwattr $C$DW$132, DW_AT_TI_symbol_name("PRU1_IMEM_PE_CLR")
1846 .dwattr $C$DW$132, DW_AT_bit_offset(0x14), DW_AT_bit_size(0x04)
1847 .dwattr $C$DW$132, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
1848 .dwattr $C$DW$132, DW_AT_accessibility(DW_ACCESS_public)
1849 .dwattr $C$DW$132, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
1850 .dwattr $C$DW$132, DW_AT_decl_line(0xb5)
1851 .dwattr $C$DW$132, DW_AT_decl_column(0x0d)
1852$C$DW$133 .dwtag DW_TAG_member
1853 .dwattr $C$DW$133, DW_AT_type(*$C$DW$T$11)
1854 .dwattr $C$DW$133, DW_AT_name("PRU1_DMEM_PE_CLR")
1855 .dwattr $C$DW$133, DW_AT_TI_symbol_name("PRU1_DMEM_PE_CLR")
1856 .dwattr $C$DW$133, DW_AT_bit_offset(0x10), DW_AT_bit_size(0x04)
1857 .dwattr $C$DW$133, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
1858 .dwattr $C$DW$133, DW_AT_accessibility(DW_ACCESS_public)
1859 .dwattr $C$DW$133, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
1860 .dwattr $C$DW$133, DW_AT_decl_line(0xb6)
1861 .dwattr $C$DW$133, DW_AT_decl_column(0x0d)
1862$C$DW$134 .dwtag DW_TAG_member
1863 .dwattr $C$DW$134, DW_AT_type(*$C$DW$T$11)
1864 .dwattr $C$DW$134, DW_AT_name("rsvd16")
1865 .dwattr $C$DW$134, DW_AT_TI_symbol_name("rsvd16")
1866 .dwattr $C$DW$134, DW_AT_bit_offset(0x00), DW_AT_bit_size(0x10)
1867 .dwattr $C$DW$134, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
1868 .dwattr $C$DW$134, DW_AT_accessibility(DW_ACCESS_public)
1869 .dwattr $C$DW$134, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
1870 .dwattr $C$DW$134, DW_AT_decl_line(0xb7)
1871 .dwattr $C$DW$134, DW_AT_decl_column(0x0d)
1872 .dwendtag $C$DW$T$28
1873
1874 .dwattr $C$DW$T$28, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
1875 .dwattr $C$DW$T$28, DW_AT_decl_line(0xb2)
1876 .dwattr $C$DW$T$28, DW_AT_decl_column(0x13)
1877$C$DW$T$65 .dwtag DW_TAG_volatile_type
1878 .dwattr $C$DW$T$65, DW_AT_type(*$C$DW$T$28)
1879
1880$C$DW$T$29 .dwtag DW_TAG_structure_type
1881 .dwattr $C$DW$T$29, DW_AT_byte_size(0x04)
1882$C$DW$135 .dwtag DW_TAG_member
1883 .dwattr $C$DW$135, DW_AT_type(*$C$DW$T$11)
1884 .dwattr $C$DW$135, DW_AT_name("PMAO_PRU0")
1885 .dwattr $C$DW$135, DW_AT_TI_symbol_name("PMAO_PRU0")
1886 .dwattr $C$DW$135, DW_AT_bit_offset(0x1f), DW_AT_bit_size(0x01)
1887 .dwattr $C$DW$135, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
1888 .dwattr $C$DW$135, DW_AT_accessibility(DW_ACCESS_public)
1889 .dwattr $C$DW$135, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
1890 .dwattr $C$DW$135, DW_AT_decl_line(0xc4)
1891 .dwattr $C$DW$135, DW_AT_decl_column(0x0d)
1892$C$DW$136 .dwtag DW_TAG_member
1893 .dwattr $C$DW$136, DW_AT_type(*$C$DW$T$11)
1894 .dwattr $C$DW$136, DW_AT_name("PMAO_PRU1")
1895 .dwattr $C$DW$136, DW_AT_TI_symbol_name("PMAO_PRU1")
1896 .dwattr $C$DW$136, DW_AT_bit_offset(0x1e), DW_AT_bit_size(0x01)
1897 .dwattr $C$DW$136, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
1898 .dwattr $C$DW$136, DW_AT_accessibility(DW_ACCESS_public)
1899 .dwattr $C$DW$136, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
1900 .dwattr $C$DW$136, DW_AT_decl_line(0xc5)
1901 .dwattr $C$DW$136, DW_AT_decl_column(0x0d)
1902$C$DW$137 .dwtag DW_TAG_member
1903 .dwattr $C$DW$137, DW_AT_type(*$C$DW$T$11)
1904 .dwattr $C$DW$137, DW_AT_name("rsvd2")
1905 .dwattr $C$DW$137, DW_AT_TI_symbol_name("rsvd2")
1906 .dwattr $C$DW$137, DW_AT_bit_offset(0x00), DW_AT_bit_size(0x1e)
1907 .dwattr $C$DW$137, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
1908 .dwattr $C$DW$137, DW_AT_accessibility(DW_ACCESS_public)
1909 .dwattr $C$DW$137, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
1910 .dwattr $C$DW$137, DW_AT_decl_line(0xc6)
1911 .dwattr $C$DW$137, DW_AT_decl_column(0x0d)
1912 .dwendtag $C$DW$T$29
1913
1914 .dwattr $C$DW$T$29, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
1915 .dwattr $C$DW$T$29, DW_AT_decl_line(0xc3)
1916 .dwattr $C$DW$T$29, DW_AT_decl_column(0x13)
1917$C$DW$T$67 .dwtag DW_TAG_volatile_type
1918 .dwattr $C$DW$T$67, DW_AT_type(*$C$DW$T$29)
1919
1920$C$DW$T$30 .dwtag DW_TAG_structure_type
1921 .dwattr $C$DW$T$30, DW_AT_byte_size(0x04)
1922$C$DW$138 .dwtag DW_TAG_member
1923 .dwattr $C$DW$138, DW_AT_type(*$C$DW$T$11)
1924 .dwattr $C$DW$138, DW_AT_name("OCP_EN")
1925 .dwattr $C$DW$138, DW_AT_TI_symbol_name("OCP_EN")
1926 .dwattr $C$DW$138, DW_AT_bit_offset(0x1f), DW_AT_bit_size(0x01)
1927 .dwattr $C$DW$138, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
1928 .dwattr $C$DW$138, DW_AT_accessibility(DW_ACCESS_public)
1929 .dwattr $C$DW$138, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
1930 .dwattr $C$DW$138, DW_AT_decl_line(0xd3)
1931 .dwattr $C$DW$138, DW_AT_decl_column(0x0d)
1932$C$DW$139 .dwtag DW_TAG_member
1933 .dwattr $C$DW$139, DW_AT_type(*$C$DW$T$11)
1934 .dwattr $C$DW$139, DW_AT_name("rsvd1")
1935 .dwattr $C$DW$139, DW_AT_TI_symbol_name("rsvd1")
1936 .dwattr $C$DW$139, DW_AT_bit_offset(0x00), DW_AT_bit_size(0x1f)
1937 .dwattr $C$DW$139, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
1938 .dwattr $C$DW$139, DW_AT_accessibility(DW_ACCESS_public)
1939 .dwattr $C$DW$139, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
1940 .dwattr $C$DW$139, DW_AT_decl_line(0xd4)
1941 .dwattr $C$DW$139, DW_AT_decl_column(0x0d)
1942 .dwendtag $C$DW$T$30
1943
1944 .dwattr $C$DW$T$30, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
1945 .dwattr $C$DW$T$30, DW_AT_decl_line(0xd2)
1946 .dwattr $C$DW$T$30, DW_AT_decl_column(0x13)
1947$C$DW$T$69 .dwtag DW_TAG_volatile_type
1948 .dwattr $C$DW$T$69, DW_AT_type(*$C$DW$T$30)
1949
1950$C$DW$T$31 .dwtag DW_TAG_structure_type
1951 .dwattr $C$DW$T$31, DW_AT_byte_size(0x04)
1952$C$DW$140 .dwtag DW_TAG_member
1953 .dwattr $C$DW$140, DW_AT_type(*$C$DW$T$11)
1954 .dwattr $C$DW$140, DW_AT_name("PRU1_PAD_HP_EN")
1955 .dwattr $C$DW$140, DW_AT_TI_symbol_name("PRU1_PAD_HP_EN")
1956 .dwattr $C$DW$140, DW_AT_bit_offset(0x1f), DW_AT_bit_size(0x01)
1957 .dwattr $C$DW$140, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
1958 .dwattr $C$DW$140, DW_AT_accessibility(DW_ACCESS_public)
1959 .dwattr $C$DW$140, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
1960 .dwattr $C$DW$140, DW_AT_decl_line(0xde)
1961 .dwattr $C$DW$140, DW_AT_decl_column(0x0d)
1962$C$DW$141 .dwtag DW_TAG_member
1963 .dwattr $C$DW$141, DW_AT_type(*$C$DW$T$11)
1964 .dwattr $C$DW$141, DW_AT_name("XFR_SHIFT_EN")
1965 .dwattr $C$DW$141, DW_AT_TI_symbol_name("XFR_SHIFT_EN")
1966 .dwattr $C$DW$141, DW_AT_bit_offset(0x1e), DW_AT_bit_size(0x01)
1967 .dwattr $C$DW$141, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
1968 .dwattr $C$DW$141, DW_AT_accessibility(DW_ACCESS_public)
1969 .dwattr $C$DW$141, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
1970 .dwattr $C$DW$141, DW_AT_decl_line(0xdf)
1971 .dwattr $C$DW$141, DW_AT_decl_column(0x0d)
1972$C$DW$142 .dwtag DW_TAG_member
1973 .dwattr $C$DW$142, DW_AT_type(*$C$DW$T$11)
1974 .dwattr $C$DW$142, DW_AT_name("rsvd2")
1975 .dwattr $C$DW$142, DW_AT_TI_symbol_name("rsvd2")
1976 .dwattr $C$DW$142, DW_AT_bit_offset(0x00), DW_AT_bit_size(0x1e)
1977 .dwattr $C$DW$142, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
1978 .dwattr $C$DW$142, DW_AT_accessibility(DW_ACCESS_public)
1979 .dwattr $C$DW$142, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
1980 .dwattr $C$DW$142, DW_AT_decl_line(0xe0)
1981 .dwattr $C$DW$142, DW_AT_decl_column(0x0d)
1982 .dwendtag $C$DW$T$31
1983
1984 .dwattr $C$DW$T$31, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
1985 .dwattr $C$DW$T$31, DW_AT_decl_line(0xdd)
1986 .dwattr $C$DW$T$31, DW_AT_decl_column(0x13)
1987$C$DW$T$71 .dwtag DW_TAG_volatile_type
1988 .dwattr $C$DW$T$71, DW_AT_type(*$C$DW$T$31)
1989
1990$C$DW$T$32 .dwtag DW_TAG_structure_type
1991 .dwattr $C$DW$T$32, DW_AT_byte_size(0x04)
1992$C$DW$143 .dwtag DW_TAG_member
1993 .dwattr $C$DW$143, DW_AT_type(*$C$DW$T$11)
1994 .dwattr $C$DW$143, DW_AT_name("PIN_MUX_SEL")
1995 .dwattr $C$DW$143, DW_AT_TI_symbol_name("PIN_MUX_SEL")
1996 .dwattr $C$DW$143, DW_AT_bit_offset(0x18), DW_AT_bit_size(0x08)
1997 .dwattr $C$DW$143, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
1998 .dwattr $C$DW$143, DW_AT_accessibility(DW_ACCESS_public)
1999 .dwattr $C$DW$143, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
2000 .dwattr $C$DW$143, DW_AT_decl_line(0xec)
2001 .dwattr $C$DW$143, DW_AT_decl_column(0x0d)
2002$C$DW$144 .dwtag DW_TAG_member
2003 .dwattr $C$DW$144, DW_AT_type(*$C$DW$T$11)
2004 .dwattr $C$DW$144, DW_AT_name("rsvd2")
2005 .dwattr $C$DW$144, DW_AT_TI_symbol_name("rsvd2")
2006 .dwattr $C$DW$144, DW_AT_bit_offset(0x00), DW_AT_bit_size(0x18)
2007 .dwattr $C$DW$144, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
2008 .dwattr $C$DW$144, DW_AT_accessibility(DW_ACCESS_public)
2009 .dwattr $C$DW$144, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
2010 .dwattr $C$DW$144, DW_AT_decl_line(0xed)
2011 .dwattr $C$DW$144, DW_AT_decl_column(0x0d)
2012 .dwendtag $C$DW$T$32
2013
2014 .dwattr $C$DW$T$32, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
2015 .dwattr $C$DW$T$32, DW_AT_decl_line(0xeb)
2016 .dwattr $C$DW$T$32, DW_AT_decl_column(0x13)
2017$C$DW$T$73 .dwtag DW_TAG_volatile_type
2018 .dwattr $C$DW$T$73, DW_AT_type(*$C$DW$T$32)
2019
2020$C$DW$T$36 .dwtag DW_TAG_structure_type
2021 .dwattr $C$DW$T$36, DW_AT_byte_size(0x44)
2022$C$DW$145 .dwtag DW_TAG_member
2023 .dwattr $C$DW$145, DW_AT_type(*$C$DW$T$50)
2024 .dwattr $C$DW$145, DW_AT_name("$P$T0")
2025 .dwattr $C$DW$145, DW_AT_TI_symbol_name("$P$T0")
2026 .dwattr $C$DW$145, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
2027 .dwattr $C$DW$145, DW_AT_accessibility(DW_ACCESS_public)
2028 .dwattr $C$DW$145, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
2029 .dwattr $C$DW$145, DW_AT_decl_line(0x29)
2030 .dwattr $C$DW$145, DW_AT_decl_column(0x02)
2031$C$DW$146 .dwtag DW_TAG_member
2032 .dwattr $C$DW$146, DW_AT_type(*$C$DW$T$52)
2033 .dwattr $C$DW$146, DW_AT_name("$P$T1")
2034 .dwattr $C$DW$146, DW_AT_TI_symbol_name("$P$T1")
2035 .dwattr $C$DW$146, DW_AT_data_member_location[DW_OP_plus_uconst 0x4]
2036 .dwattr $C$DW$146, DW_AT_accessibility(DW_ACCESS_public)
2037 .dwattr $C$DW$146, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
2038 .dwattr $C$DW$146, DW_AT_decl_line(0x33)
2039 .dwattr $C$DW$146, DW_AT_decl_column(0x02)
2040$C$DW$147 .dwtag DW_TAG_member
2041 .dwattr $C$DW$147, DW_AT_type(*$C$DW$T$54)
2042 .dwattr $C$DW$147, DW_AT_name("$P$T2")
2043 .dwattr $C$DW$147, DW_AT_TI_symbol_name("$P$T2")
2044 .dwattr $C$DW$147, DW_AT_data_member_location[DW_OP_plus_uconst 0x8]
2045 .dwattr $C$DW$147, DW_AT_accessibility(DW_ACCESS_public)
2046 .dwattr $C$DW$147, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
2047 .dwattr $C$DW$147, DW_AT_decl_line(0x41)
2048 .dwattr $C$DW$147, DW_AT_decl_column(0x02)
2049$C$DW$148 .dwtag DW_TAG_member
2050 .dwattr $C$DW$148, DW_AT_type(*$C$DW$T$56)
2051 .dwattr $C$DW$148, DW_AT_name("$P$T3")
2052 .dwattr $C$DW$148, DW_AT_TI_symbol_name("$P$T3")
2053 .dwattr $C$DW$148, DW_AT_data_member_location[DW_OP_plus_uconst 0xc]
2054 .dwattr $C$DW$148, DW_AT_accessibility(DW_ACCESS_public)
2055 .dwattr $C$DW$148, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
2056 .dwattr $C$DW$148, DW_AT_decl_line(0x54)
2057 .dwattr $C$DW$148, DW_AT_decl_column(0x02)
2058$C$DW$149 .dwtag DW_TAG_member
2059 .dwattr $C$DW$149, DW_AT_type(*$C$DW$T$58)
2060 .dwattr $C$DW$149, DW_AT_name("$P$T4")
2061 .dwattr $C$DW$149, DW_AT_TI_symbol_name("$P$T4")
2062 .dwattr $C$DW$149, DW_AT_data_member_location[DW_OP_plus_uconst 0x10]
2063 .dwattr $C$DW$149, DW_AT_accessibility(DW_ACCESS_public)
2064 .dwattr $C$DW$149, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
2065 .dwattr $C$DW$149, DW_AT_decl_line(0x67)
2066 .dwattr $C$DW$149, DW_AT_decl_column(0x02)
2067$C$DW$150 .dwtag DW_TAG_member
2068 .dwattr $C$DW$150, DW_AT_type(*$C$DW$T$60)
2069 .dwattr $C$DW$150, DW_AT_name("$P$T5")
2070 .dwattr $C$DW$150, DW_AT_TI_symbol_name("$P$T5")
2071 .dwattr $C$DW$150, DW_AT_data_member_location[DW_OP_plus_uconst 0x14]
2072 .dwattr $C$DW$150, DW_AT_accessibility(DW_ACCESS_public)
2073 .dwattr $C$DW$150, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
2074 .dwattr $C$DW$150, DW_AT_decl_line(0x83)
2075 .dwattr $C$DW$150, DW_AT_decl_column(0x02)
2076$C$DW$151 .dwtag DW_TAG_member
2077 .dwattr $C$DW$151, DW_AT_type(*$C$DW$T$62)
2078 .dwattr $C$DW$151, DW_AT_name("$P$T6")
2079 .dwattr $C$DW$151, DW_AT_TI_symbol_name("$P$T6")
2080 .dwattr $C$DW$151, DW_AT_data_member_location[DW_OP_plus_uconst 0x18]
2081 .dwattr $C$DW$151, DW_AT_accessibility(DW_ACCESS_public)
2082 .dwattr $C$DW$151, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
2083 .dwattr $C$DW$151, DW_AT_decl_line(0x92)
2084 .dwattr $C$DW$151, DW_AT_decl_column(0x02)
2085$C$DW$152 .dwtag DW_TAG_member
2086 .dwattr $C$DW$152, DW_AT_type(*$C$DW$T$64)
2087 .dwattr $C$DW$152, DW_AT_name("$P$T7")
2088 .dwattr $C$DW$152, DW_AT_TI_symbol_name("$P$T7")
2089 .dwattr $C$DW$152, DW_AT_data_member_location[DW_OP_plus_uconst 0x1c]
2090 .dwattr $C$DW$152, DW_AT_accessibility(DW_ACCESS_public)
2091 .dwattr $C$DW$152, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
2092 .dwattr $C$DW$152, DW_AT_decl_line(0xa0)
2093 .dwattr $C$DW$152, DW_AT_decl_column(0x02)
2094$C$DW$153 .dwtag DW_TAG_member
2095 .dwattr $C$DW$153, DW_AT_type(*$C$DW$T$66)
2096 .dwattr $C$DW$153, DW_AT_name("$P$T8")
2097 .dwattr $C$DW$153, DW_AT_TI_symbol_name("$P$T8")
2098 .dwattr $C$DW$153, DW_AT_data_member_location[DW_OP_plus_uconst 0x20]
2099 .dwattr $C$DW$153, DW_AT_accessibility(DW_ACCESS_public)
2100 .dwattr $C$DW$153, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
2101 .dwattr $C$DW$153, DW_AT_decl_line(0xaf)
2102 .dwattr $C$DW$153, DW_AT_decl_column(0x02)
2103$C$DW$154 .dwtag DW_TAG_member
2104 .dwattr $C$DW$154, DW_AT_type(*$C$DW$T$33)
2105 .dwattr $C$DW$154, DW_AT_name("rsvd24")
2106 .dwattr $C$DW$154, DW_AT_TI_symbol_name("rsvd24")
2107 .dwattr $C$DW$154, DW_AT_data_member_location[DW_OP_plus_uconst 0x24]
2108 .dwattr $C$DW$154, DW_AT_accessibility(DW_ACCESS_public)
2109 .dwattr $C$DW$154, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
2110 .dwattr $C$DW$154, DW_AT_decl_line(0xbc)
2111 .dwattr $C$DW$154, DW_AT_decl_column(0x0b)
2112$C$DW$155 .dwtag DW_TAG_member
2113 .dwattr $C$DW$155, DW_AT_type(*$C$DW$T$68)
2114 .dwattr $C$DW$155, DW_AT_name("$P$T9")
2115 .dwattr $C$DW$155, DW_AT_TI_symbol_name("$P$T9")
2116 .dwattr $C$DW$155, DW_AT_data_member_location[DW_OP_plus_uconst 0x28]
2117 .dwattr $C$DW$155, DW_AT_accessibility(DW_ACCESS_public)
2118 .dwattr $C$DW$155, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
2119 .dwattr $C$DW$155, DW_AT_decl_line(0xc0)
2120 .dwattr $C$DW$155, DW_AT_decl_column(0x02)
2121$C$DW$156 .dwtag DW_TAG_member
2122 .dwattr $C$DW$156, DW_AT_type(*$C$DW$T$34)
2123 .dwattr $C$DW$156, DW_AT_name("rsvd2c")
2124 .dwattr $C$DW$156, DW_AT_TI_symbol_name("rsvd2c")
2125 .dwattr $C$DW$156, DW_AT_data_member_location[DW_OP_plus_uconst 0x2c]
2126 .dwattr $C$DW$156, DW_AT_accessibility(DW_ACCESS_public)
2127 .dwattr $C$DW$156, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
2128 .dwattr $C$DW$156, DW_AT_decl_line(0xcb)
2129 .dwattr $C$DW$156, DW_AT_decl_column(0x0b)
2130$C$DW$157 .dwtag DW_TAG_member
2131 .dwattr $C$DW$157, DW_AT_type(*$C$DW$T$70)
2132 .dwattr $C$DW$157, DW_AT_name("$P$T10")
2133 .dwattr $C$DW$157, DW_AT_TI_symbol_name("$P$T10")
2134 .dwattr $C$DW$157, DW_AT_data_member_location[DW_OP_plus_uconst 0x30]
2135 .dwattr $C$DW$157, DW_AT_accessibility(DW_ACCESS_public)
2136 .dwattr $C$DW$157, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
2137 .dwattr $C$DW$157, DW_AT_decl_line(0xcf)
2138 .dwattr $C$DW$157, DW_AT_decl_column(0x02)
2139$C$DW$158 .dwtag DW_TAG_member
2140 .dwattr $C$DW$158, DW_AT_type(*$C$DW$T$72)
2141 .dwattr $C$DW$158, DW_AT_name("$P$T11")
2142 .dwattr $C$DW$158, DW_AT_TI_symbol_name("$P$T11")
2143 .dwattr $C$DW$158, DW_AT_data_member_location[DW_OP_plus_uconst 0x34]
2144 .dwattr $C$DW$158, DW_AT_accessibility(DW_ACCESS_public)
2145 .dwattr $C$DW$158, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
2146 .dwattr $C$DW$158, DW_AT_decl_line(0xda)
2147 .dwattr $C$DW$158, DW_AT_decl_column(0x02)
2148$C$DW$159 .dwtag DW_TAG_member
2149 .dwattr $C$DW$159, DW_AT_type(*$C$DW$T$35)
2150 .dwattr $C$DW$159, DW_AT_name("rsvd38")
2151 .dwattr $C$DW$159, DW_AT_TI_symbol_name("rsvd38")
2152 .dwattr $C$DW$159, DW_AT_data_member_location[DW_OP_plus_uconst 0x38]
2153 .dwattr $C$DW$159, DW_AT_accessibility(DW_ACCESS_public)
2154 .dwattr $C$DW$159, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
2155 .dwattr $C$DW$159, DW_AT_decl_line(0xe5)
2156 .dwattr $C$DW$159, DW_AT_decl_column(0x0b)
2157$C$DW$160 .dwtag DW_TAG_member
2158 .dwattr $C$DW$160, DW_AT_type(*$C$DW$T$74)
2159 .dwattr $C$DW$160, DW_AT_name("$P$T12")
2160 .dwattr $C$DW$160, DW_AT_TI_symbol_name("$P$T12")
2161 .dwattr $C$DW$160, DW_AT_data_member_location[DW_OP_plus_uconst 0x40]
2162 .dwattr $C$DW$160, DW_AT_accessibility(DW_ACCESS_public)
2163 .dwattr $C$DW$160, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
2164 .dwattr $C$DW$160, DW_AT_decl_line(0xe8)
2165 .dwattr $C$DW$160, DW_AT_decl_column(0x02)
2166 .dwendtag $C$DW$T$36
2167
2168 .dwattr $C$DW$T$36, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
2169 .dwattr $C$DW$T$36, DW_AT_decl_line(0x26)
2170 .dwattr $C$DW$T$36, DW_AT_decl_column(0x10)
2171$C$DW$T$98 .dwtag DW_TAG_typedef, DW_AT_name("pruCfg")
2172 .dwattr $C$DW$T$98, DW_AT_type(*$C$DW$T$36)
2173 .dwattr $C$DW$T$98, DW_AT_language(DW_LANG_C)
2174 .dwattr $C$DW$T$98, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
2175 .dwattr $C$DW$T$98, DW_AT_decl_line(0xf0)
2176 .dwattr $C$DW$T$98, DW_AT_decl_column(0x03)
2177$C$DW$T$99 .dwtag DW_TAG_volatile_type
2178 .dwattr $C$DW$T$99, DW_AT_type(*$C$DW$T$98)
2179
2180$C$DW$T$37 .dwtag DW_TAG_structure_type
2181 .dwattr $C$DW$T$37, DW_AT_byte_size(0x04)
2182$C$DW$161 .dwtag DW_TAG_member
2183 .dwattr $C$DW$161, DW_AT_type(*$C$DW$T$11)
2184 .dwattr $C$DW$161, DW_AT_name("SOFT_RST_N")
2185 .dwattr $C$DW$161, DW_AT_TI_symbol_name("SOFT_RST_N")
2186 .dwattr $C$DW$161, DW_AT_bit_offset(0x1f), DW_AT_bit_size(0x01)
2187 .dwattr $C$DW$161, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
2188 .dwattr $C$DW$161, DW_AT_accessibility(DW_ACCESS_public)
2189 .dwattr $C$DW$161, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_ctrl.h")
2190 .dwattr $C$DW$161, DW_AT_decl_line(0x2d)
2191 .dwattr $C$DW$161, DW_AT_decl_column(0x0d)
2192$C$DW$162 .dwtag DW_TAG_member
2193 .dwattr $C$DW$162, DW_AT_type(*$C$DW$T$11)
2194 .dwattr $C$DW$162, DW_AT_name("EN")
2195 .dwattr $C$DW$162, DW_AT_TI_symbol_name("EN")
2196 .dwattr $C$DW$162, DW_AT_bit_offset(0x1e), DW_AT_bit_size(0x01)
2197 .dwattr $C$DW$162, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
2198 .dwattr $C$DW$162, DW_AT_accessibility(DW_ACCESS_public)
2199 .dwattr $C$DW$162, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_ctrl.h")
2200 .dwattr $C$DW$162, DW_AT_decl_line(0x2e)
2201 .dwattr $C$DW$162, DW_AT_decl_column(0x0d)
2202$C$DW$163 .dwtag DW_TAG_member
2203 .dwattr $C$DW$163, DW_AT_type(*$C$DW$T$11)
2204 .dwattr $C$DW$163, DW_AT_name("SLEEPING")
2205 .dwattr $C$DW$163, DW_AT_TI_symbol_name("SLEEPING")
2206 .dwattr $C$DW$163, DW_AT_bit_offset(0x1d), DW_AT_bit_size(0x01)
2207 .dwattr $C$DW$163, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
2208 .dwattr $C$DW$163, DW_AT_accessibility(DW_ACCESS_public)
2209 .dwattr $C$DW$163, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_ctrl.h")
2210 .dwattr $C$DW$163, DW_AT_decl_line(0x2f)
2211 .dwattr $C$DW$163, DW_AT_decl_column(0x0d)
2212$C$DW$164 .dwtag DW_TAG_member
2213 .dwattr $C$DW$164, DW_AT_type(*$C$DW$T$11)
2214 .dwattr $C$DW$164, DW_AT_name("CTR_EN")
2215 .dwattr $C$DW$164, DW_AT_TI_symbol_name("CTR_EN")
2216 .dwattr $C$DW$164, DW_AT_bit_offset(0x1c), DW_AT_bit_size(0x01)
2217 .dwattr $C$DW$164, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
2218 .dwattr $C$DW$164, DW_AT_accessibility(DW_ACCESS_public)
2219 .dwattr $C$DW$164, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_ctrl.h")
2220 .dwattr $C$DW$164, DW_AT_decl_line(0x30)
2221 .dwattr $C$DW$164, DW_AT_decl_column(0x0d)
2222$C$DW$165 .dwtag DW_TAG_member
2223 .dwattr $C$DW$165, DW_AT_type(*$C$DW$T$11)
2224 .dwattr $C$DW$165, DW_AT_name("rsvd4")
2225 .dwattr $C$DW$165, DW_AT_TI_symbol_name("rsvd4")
2226 .dwattr $C$DW$165, DW_AT_bit_offset(0x18), DW_AT_bit_size(0x04)
2227 .dwattr $C$DW$165, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
2228 .dwattr $C$DW$165, DW_AT_accessibility(DW_ACCESS_public)
2229 .dwattr $C$DW$165, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_ctrl.h")
2230 .dwattr $C$DW$165, DW_AT_decl_line(0x31)
2231 .dwattr $C$DW$165, DW_AT_decl_column(0x0d)
2232$C$DW$166 .dwtag DW_TAG_member
2233 .dwattr $C$DW$166, DW_AT_type(*$C$DW$T$11)
2234 .dwattr $C$DW$166, DW_AT_name("SINGLE_STEP")
2235 .dwattr $C$DW$166, DW_AT_TI_symbol_name("SINGLE_STEP")
2236 .dwattr $C$DW$166, DW_AT_bit_offset(0x17), DW_AT_bit_size(0x01)
2237 .dwattr $C$DW$166, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
2238 .dwattr $C$DW$166, DW_AT_accessibility(DW_ACCESS_public)
2239 .dwattr $C$DW$166, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_ctrl.h")
2240 .dwattr $C$DW$166, DW_AT_decl_line(0x32)
2241 .dwattr $C$DW$166, DW_AT_decl_column(0x0d)
2242$C$DW$167 .dwtag DW_TAG_member
2243 .dwattr $C$DW$167, DW_AT_type(*$C$DW$T$11)
2244 .dwattr $C$DW$167, DW_AT_name("rsvd9")
2245 .dwattr $C$DW$167, DW_AT_TI_symbol_name("rsvd9")
2246 .dwattr $C$DW$167, DW_AT_bit_offset(0x11), DW_AT_bit_size(0x06)
2247 .dwattr $C$DW$167, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
2248 .dwattr $C$DW$167, DW_AT_accessibility(DW_ACCESS_public)
2249 .dwattr $C$DW$167, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_ctrl.h")
2250 .dwattr $C$DW$167, DW_AT_decl_line(0x33)
2251 .dwattr $C$DW$167, DW_AT_decl_column(0x0d)
2252$C$DW$168 .dwtag DW_TAG_member
2253 .dwattr $C$DW$168, DW_AT_type(*$C$DW$T$11)
2254 .dwattr $C$DW$168, DW_AT_name("RUNSTATE")
2255 .dwattr $C$DW$168, DW_AT_TI_symbol_name("RUNSTATE")
2256 .dwattr $C$DW$168, DW_AT_bit_offset(0x10), DW_AT_bit_size(0x01)
2257 .dwattr $C$DW$168, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
2258 .dwattr $C$DW$168, DW_AT_accessibility(DW_ACCESS_public)
2259 .dwattr $C$DW$168, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_ctrl.h")
2260 .dwattr $C$DW$168, DW_AT_decl_line(0x34)
2261 .dwattr $C$DW$168, DW_AT_decl_column(0x0d)
2262$C$DW$169 .dwtag DW_TAG_member
2263 .dwattr $C$DW$169, DW_AT_type(*$C$DW$T$11)
2264 .dwattr $C$DW$169, DW_AT_name("PCTR_RST_VAL")
2265 .dwattr $C$DW$169, DW_AT_TI_symbol_name("PCTR_RST_VAL")
2266 .dwattr $C$DW$169, DW_AT_bit_offset(0x00), DW_AT_bit_size(0x10)
2267 .dwattr $C$DW$169, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
2268 .dwattr $C$DW$169, DW_AT_accessibility(DW_ACCESS_public)
2269 .dwattr $C$DW$169, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_ctrl.h")
2270 .dwattr $C$DW$169, DW_AT_decl_line(0x35)
2271 .dwattr $C$DW$169, DW_AT_decl_column(0x0d)
2272 .dwendtag $C$DW$T$37
2273
2274 .dwattr $C$DW$T$37, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_ctrl.h")
2275 .dwattr $C$DW$T$37, DW_AT_decl_line(0x2c)
2276 .dwattr $C$DW$T$37, DW_AT_decl_column(0x13)
2277$C$DW$T$75 .dwtag DW_TAG_volatile_type
2278 .dwattr $C$DW$T$75, DW_AT_type(*$C$DW$T$37)
2279
2280$C$DW$T$38 .dwtag DW_TAG_structure_type
2281 .dwattr $C$DW$T$38, DW_AT_byte_size(0x04)
2282$C$DW$170 .dwtag DW_TAG_member
2283 .dwattr $C$DW$170, DW_AT_type(*$C$DW$T$11)
2284 .dwattr $C$DW$170, DW_AT_name("PCTR")
2285 .dwattr $C$DW$170, DW_AT_TI_symbol_name("PCTR")
2286 .dwattr $C$DW$170, DW_AT_bit_offset(0x10), DW_AT_bit_size(0x10)
2287 .dwattr $C$DW$170, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
2288 .dwattr $C$DW$170, DW_AT_accessibility(DW_ACCESS_public)
2289 .dwattr $C$DW$170, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_ctrl.h")
2290 .dwattr $C$DW$170, DW_AT_decl_line(0x3f)
2291 .dwattr $C$DW$170, DW_AT_decl_column(0x0d)
2292$C$DW$171 .dwtag DW_TAG_member
2293 .dwattr $C$DW$171, DW_AT_type(*$C$DW$T$11)
2294 .dwattr $C$DW$171, DW_AT_name("rsvd16")
2295 .dwattr $C$DW$171, DW_AT_TI_symbol_name("rsvd16")
2296 .dwattr $C$DW$171, DW_AT_bit_offset(0x00), DW_AT_bit_size(0x10)
2297 .dwattr $C$DW$171, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
2298 .dwattr $C$DW$171, DW_AT_accessibility(DW_ACCESS_public)
2299 .dwattr $C$DW$171, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_ctrl.h")
2300 .dwattr $C$DW$171, DW_AT_decl_line(0x40)
2301 .dwattr $C$DW$171, DW_AT_decl_column(0x0d)
2302 .dwendtag $C$DW$T$38
2303
2304 .dwattr $C$DW$T$38, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_ctrl.h")
2305 .dwattr $C$DW$T$38, DW_AT_decl_line(0x3e)
2306 .dwattr $C$DW$T$38, DW_AT_decl_column(0x13)
2307$C$DW$T$77 .dwtag DW_TAG_volatile_type
2308 .dwattr $C$DW$T$77, DW_AT_type(*$C$DW$T$38)
2309
2310$C$DW$T$39 .dwtag DW_TAG_structure_type
2311 .dwattr $C$DW$T$39, DW_AT_byte_size(0x04)
2312$C$DW$172 .dwtag DW_TAG_member
2313 .dwattr $C$DW$172, DW_AT_type(*$C$DW$T$11)
2314 .dwattr $C$DW$172, DW_AT_name("BITWISE_ENS")
2315 .dwattr $C$DW$172, DW_AT_TI_symbol_name("BITWISE_ENS")
2316 .dwattr $C$DW$172, DW_AT_bit_offset(0x00), DW_AT_bit_size(0x20)
2317 .dwattr $C$DW$172, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
2318 .dwattr $C$DW$172, DW_AT_accessibility(DW_ACCESS_public)
2319 .dwattr $C$DW$172, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_ctrl.h")
2320 .dwattr $C$DW$172, DW_AT_decl_line(0x4a)
2321 .dwattr $C$DW$172, DW_AT_decl_column(0x0d)
2322 .dwendtag $C$DW$T$39
2323
2324 .dwattr $C$DW$T$39, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_ctrl.h")
2325 .dwattr $C$DW$T$39, DW_AT_decl_line(0x49)
2326 .dwattr $C$DW$T$39, DW_AT_decl_column(0x13)
2327$C$DW$T$79 .dwtag DW_TAG_volatile_type
2328 .dwattr $C$DW$T$79, DW_AT_type(*$C$DW$T$39)
2329
2330$C$DW$T$40 .dwtag DW_TAG_structure_type
2331 .dwattr $C$DW$T$40, DW_AT_byte_size(0x04)
2332$C$DW$173 .dwtag DW_TAG_member
2333 .dwattr $C$DW$173, DW_AT_type(*$C$DW$T$11)
2334 .dwattr $C$DW$173, DW_AT_name("CYCLECOUNT")
2335 .dwattr $C$DW$173, DW_AT_TI_symbol_name("CYCLECOUNT")
2336 .dwattr $C$DW$173, DW_AT_bit_offset(0x00), DW_AT_bit_size(0x20)
2337 .dwattr $C$DW$173, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
2338 .dwattr $C$DW$173, DW_AT_accessibility(DW_ACCESS_public)
2339 .dwattr $C$DW$173, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_ctrl.h")
2340 .dwattr $C$DW$173, DW_AT_decl_line(0x54)
2341 .dwattr $C$DW$173, DW_AT_decl_column(0x0d)
2342 .dwendtag $C$DW$T$40
2343
2344 .dwattr $C$DW$T$40, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_ctrl.h")
2345 .dwattr $C$DW$T$40, DW_AT_decl_line(0x53)
2346 .dwattr $C$DW$T$40, DW_AT_decl_column(0x13)
2347$C$DW$T$81 .dwtag DW_TAG_volatile_type
2348 .dwattr $C$DW$T$81, DW_AT_type(*$C$DW$T$40)
2349
2350$C$DW$T$41 .dwtag DW_TAG_structure_type
2351 .dwattr $C$DW$T$41, DW_AT_byte_size(0x04)
2352$C$DW$174 .dwtag DW_TAG_member
2353 .dwattr $C$DW$174, DW_AT_type(*$C$DW$T$11)
2354 .dwattr $C$DW$174, DW_AT_name("STALLCOUNT")
2355 .dwattr $C$DW$174, DW_AT_TI_symbol_name("STALLCOUNT")
2356 .dwattr $C$DW$174, DW_AT_bit_offset(0x00), DW_AT_bit_size(0x20)
2357 .dwattr $C$DW$174, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
2358 .dwattr $C$DW$174, DW_AT_accessibility(DW_ACCESS_public)
2359 .dwattr $C$DW$174, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_ctrl.h")
2360 .dwattr $C$DW$174, DW_AT_decl_line(0x5e)
2361 .dwattr $C$DW$174, DW_AT_decl_column(0x0d)
2362 .dwendtag $C$DW$T$41
2363
2364 .dwattr $C$DW$T$41, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_ctrl.h")
2365 .dwattr $C$DW$T$41, DW_AT_decl_line(0x5d)
2366 .dwattr $C$DW$T$41, DW_AT_decl_column(0x14)
2367$C$DW$T$83 .dwtag DW_TAG_volatile_type
2368 .dwattr $C$DW$T$83, DW_AT_type(*$C$DW$T$41)
2369
2370$C$DW$T$42 .dwtag DW_TAG_structure_type
2371 .dwattr $C$DW$T$42, DW_AT_byte_size(0x04)
2372$C$DW$175 .dwtag DW_TAG_member
2373 .dwattr $C$DW$175, DW_AT_type(*$C$DW$T$11)
2374 .dwattr $C$DW$175, DW_AT_name("C24_BLK_IDX")
2375 .dwattr $C$DW$175, DW_AT_TI_symbol_name("C24_BLK_IDX")
2376 .dwattr $C$DW$175, DW_AT_bit_offset(0x18), DW_AT_bit_size(0x08)
2377 .dwattr $C$DW$175, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
2378 .dwattr $C$DW$175, DW_AT_accessibility(DW_ACCESS_public)
2379 .dwattr $C$DW$175, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_ctrl.h")
2380 .dwattr $C$DW$175, DW_AT_decl_line(0x6b)
2381 .dwattr $C$DW$175, DW_AT_decl_column(0x0d)
2382$C$DW$176 .dwtag DW_TAG_member
2383 .dwattr $C$DW$176, DW_AT_type(*$C$DW$T$11)
2384 .dwattr $C$DW$176, DW_AT_name("rsvd8")
2385 .dwattr $C$DW$176, DW_AT_TI_symbol_name("rsvd8")
2386 .dwattr $C$DW$176, DW_AT_bit_offset(0x10), DW_AT_bit_size(0x08)
2387 .dwattr $C$DW$176, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
2388 .dwattr $C$DW$176, DW_AT_accessibility(DW_ACCESS_public)
2389 .dwattr $C$DW$176, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_ctrl.h")
2390 .dwattr $C$DW$176, DW_AT_decl_line(0x6c)
2391 .dwattr $C$DW$176, DW_AT_decl_column(0x0d)
2392$C$DW$177 .dwtag DW_TAG_member
2393 .dwattr $C$DW$177, DW_AT_type(*$C$DW$T$11)
2394 .dwattr $C$DW$177, DW_AT_name("C25_BLK_IDX")
2395 .dwattr $C$DW$177, DW_AT_TI_symbol_name("C25_BLK_IDX")
2396 .dwattr $C$DW$177, DW_AT_bit_offset(0x08), DW_AT_bit_size(0x08)
2397 .dwattr $C$DW$177, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
2398 .dwattr $C$DW$177, DW_AT_accessibility(DW_ACCESS_public)
2399 .dwattr $C$DW$177, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_ctrl.h")
2400 .dwattr $C$DW$177, DW_AT_decl_line(0x6d)
2401 .dwattr $C$DW$177, DW_AT_decl_column(0x0d)
2402$C$DW$178 .dwtag DW_TAG_member
2403 .dwattr $C$DW$178, DW_AT_type(*$C$DW$T$11)
2404 .dwattr $C$DW$178, DW_AT_name("rsvd24")
2405 .dwattr $C$DW$178, DW_AT_TI_symbol_name("rsvd24")
2406 .dwattr $C$DW$178, DW_AT_bit_offset(0x00), DW_AT_bit_size(0x08)
2407 .dwattr $C$DW$178, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
2408 .dwattr $C$DW$178, DW_AT_accessibility(DW_ACCESS_public)
2409 .dwattr $C$DW$178, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_ctrl.h")
2410 .dwattr $C$DW$178, DW_AT_decl_line(0x6e)
2411 .dwattr $C$DW$178, DW_AT_decl_column(0x0d)
2412 .dwendtag $C$DW$T$42
2413
2414 .dwattr $C$DW$T$42, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_ctrl.h")
2415 .dwattr $C$DW$T$42, DW_AT_decl_line(0x6a)
2416 .dwattr $C$DW$T$42, DW_AT_decl_column(0x13)
2417$C$DW$T$85 .dwtag DW_TAG_volatile_type
2418 .dwattr $C$DW$T$85, DW_AT_type(*$C$DW$T$42)
2419
2420$C$DW$T$43 .dwtag DW_TAG_structure_type
2421 .dwattr $C$DW$T$43, DW_AT_byte_size(0x04)
2422$C$DW$179 .dwtag DW_TAG_member
2423 .dwattr $C$DW$179, DW_AT_type(*$C$DW$T$11)
2424 .dwattr $C$DW$179, DW_AT_name("C26_BLK_IDX")
2425 .dwattr $C$DW$179, DW_AT_TI_symbol_name("C26_BLK_IDX")
2426 .dwattr $C$DW$179, DW_AT_bit_offset(0x18), DW_AT_bit_size(0x08)
2427 .dwattr $C$DW$179, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
2428 .dwattr $C$DW$179, DW_AT_accessibility(DW_ACCESS_public)
2429 .dwattr $C$DW$179, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_ctrl.h")
2430 .dwattr $C$DW$179, DW_AT_decl_line(0x78)
2431 .dwattr $C$DW$179, DW_AT_decl_column(0x0d)
2432$C$DW$180 .dwtag DW_TAG_member
2433 .dwattr $C$DW$180, DW_AT_type(*$C$DW$T$11)
2434 .dwattr $C$DW$180, DW_AT_name("rsvd8")
2435 .dwattr $C$DW$180, DW_AT_TI_symbol_name("rsvd8")
2436 .dwattr $C$DW$180, DW_AT_bit_offset(0x10), DW_AT_bit_size(0x08)
2437 .dwattr $C$DW$180, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
2438 .dwattr $C$DW$180, DW_AT_accessibility(DW_ACCESS_public)
2439 .dwattr $C$DW$180, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_ctrl.h")
2440 .dwattr $C$DW$180, DW_AT_decl_line(0x79)
2441 .dwattr $C$DW$180, DW_AT_decl_column(0x0d)
2442$C$DW$181 .dwtag DW_TAG_member
2443 .dwattr $C$DW$181, DW_AT_type(*$C$DW$T$11)
2444 .dwattr $C$DW$181, DW_AT_name("C27_BLK_IDX")
2445 .dwattr $C$DW$181, DW_AT_TI_symbol_name("C27_BLK_IDX")
2446 .dwattr $C$DW$181, DW_AT_bit_offset(0x08), DW_AT_bit_size(0x08)
2447 .dwattr $C$DW$181, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
2448 .dwattr $C$DW$181, DW_AT_accessibility(DW_ACCESS_public)
2449 .dwattr $C$DW$181, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_ctrl.h")
2450 .dwattr $C$DW$181, DW_AT_decl_line(0x7a)
2451 .dwattr $C$DW$181, DW_AT_decl_column(0x0d)
2452$C$DW$182 .dwtag DW_TAG_member
2453 .dwattr $C$DW$182, DW_AT_type(*$C$DW$T$11)
2454 .dwattr $C$DW$182, DW_AT_name("rsvd24")
2455 .dwattr $C$DW$182, DW_AT_TI_symbol_name("rsvd24")
2456 .dwattr $C$DW$182, DW_AT_bit_offset(0x00), DW_AT_bit_size(0x08)
2457 .dwattr $C$DW$182, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
2458 .dwattr $C$DW$182, DW_AT_accessibility(DW_ACCESS_public)
2459 .dwattr $C$DW$182, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_ctrl.h")
2460 .dwattr $C$DW$182, DW_AT_decl_line(0x7b)
2461 .dwattr $C$DW$182, DW_AT_decl_column(0x0d)
2462 .dwendtag $C$DW$T$43
2463
2464 .dwattr $C$DW$T$43, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_ctrl.h")
2465 .dwattr $C$DW$T$43, DW_AT_decl_line(0x77)
2466 .dwattr $C$DW$T$43, DW_AT_decl_column(0x13)
2467$C$DW$T$87 .dwtag DW_TAG_volatile_type
2468 .dwattr $C$DW$T$87, DW_AT_type(*$C$DW$T$43)
2469
2470$C$DW$T$44 .dwtag DW_TAG_structure_type
2471 .dwattr $C$DW$T$44, DW_AT_byte_size(0x04)
2472$C$DW$183 .dwtag DW_TAG_member
2473 .dwattr $C$DW$183, DW_AT_type(*$C$DW$T$11)
2474 .dwattr $C$DW$183, DW_AT_name("C28_BLK_POINTER")
2475 .dwattr $C$DW$183, DW_AT_TI_symbol_name("C28_BLK_POINTER")
2476 .dwattr $C$DW$183, DW_AT_bit_offset(0x10), DW_AT_bit_size(0x10)
2477 .dwattr $C$DW$183, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
2478 .dwattr $C$DW$183, DW_AT_accessibility(DW_ACCESS_public)
2479 .dwattr $C$DW$183, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_ctrl.h")
2480 .dwattr $C$DW$183, DW_AT_decl_line(0x85)
2481 .dwattr $C$DW$183, DW_AT_decl_column(0x0d)
2482$C$DW$184 .dwtag DW_TAG_member
2483 .dwattr $C$DW$184, DW_AT_type(*$C$DW$T$11)
2484 .dwattr $C$DW$184, DW_AT_name("C29_BLK_POINTER")
2485 .dwattr $C$DW$184, DW_AT_TI_symbol_name("C29_BLK_POINTER")
2486 .dwattr $C$DW$184, DW_AT_bit_offset(0x00), DW_AT_bit_size(0x10)
2487 .dwattr $C$DW$184, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
2488 .dwattr $C$DW$184, DW_AT_accessibility(DW_ACCESS_public)
2489 .dwattr $C$DW$184, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_ctrl.h")
2490 .dwattr $C$DW$184, DW_AT_decl_line(0x86)
2491 .dwattr $C$DW$184, DW_AT_decl_column(0x0d)
2492 .dwendtag $C$DW$T$44
2493
2494 .dwattr $C$DW$T$44, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_ctrl.h")
2495 .dwattr $C$DW$T$44, DW_AT_decl_line(0x84)
2496 .dwattr $C$DW$T$44, DW_AT_decl_column(0x13)
2497$C$DW$T$89 .dwtag DW_TAG_volatile_type
2498 .dwattr $C$DW$T$89, DW_AT_type(*$C$DW$T$44)
2499
2500$C$DW$T$45 .dwtag DW_TAG_structure_type
2501 .dwattr $C$DW$T$45, DW_AT_byte_size(0x04)
2502$C$DW$185 .dwtag DW_TAG_member
2503 .dwattr $C$DW$185, DW_AT_type(*$C$DW$T$11)
2504 .dwattr $C$DW$185, DW_AT_name("C30_BLK_POINTER")
2505 .dwattr $C$DW$185, DW_AT_TI_symbol_name("C30_BLK_POINTER")
2506 .dwattr $C$DW$185, DW_AT_bit_offset(0x10), DW_AT_bit_size(0x10)
2507 .dwattr $C$DW$185, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
2508 .dwattr $C$DW$185, DW_AT_accessibility(DW_ACCESS_public)
2509 .dwattr $C$DW$185, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_ctrl.h")
2510 .dwattr $C$DW$185, DW_AT_decl_line(0x90)
2511 .dwattr $C$DW$185, DW_AT_decl_column(0x0d)
2512$C$DW$186 .dwtag DW_TAG_member
2513 .dwattr $C$DW$186, DW_AT_type(*$C$DW$T$11)
2514 .dwattr $C$DW$186, DW_AT_name("C31_BLK_POINTER")
2515 .dwattr $C$DW$186, DW_AT_TI_symbol_name("C31_BLK_POINTER")
2516 .dwattr $C$DW$186, DW_AT_bit_offset(0x00), DW_AT_bit_size(0x10)
2517 .dwattr $C$DW$186, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
2518 .dwattr $C$DW$186, DW_AT_accessibility(DW_ACCESS_public)
2519 .dwattr $C$DW$186, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_ctrl.h")
2520 .dwattr $C$DW$186, DW_AT_decl_line(0x91)
2521 .dwattr $C$DW$186, DW_AT_decl_column(0x0d)
2522 .dwendtag $C$DW$T$45
2523
2524 .dwattr $C$DW$T$45, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_ctrl.h")
2525 .dwattr $C$DW$T$45, DW_AT_decl_line(0x8f)
2526 .dwattr $C$DW$T$45, DW_AT_decl_column(0x13)
2527$C$DW$T$91 .dwtag DW_TAG_volatile_type
2528 .dwattr $C$DW$T$91, DW_AT_type(*$C$DW$T$45)
2529
2530$C$DW$T$47 .dwtag DW_TAG_structure_type
2531 .dwattr $C$DW$T$47, DW_AT_byte_size(0x30)
2532$C$DW$187 .dwtag DW_TAG_member
2533 .dwattr $C$DW$187, DW_AT_type(*$C$DW$T$76)
2534 .dwattr $C$DW$187, DW_AT_name("$P$T13")
2535 .dwattr $C$DW$187, DW_AT_TI_symbol_name("$P$T13")
2536 .dwattr $C$DW$187, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
2537 .dwattr $C$DW$187, DW_AT_accessibility(DW_ACCESS_public)
2538 .dwattr $C$DW$187, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_ctrl.h")
2539 .dwattr $C$DW$187, DW_AT_decl_line(0x29)
2540 .dwattr $C$DW$187, DW_AT_decl_column(0x02)
2541$C$DW$188 .dwtag DW_TAG_member
2542 .dwattr $C$DW$188, DW_AT_type(*$C$DW$T$78)
2543 .dwattr $C$DW$188, DW_AT_name("$P$T14")
2544 .dwattr $C$DW$188, DW_AT_TI_symbol_name("$P$T14")
2545 .dwattr $C$DW$188, DW_AT_data_member_location[DW_OP_plus_uconst 0x4]
2546 .dwattr $C$DW$188, DW_AT_accessibility(DW_ACCESS_public)
2547 .dwattr $C$DW$188, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_ctrl.h")
2548 .dwattr $C$DW$188, DW_AT_decl_line(0x3b)
2549 .dwattr $C$DW$188, DW_AT_decl_column(0x02)
2550$C$DW$189 .dwtag DW_TAG_member
2551 .dwattr $C$DW$189, DW_AT_type(*$C$DW$T$80)
2552 .dwattr $C$DW$189, DW_AT_name("$P$T15")
2553 .dwattr $C$DW$189, DW_AT_TI_symbol_name("$P$T15")
2554 .dwattr $C$DW$189, DW_AT_data_member_location[DW_OP_plus_uconst 0x8]
2555 .dwattr $C$DW$189, DW_AT_accessibility(DW_ACCESS_public)
2556 .dwattr $C$DW$189, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_ctrl.h")
2557 .dwattr $C$DW$189, DW_AT_decl_line(0x46)
2558 .dwattr $C$DW$189, DW_AT_decl_column(0x02)
2559$C$DW$190 .dwtag DW_TAG_member
2560 .dwattr $C$DW$190, DW_AT_type(*$C$DW$T$82)
2561 .dwattr $C$DW$190, DW_AT_name("$P$T16")
2562 .dwattr $C$DW$190, DW_AT_TI_symbol_name("$P$T16")
2563 .dwattr $C$DW$190, DW_AT_data_member_location[DW_OP_plus_uconst 0xc]
2564 .dwattr $C$DW$190, DW_AT_accessibility(DW_ACCESS_public)
2565 .dwattr $C$DW$190, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_ctrl.h")
2566 .dwattr $C$DW$190, DW_AT_decl_line(0x50)
2567 .dwattr $C$DW$190, DW_AT_decl_column(0x02)
2568$C$DW$191 .dwtag DW_TAG_member
2569 .dwattr $C$DW$191, DW_AT_type(*$C$DW$T$84)
2570 .dwattr $C$DW$191, DW_AT_name("$P$T17")
2571 .dwattr $C$DW$191, DW_AT_TI_symbol_name("$P$T17")
2572 .dwattr $C$DW$191, DW_AT_data_member_location[DW_OP_plus_uconst 0x10]
2573 .dwattr $C$DW$191, DW_AT_accessibility(DW_ACCESS_public)
2574 .dwattr $C$DW$191, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_ctrl.h")
2575 .dwattr $C$DW$191, DW_AT_decl_line(0x5a)
2576 .dwattr $C$DW$191, DW_AT_decl_column(0x02)
2577$C$DW$192 .dwtag DW_TAG_member
2578 .dwattr $C$DW$192, DW_AT_type(*$C$DW$T$46)
2579 .dwattr $C$DW$192, DW_AT_name("rsvd14")
2580 .dwattr $C$DW$192, DW_AT_TI_symbol_name("rsvd14")
2581 .dwattr $C$DW$192, DW_AT_data_member_location[DW_OP_plus_uconst 0x14]
2582 .dwattr $C$DW$192, DW_AT_accessibility(DW_ACCESS_public)
2583 .dwattr $C$DW$192, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_ctrl.h")
2584 .dwattr $C$DW$192, DW_AT_decl_line(0x63)
2585 .dwattr $C$DW$192, DW_AT_decl_column(0x0b)
2586$C$DW$193 .dwtag DW_TAG_member
2587 .dwattr $C$DW$193, DW_AT_type(*$C$DW$T$86)
2588 .dwattr $C$DW$193, DW_AT_name("$P$T18")
2589 .dwattr $C$DW$193, DW_AT_TI_symbol_name("$P$T18")
2590 .dwattr $C$DW$193, DW_AT_data_member_location[DW_OP_plus_uconst 0x20]
2591 .dwattr $C$DW$193, DW_AT_accessibility(DW_ACCESS_public)
2592 .dwattr $C$DW$193, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_ctrl.h")
2593 .dwattr $C$DW$193, DW_AT_decl_line(0x67)
2594 .dwattr $C$DW$193, DW_AT_decl_column(0x02)
2595$C$DW$194 .dwtag DW_TAG_member
2596 .dwattr $C$DW$194, DW_AT_type(*$C$DW$T$88)
2597 .dwattr $C$DW$194, DW_AT_name("$P$T19")
2598 .dwattr $C$DW$194, DW_AT_TI_symbol_name("$P$T19")
2599 .dwattr $C$DW$194, DW_AT_data_member_location[DW_OP_plus_uconst 0x24]
2600 .dwattr $C$DW$194, DW_AT_accessibility(DW_ACCESS_public)
2601 .dwattr $C$DW$194, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_ctrl.h")
2602 .dwattr $C$DW$194, DW_AT_decl_line(0x74)
2603 .dwattr $C$DW$194, DW_AT_decl_column(0x02)
2604$C$DW$195 .dwtag DW_TAG_member
2605 .dwattr $C$DW$195, DW_AT_type(*$C$DW$T$90)
2606 .dwattr $C$DW$195, DW_AT_name("$P$T20")
2607 .dwattr $C$DW$195, DW_AT_TI_symbol_name("$P$T20")
2608 .dwattr $C$DW$195, DW_AT_data_member_location[DW_OP_plus_uconst 0x28]
2609 .dwattr $C$DW$195, DW_AT_accessibility(DW_ACCESS_public)
2610 .dwattr $C$DW$195, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_ctrl.h")
2611 .dwattr $C$DW$195, DW_AT_decl_line(0x81)
2612 .dwattr $C$DW$195, DW_AT_decl_column(0x02)
2613$C$DW$196 .dwtag DW_TAG_member
2614 .dwattr $C$DW$196, DW_AT_type(*$C$DW$T$92)
2615 .dwattr $C$DW$196, DW_AT_name("$P$T21")
2616 .dwattr $C$DW$196, DW_AT_TI_symbol_name("$P$T21")
2617 .dwattr $C$DW$196, DW_AT_data_member_location[DW_OP_plus_uconst 0x2c]
2618 .dwattr $C$DW$196, DW_AT_accessibility(DW_ACCESS_public)
2619 .dwattr $C$DW$196, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_ctrl.h")
2620 .dwattr $C$DW$196, DW_AT_decl_line(0x8c)
2621 .dwattr $C$DW$196, DW_AT_decl_column(0x02)
2622 .dwendtag $C$DW$T$47
2623
2624 .dwattr $C$DW$T$47, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_ctrl.h")
2625 .dwattr $C$DW$T$47, DW_AT_decl_line(0x26)
2626 .dwattr $C$DW$T$47, DW_AT_decl_column(0x10)
2627$C$DW$T$103 .dwtag DW_TAG_typedef, DW_AT_name("pruCtrl")
2628 .dwattr $C$DW$T$103, DW_AT_type(*$C$DW$T$47)
2629 .dwattr $C$DW$T$103, DW_AT_language(DW_LANG_C)
2630 .dwattr $C$DW$T$103, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_ctrl.h")
2631 .dwattr $C$DW$T$103, DW_AT_decl_line(0x95)
2632 .dwattr $C$DW$T$103, DW_AT_decl_column(0x03)
2633
2634$C$DW$T$50 .dwtag DW_TAG_union_type
2635 .dwattr $C$DW$T$50, DW_AT_byte_size(0x04)
2636$C$DW$197 .dwtag DW_TAG_member
2637 .dwattr $C$DW$197, DW_AT_type(*$C$DW$T$48)
2638 .dwattr $C$DW$197, DW_AT_name("REVID")
2639 .dwattr $C$DW$197, DW_AT_TI_symbol_name("REVID")
2640 .dwattr $C$DW$197, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
2641 .dwattr $C$DW$197, DW_AT_accessibility(DW_ACCESS_public)
2642 .dwattr $C$DW$197, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
2643 .dwattr $C$DW$197, DW_AT_decl_line(0x2a)
2644 .dwattr $C$DW$197, DW_AT_decl_column(0x15)
2645$C$DW$198 .dwtag DW_TAG_member
2646 .dwattr $C$DW$198, DW_AT_type(*$C$DW$T$49)
2647 .dwattr $C$DW$198, DW_AT_name("REVID_bit")
2648 .dwattr $C$DW$198, DW_AT_TI_symbol_name("REVID_bit")
2649 .dwattr $C$DW$198, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
2650 .dwattr $C$DW$198, DW_AT_accessibility(DW_ACCESS_public)
2651 .dwattr $C$DW$198, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
2652 .dwattr $C$DW$198, DW_AT_decl_line(0x2e)
2653 .dwattr $C$DW$198, DW_AT_decl_column(0x05)
2654 .dwendtag $C$DW$T$50
2655
2656 .dwattr $C$DW$T$50, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
2657 .dwattr $C$DW$T$50, DW_AT_decl_line(0x29)
2658 .dwattr $C$DW$T$50, DW_AT_decl_column(0x08)
2659
2660$C$DW$T$52 .dwtag DW_TAG_union_type
2661 .dwattr $C$DW$T$52, DW_AT_byte_size(0x04)
2662$C$DW$199 .dwtag DW_TAG_member
2663 .dwattr $C$DW$199, DW_AT_type(*$C$DW$T$48)
2664 .dwattr $C$DW$199, DW_AT_name("SYSCFG")
2665 .dwattr $C$DW$199, DW_AT_TI_symbol_name("SYSCFG")
2666 .dwattr $C$DW$199, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
2667 .dwattr $C$DW$199, DW_AT_accessibility(DW_ACCESS_public)
2668 .dwattr $C$DW$199, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
2669 .dwattr $C$DW$199, DW_AT_decl_line(0x34)
2670 .dwattr $C$DW$199, DW_AT_decl_column(0x15)
2671$C$DW$200 .dwtag DW_TAG_member
2672 .dwattr $C$DW$200, DW_AT_type(*$C$DW$T$51)
2673 .dwattr $C$DW$200, DW_AT_name("SYSCFG_bit")
2674 .dwattr $C$DW$200, DW_AT_TI_symbol_name("SYSCFG_bit")
2675 .dwattr $C$DW$200, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
2676 .dwattr $C$DW$200, DW_AT_accessibility(DW_ACCESS_public)
2677 .dwattr $C$DW$200, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
2678 .dwattr $C$DW$200, DW_AT_decl_line(0x3c)
2679 .dwattr $C$DW$200, DW_AT_decl_column(0x05)
2680 .dwendtag $C$DW$T$52
2681
2682 .dwattr $C$DW$T$52, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
2683 .dwattr $C$DW$T$52, DW_AT_decl_line(0x33)
2684 .dwattr $C$DW$T$52, DW_AT_decl_column(0x08)
2685
2686$C$DW$T$54 .dwtag DW_TAG_union_type
2687 .dwattr $C$DW$T$54, DW_AT_byte_size(0x04)
2688$C$DW$201 .dwtag DW_TAG_member
2689 .dwattr $C$DW$201, DW_AT_type(*$C$DW$T$48)
2690 .dwattr $C$DW$201, DW_AT_name("GPCFG0")
2691 .dwattr $C$DW$201, DW_AT_TI_symbol_name("GPCFG0")
2692 .dwattr $C$DW$201, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
2693 .dwattr $C$DW$201, DW_AT_accessibility(DW_ACCESS_public)
2694 .dwattr $C$DW$201, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
2695 .dwattr $C$DW$201, DW_AT_decl_line(0x42)
2696 .dwattr $C$DW$201, DW_AT_decl_column(0x15)
2697$C$DW$202 .dwtag DW_TAG_member
2698 .dwattr $C$DW$202, DW_AT_type(*$C$DW$T$53)
2699 .dwattr $C$DW$202, DW_AT_name("GPCFG0_bit")
2700 .dwattr $C$DW$202, DW_AT_TI_symbol_name("GPCFG0_bit")
2701 .dwattr $C$DW$202, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
2702 .dwattr $C$DW$202, DW_AT_accessibility(DW_ACCESS_public)
2703 .dwattr $C$DW$202, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
2704 .dwattr $C$DW$202, DW_AT_decl_line(0x4f)
2705 .dwattr $C$DW$202, DW_AT_decl_column(0x05)
2706 .dwendtag $C$DW$T$54
2707
2708 .dwattr $C$DW$T$54, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
2709 .dwattr $C$DW$T$54, DW_AT_decl_line(0x41)
2710 .dwattr $C$DW$T$54, DW_AT_decl_column(0x08)
2711
2712$C$DW$T$56 .dwtag DW_TAG_union_type
2713 .dwattr $C$DW$T$56, DW_AT_byte_size(0x04)
2714$C$DW$203 .dwtag DW_TAG_member
2715 .dwattr $C$DW$203, DW_AT_type(*$C$DW$T$48)
2716 .dwattr $C$DW$203, DW_AT_name("GPCFG1")
2717 .dwattr $C$DW$203, DW_AT_TI_symbol_name("GPCFG1")
2718 .dwattr $C$DW$203, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
2719 .dwattr $C$DW$203, DW_AT_accessibility(DW_ACCESS_public)
2720 .dwattr $C$DW$203, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
2721 .dwattr $C$DW$203, DW_AT_decl_line(0x55)
2722 .dwattr $C$DW$203, DW_AT_decl_column(0x15)
2723$C$DW$204 .dwtag DW_TAG_member
2724 .dwattr $C$DW$204, DW_AT_type(*$C$DW$T$55)
2725 .dwattr $C$DW$204, DW_AT_name("GPCFG1_bit")
2726 .dwattr $C$DW$204, DW_AT_TI_symbol_name("GPCFG1_bit")
2727 .dwattr $C$DW$204, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
2728 .dwattr $C$DW$204, DW_AT_accessibility(DW_ACCESS_public)
2729 .dwattr $C$DW$204, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
2730 .dwattr $C$DW$204, DW_AT_decl_line(0x62)
2731 .dwattr $C$DW$204, DW_AT_decl_column(0x05)
2732 .dwendtag $C$DW$T$56
2733
2734 .dwattr $C$DW$T$56, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
2735 .dwattr $C$DW$T$56, DW_AT_decl_line(0x54)
2736 .dwattr $C$DW$T$56, DW_AT_decl_column(0x08)
2737
2738$C$DW$T$58 .dwtag DW_TAG_union_type
2739 .dwattr $C$DW$T$58, DW_AT_byte_size(0x04)
2740$C$DW$205 .dwtag DW_TAG_member
2741 .dwattr $C$DW$205, DW_AT_type(*$C$DW$T$48)
2742 .dwattr $C$DW$205, DW_AT_name("CGR")
2743 .dwattr $C$DW$205, DW_AT_TI_symbol_name("CGR")
2744 .dwattr $C$DW$205, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
2745 .dwattr $C$DW$205, DW_AT_accessibility(DW_ACCESS_public)
2746 .dwattr $C$DW$205, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
2747 .dwattr $C$DW$205, DW_AT_decl_line(0x68)
2748 .dwattr $C$DW$205, DW_AT_decl_column(0x15)
2749$C$DW$206 .dwtag DW_TAG_member
2750 .dwattr $C$DW$206, DW_AT_type(*$C$DW$T$57)
2751 .dwattr $C$DW$206, DW_AT_name("CGR_bit")
2752 .dwattr $C$DW$206, DW_AT_TI_symbol_name("CGR_bit")
2753 .dwattr $C$DW$206, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
2754 .dwattr $C$DW$206, DW_AT_accessibility(DW_ACCESS_public)
2755 .dwattr $C$DW$206, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
2756 .dwattr $C$DW$206, DW_AT_decl_line(0x7e)
2757 .dwattr $C$DW$206, DW_AT_decl_column(0x05)
2758 .dwendtag $C$DW$T$58
2759
2760 .dwattr $C$DW$T$58, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
2761 .dwattr $C$DW$T$58, DW_AT_decl_line(0x67)
2762 .dwattr $C$DW$T$58, DW_AT_decl_column(0x08)
2763
2764$C$DW$T$60 .dwtag DW_TAG_union_type
2765 .dwattr $C$DW$T$60, DW_AT_byte_size(0x04)
2766$C$DW$207 .dwtag DW_TAG_member
2767 .dwattr $C$DW$207, DW_AT_type(*$C$DW$T$48)
2768 .dwattr $C$DW$207, DW_AT_name("ISRP")
2769 .dwattr $C$DW$207, DW_AT_TI_symbol_name("ISRP")
2770 .dwattr $C$DW$207, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
2771 .dwattr $C$DW$207, DW_AT_accessibility(DW_ACCESS_public)
2772 .dwattr $C$DW$207, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
2773 .dwattr $C$DW$207, DW_AT_decl_line(0x84)
2774 .dwattr $C$DW$207, DW_AT_decl_column(0x15)
2775$C$DW$208 .dwtag DW_TAG_member
2776 .dwattr $C$DW$208, DW_AT_type(*$C$DW$T$59)
2777 .dwattr $C$DW$208, DW_AT_name("ISRP_bit")
2778 .dwattr $C$DW$208, DW_AT_TI_symbol_name("ISRP_bit")
2779 .dwattr $C$DW$208, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
2780 .dwattr $C$DW$208, DW_AT_accessibility(DW_ACCESS_public)
2781 .dwattr $C$DW$208, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
2782 .dwattr $C$DW$208, DW_AT_decl_line(0x8d)
2783 .dwattr $C$DW$208, DW_AT_decl_column(0x05)
2784 .dwendtag $C$DW$T$60
2785
2786 .dwattr $C$DW$T$60, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
2787 .dwattr $C$DW$T$60, DW_AT_decl_line(0x83)
2788 .dwattr $C$DW$T$60, DW_AT_decl_column(0x08)
2789
2790$C$DW$T$62 .dwtag DW_TAG_union_type
2791 .dwattr $C$DW$T$62, DW_AT_byte_size(0x04)
2792$C$DW$209 .dwtag DW_TAG_member
2793 .dwattr $C$DW$209, DW_AT_type(*$C$DW$T$48)
2794 .dwattr $C$DW$209, DW_AT_name("ISP")
2795 .dwattr $C$DW$209, DW_AT_TI_symbol_name("ISP")
2796 .dwattr $C$DW$209, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
2797 .dwattr $C$DW$209, DW_AT_accessibility(DW_ACCESS_public)
2798 .dwattr $C$DW$209, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
2799 .dwattr $C$DW$209, DW_AT_decl_line(0x93)
2800 .dwattr $C$DW$209, DW_AT_decl_column(0x15)
2801$C$DW$210 .dwtag DW_TAG_member
2802 .dwattr $C$DW$210, DW_AT_type(*$C$DW$T$61)
2803 .dwattr $C$DW$210, DW_AT_name("ISP_bit")
2804 .dwattr $C$DW$210, DW_AT_TI_symbol_name("ISP_bit")
2805 .dwattr $C$DW$210, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
2806 .dwattr $C$DW$210, DW_AT_accessibility(DW_ACCESS_public)
2807 .dwattr $C$DW$210, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
2808 .dwattr $C$DW$210, DW_AT_decl_line(0x9c)
2809 .dwattr $C$DW$210, DW_AT_decl_column(0x05)
2810 .dwendtag $C$DW$T$62
2811
2812 .dwattr $C$DW$T$62, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
2813 .dwattr $C$DW$T$62, DW_AT_decl_line(0x92)
2814 .dwattr $C$DW$T$62, DW_AT_decl_column(0x08)
2815
2816$C$DW$T$64 .dwtag DW_TAG_union_type
2817 .dwattr $C$DW$T$64, DW_AT_byte_size(0x04)
2818$C$DW$211 .dwtag DW_TAG_member
2819 .dwattr $C$DW$211, DW_AT_type(*$C$DW$T$48)
2820 .dwattr $C$DW$211, DW_AT_name("IESP")
2821 .dwattr $C$DW$211, DW_AT_TI_symbol_name("IESP")
2822 .dwattr $C$DW$211, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
2823 .dwattr $C$DW$211, DW_AT_accessibility(DW_ACCESS_public)
2824 .dwattr $C$DW$211, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
2825 .dwattr $C$DW$211, DW_AT_decl_line(0xa1)
2826 .dwattr $C$DW$211, DW_AT_decl_column(0x15)
2827$C$DW$212 .dwtag DW_TAG_member
2828 .dwattr $C$DW$212, DW_AT_type(*$C$DW$T$63)
2829 .dwattr $C$DW$212, DW_AT_name("IESP_bit")
2830 .dwattr $C$DW$212, DW_AT_TI_symbol_name("IESP_bit")
2831 .dwattr $C$DW$212, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
2832 .dwattr $C$DW$212, DW_AT_accessibility(DW_ACCESS_public)
2833 .dwattr $C$DW$212, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
2834 .dwattr $C$DW$212, DW_AT_decl_line(0xaa)
2835 .dwattr $C$DW$212, DW_AT_decl_column(0x05)
2836 .dwendtag $C$DW$T$64
2837
2838 .dwattr $C$DW$T$64, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
2839 .dwattr $C$DW$T$64, DW_AT_decl_line(0xa0)
2840 .dwattr $C$DW$T$64, DW_AT_decl_column(0x08)
2841
2842$C$DW$T$66 .dwtag DW_TAG_union_type
2843 .dwattr $C$DW$T$66, DW_AT_byte_size(0x04)
2844$C$DW$213 .dwtag DW_TAG_member
2845 .dwattr $C$DW$213, DW_AT_type(*$C$DW$T$48)
2846 .dwattr $C$DW$213, DW_AT_name("IECP")
2847 .dwattr $C$DW$213, DW_AT_TI_symbol_name("IECP")
2848 .dwattr $C$DW$213, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
2849 .dwattr $C$DW$213, DW_AT_accessibility(DW_ACCESS_public)
2850 .dwattr $C$DW$213, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
2851 .dwattr $C$DW$213, DW_AT_decl_line(0xb0)
2852 .dwattr $C$DW$213, DW_AT_decl_column(0x15)
2853$C$DW$214 .dwtag DW_TAG_member
2854 .dwattr $C$DW$214, DW_AT_type(*$C$DW$T$65)
2855 .dwattr $C$DW$214, DW_AT_name("IECP_bit")
2856 .dwattr $C$DW$214, DW_AT_TI_symbol_name("IECP_bit")
2857 .dwattr $C$DW$214, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
2858 .dwattr $C$DW$214, DW_AT_accessibility(DW_ACCESS_public)
2859 .dwattr $C$DW$214, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
2860 .dwattr $C$DW$214, DW_AT_decl_line(0xb8)
2861 .dwattr $C$DW$214, DW_AT_decl_column(0x05)
2862 .dwendtag $C$DW$T$66
2863
2864 .dwattr $C$DW$T$66, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
2865 .dwattr $C$DW$T$66, DW_AT_decl_line(0xaf)
2866 .dwattr $C$DW$T$66, DW_AT_decl_column(0x08)
2867
2868$C$DW$T$68 .dwtag DW_TAG_union_type
2869 .dwattr $C$DW$T$68, DW_AT_byte_size(0x04)
2870$C$DW$215 .dwtag DW_TAG_member
2871 .dwattr $C$DW$215, DW_AT_type(*$C$DW$T$48)
2872 .dwattr $C$DW$215, DW_AT_name("PMAO")
2873 .dwattr $C$DW$215, DW_AT_TI_symbol_name("PMAO")
2874 .dwattr $C$DW$215, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
2875 .dwattr $C$DW$215, DW_AT_accessibility(DW_ACCESS_public)
2876 .dwattr $C$DW$215, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
2877 .dwattr $C$DW$215, DW_AT_decl_line(0xc1)
2878 .dwattr $C$DW$215, DW_AT_decl_column(0x15)
2879$C$DW$216 .dwtag DW_TAG_member
2880 .dwattr $C$DW$216, DW_AT_type(*$C$DW$T$67)
2881 .dwattr $C$DW$216, DW_AT_name("PMAO_bit")
2882 .dwattr $C$DW$216, DW_AT_TI_symbol_name("PMAO_bit")
2883 .dwattr $C$DW$216, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
2884 .dwattr $C$DW$216, DW_AT_accessibility(DW_ACCESS_public)
2885 .dwattr $C$DW$216, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
2886 .dwattr $C$DW$216, DW_AT_decl_line(0xc7)
2887 .dwattr $C$DW$216, DW_AT_decl_column(0x05)
2888 .dwendtag $C$DW$T$68
2889
2890 .dwattr $C$DW$T$68, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
2891 .dwattr $C$DW$T$68, DW_AT_decl_line(0xc0)
2892 .dwattr $C$DW$T$68, DW_AT_decl_column(0x08)
2893
2894$C$DW$T$70 .dwtag DW_TAG_union_type
2895 .dwattr $C$DW$T$70, DW_AT_byte_size(0x04)
2896$C$DW$217 .dwtag DW_TAG_member
2897 .dwattr $C$DW$217, DW_AT_type(*$C$DW$T$48)
2898 .dwattr $C$DW$217, DW_AT_name("IEPCLK")
2899 .dwattr $C$DW$217, DW_AT_TI_symbol_name("IEPCLK")
2900 .dwattr $C$DW$217, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
2901 .dwattr $C$DW$217, DW_AT_accessibility(DW_ACCESS_public)
2902 .dwattr $C$DW$217, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
2903 .dwattr $C$DW$217, DW_AT_decl_line(0xd0)
2904 .dwattr $C$DW$217, DW_AT_decl_column(0x15)
2905$C$DW$218 .dwtag DW_TAG_member
2906 .dwattr $C$DW$218, DW_AT_type(*$C$DW$T$69)
2907 .dwattr $C$DW$218, DW_AT_name("IEPCLK_bit")
2908 .dwattr $C$DW$218, DW_AT_TI_symbol_name("IEPCLK_bit")
2909 .dwattr $C$DW$218, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
2910 .dwattr $C$DW$218, DW_AT_accessibility(DW_ACCESS_public)
2911 .dwattr $C$DW$218, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
2912 .dwattr $C$DW$218, DW_AT_decl_line(0xd5)
2913 .dwattr $C$DW$218, DW_AT_decl_column(0x05)
2914 .dwendtag $C$DW$T$70
2915
2916 .dwattr $C$DW$T$70, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
2917 .dwattr $C$DW$T$70, DW_AT_decl_line(0xcf)
2918 .dwattr $C$DW$T$70, DW_AT_decl_column(0x08)
2919
2920$C$DW$T$72 .dwtag DW_TAG_union_type
2921 .dwattr $C$DW$T$72, DW_AT_byte_size(0x04)
2922$C$DW$219 .dwtag DW_TAG_member
2923 .dwattr $C$DW$219, DW_AT_type(*$C$DW$T$48)
2924 .dwattr $C$DW$219, DW_AT_name("SPP")
2925 .dwattr $C$DW$219, DW_AT_TI_symbol_name("SPP")
2926 .dwattr $C$DW$219, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
2927 .dwattr $C$DW$219, DW_AT_accessibility(DW_ACCESS_public)
2928 .dwattr $C$DW$219, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
2929 .dwattr $C$DW$219, DW_AT_decl_line(0xdb)
2930 .dwattr $C$DW$219, DW_AT_decl_column(0x15)
2931$C$DW$220 .dwtag DW_TAG_member
2932 .dwattr $C$DW$220, DW_AT_type(*$C$DW$T$71)
2933 .dwattr $C$DW$220, DW_AT_name("SPP_bit")
2934 .dwattr $C$DW$220, DW_AT_TI_symbol_name("SPP_bit")
2935 .dwattr $C$DW$220, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
2936 .dwattr $C$DW$220, DW_AT_accessibility(DW_ACCESS_public)
2937 .dwattr $C$DW$220, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
2938 .dwattr $C$DW$220, DW_AT_decl_line(0xe1)
2939 .dwattr $C$DW$220, DW_AT_decl_column(0x05)
2940 .dwendtag $C$DW$T$72
2941
2942 .dwattr $C$DW$T$72, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
2943 .dwattr $C$DW$T$72, DW_AT_decl_line(0xda)
2944 .dwattr $C$DW$T$72, DW_AT_decl_column(0x08)
2945
2946$C$DW$T$74 .dwtag DW_TAG_union_type
2947 .dwattr $C$DW$T$74, DW_AT_byte_size(0x04)
2948$C$DW$221 .dwtag DW_TAG_member
2949 .dwattr $C$DW$221, DW_AT_type(*$C$DW$T$48)
2950 .dwattr $C$DW$221, DW_AT_name("PIN_MX")
2951 .dwattr $C$DW$221, DW_AT_TI_symbol_name("PIN_MX")
2952 .dwattr $C$DW$221, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
2953 .dwattr $C$DW$221, DW_AT_accessibility(DW_ACCESS_public)
2954 .dwattr $C$DW$221, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
2955 .dwattr $C$DW$221, DW_AT_decl_line(0xe9)
2956 .dwattr $C$DW$221, DW_AT_decl_column(0x15)
2957$C$DW$222 .dwtag DW_TAG_member
2958 .dwattr $C$DW$222, DW_AT_type(*$C$DW$T$73)
2959 .dwattr $C$DW$222, DW_AT_name("PIN_MX_bit")
2960 .dwattr $C$DW$222, DW_AT_TI_symbol_name("PIN_MX_bit")
2961 .dwattr $C$DW$222, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
2962 .dwattr $C$DW$222, DW_AT_accessibility(DW_ACCESS_public)
2963 .dwattr $C$DW$222, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
2964 .dwattr $C$DW$222, DW_AT_decl_line(0xee)
2965 .dwattr $C$DW$222, DW_AT_decl_column(0x05)
2966 .dwendtag $C$DW$T$74
2967
2968 .dwattr $C$DW$T$74, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h")
2969 .dwattr $C$DW$T$74, DW_AT_decl_line(0xe8)
2970 .dwattr $C$DW$T$74, DW_AT_decl_column(0x08)
2971
2972$C$DW$T$76 .dwtag DW_TAG_union_type
2973 .dwattr $C$DW$T$76, DW_AT_byte_size(0x04)
2974$C$DW$223 .dwtag DW_TAG_member
2975 .dwattr $C$DW$223, DW_AT_type(*$C$DW$T$48)
2976 .dwattr $C$DW$223, DW_AT_name("CTRL")
2977 .dwattr $C$DW$223, DW_AT_TI_symbol_name("CTRL")
2978 .dwattr $C$DW$223, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
2979 .dwattr $C$DW$223, DW_AT_accessibility(DW_ACCESS_public)
2980 .dwattr $C$DW$223, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_ctrl.h")
2981 .dwattr $C$DW$223, DW_AT_decl_line(0x2a)
2982 .dwattr $C$DW$223, DW_AT_decl_column(0x15)
2983$C$DW$224 .dwtag DW_TAG_member
2984 .dwattr $C$DW$224, DW_AT_type(*$C$DW$T$75)
2985 .dwattr $C$DW$224, DW_AT_name("CTRL_bit")
2986 .dwattr $C$DW$224, DW_AT_TI_symbol_name("CTRL_bit")
2987 .dwattr $C$DW$224, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
2988 .dwattr $C$DW$224, DW_AT_accessibility(DW_ACCESS_public)
2989 .dwattr $C$DW$224, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_ctrl.h")
2990 .dwattr $C$DW$224, DW_AT_decl_line(0x36)
2991 .dwattr $C$DW$224, DW_AT_decl_column(0x05)
2992 .dwendtag $C$DW$T$76
2993
2994 .dwattr $C$DW$T$76, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_ctrl.h")
2995 .dwattr $C$DW$T$76, DW_AT_decl_line(0x29)
2996 .dwattr $C$DW$T$76, DW_AT_decl_column(0x08)
2997
2998$C$DW$T$78 .dwtag DW_TAG_union_type
2999 .dwattr $C$DW$T$78, DW_AT_byte_size(0x04)
3000$C$DW$225 .dwtag DW_TAG_member
3001 .dwattr $C$DW$225, DW_AT_type(*$C$DW$T$48)
3002 .dwattr $C$DW$225, DW_AT_name("STS")
3003 .dwattr $C$DW$225, DW_AT_TI_symbol_name("STS")
3004 .dwattr $C$DW$225, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
3005 .dwattr $C$DW$225, DW_AT_accessibility(DW_ACCESS_public)
3006 .dwattr $C$DW$225, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_ctrl.h")
3007 .dwattr $C$DW$225, DW_AT_decl_line(0x3c)
3008 .dwattr $C$DW$225, DW_AT_decl_column(0x15)
3009$C$DW$226 .dwtag DW_TAG_member
3010 .dwattr $C$DW$226, DW_AT_type(*$C$DW$T$77)
3011 .dwattr $C$DW$226, DW_AT_name("STS_bit")
3012 .dwattr $C$DW$226, DW_AT_TI_symbol_name("STS_bit")
3013 .dwattr $C$DW$226, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
3014 .dwattr $C$DW$226, DW_AT_accessibility(DW_ACCESS_public)
3015 .dwattr $C$DW$226, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_ctrl.h")
3016 .dwattr $C$DW$226, DW_AT_decl_line(0x41)
3017 .dwattr $C$DW$226, DW_AT_decl_column(0x05)
3018 .dwendtag $C$DW$T$78
3019
3020 .dwattr $C$DW$T$78, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_ctrl.h")
3021 .dwattr $C$DW$T$78, DW_AT_decl_line(0x3b)
3022 .dwattr $C$DW$T$78, DW_AT_decl_column(0x08)
3023
3024$C$DW$T$80 .dwtag DW_TAG_union_type
3025 .dwattr $C$DW$T$80, DW_AT_byte_size(0x04)
3026$C$DW$227 .dwtag DW_TAG_member
3027 .dwattr $C$DW$227, DW_AT_type(*$C$DW$T$48)
3028 .dwattr $C$DW$227, DW_AT_name("WAKEUP_EN")
3029 .dwattr $C$DW$227, DW_AT_TI_symbol_name("WAKEUP_EN")
3030 .dwattr $C$DW$227, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
3031 .dwattr $C$DW$227, DW_AT_accessibility(DW_ACCESS_public)
3032 .dwattr $C$DW$227, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_ctrl.h")
3033 .dwattr $C$DW$227, DW_AT_decl_line(0x47)
3034 .dwattr $C$DW$227, DW_AT_decl_column(0x15)
3035$C$DW$228 .dwtag DW_TAG_member
3036 .dwattr $C$DW$228, DW_AT_type(*$C$DW$T$79)
3037 .dwattr $C$DW$228, DW_AT_name("WAKEUP_EN_bit")
3038 .dwattr $C$DW$228, DW_AT_TI_symbol_name("WAKEUP_EN_bit")
3039 .dwattr $C$DW$228, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
3040 .dwattr $C$DW$228, DW_AT_accessibility(DW_ACCESS_public)
3041 .dwattr $C$DW$228, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_ctrl.h")
3042 .dwattr $C$DW$228, DW_AT_decl_line(0x4b)
3043 .dwattr $C$DW$228, DW_AT_decl_column(0x05)
3044 .dwendtag $C$DW$T$80
3045
3046 .dwattr $C$DW$T$80, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_ctrl.h")
3047 .dwattr $C$DW$T$80, DW_AT_decl_line(0x46)
3048 .dwattr $C$DW$T$80, DW_AT_decl_column(0x08)
3049
3050$C$DW$T$82 .dwtag DW_TAG_union_type
3051 .dwattr $C$DW$T$82, DW_AT_byte_size(0x04)
3052$C$DW$229 .dwtag DW_TAG_member
3053 .dwattr $C$DW$229, DW_AT_type(*$C$DW$T$48)
3054 .dwattr $C$DW$229, DW_AT_name("CYCLE")
3055 .dwattr $C$DW$229, DW_AT_TI_symbol_name("CYCLE")
3056 .dwattr $C$DW$229, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
3057 .dwattr $C$DW$229, DW_AT_accessibility(DW_ACCESS_public)
3058 .dwattr $C$DW$229, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_ctrl.h")
3059 .dwattr $C$DW$229, DW_AT_decl_line(0x51)
3060 .dwattr $C$DW$229, DW_AT_decl_column(0x15)
3061$C$DW$230 .dwtag DW_TAG_member
3062 .dwattr $C$DW$230, DW_AT_type(*$C$DW$T$81)
3063 .dwattr $C$DW$230, DW_AT_name("CYCLE_bit")
3064 .dwattr $C$DW$230, DW_AT_TI_symbol_name("CYCLE_bit")
3065 .dwattr $C$DW$230, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
3066 .dwattr $C$DW$230, DW_AT_accessibility(DW_ACCESS_public)
3067 .dwattr $C$DW$230, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_ctrl.h")
3068 .dwattr $C$DW$230, DW_AT_decl_line(0x55)
3069 .dwattr $C$DW$230, DW_AT_decl_column(0x05)
3070 .dwendtag $C$DW$T$82
3071
3072 .dwattr $C$DW$T$82, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_ctrl.h")
3073 .dwattr $C$DW$T$82, DW_AT_decl_line(0x50)
3074 .dwattr $C$DW$T$82, DW_AT_decl_column(0x08)
3075
3076$C$DW$T$84 .dwtag DW_TAG_union_type
3077 .dwattr $C$DW$T$84, DW_AT_byte_size(0x04)
3078$C$DW$231 .dwtag DW_TAG_member
3079 .dwattr $C$DW$231, DW_AT_type(*$C$DW$T$48)
3080 .dwattr $C$DW$231, DW_AT_name("STALL")
3081 .dwattr $C$DW$231, DW_AT_TI_symbol_name("STALL")
3082 .dwattr $C$DW$231, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
3083 .dwattr $C$DW$231, DW_AT_accessibility(DW_ACCESS_public)
3084 .dwattr $C$DW$231, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_ctrl.h")
3085 .dwattr $C$DW$231, DW_AT_decl_line(0x5b)
3086 .dwattr $C$DW$231, DW_AT_decl_column(0x15)
3087$C$DW$232 .dwtag DW_TAG_member
3088 .dwattr $C$DW$232, DW_AT_type(*$C$DW$T$83)
3089 .dwattr $C$DW$232, DW_AT_name("STALL_bit")
3090 .dwattr $C$DW$232, DW_AT_TI_symbol_name("STALL_bit")
3091 .dwattr $C$DW$232, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
3092 .dwattr $C$DW$232, DW_AT_accessibility(DW_ACCESS_public)
3093 .dwattr $C$DW$232, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_ctrl.h")
3094 .dwattr $C$DW$232, DW_AT_decl_line(0x5f)
3095 .dwattr $C$DW$232, DW_AT_decl_column(0x05)
3096 .dwendtag $C$DW$T$84
3097
3098 .dwattr $C$DW$T$84, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_ctrl.h")
3099 .dwattr $C$DW$T$84, DW_AT_decl_line(0x5a)
3100 .dwattr $C$DW$T$84, DW_AT_decl_column(0x08)
3101
3102$C$DW$T$86 .dwtag DW_TAG_union_type
3103 .dwattr $C$DW$T$86, DW_AT_byte_size(0x04)
3104$C$DW$233 .dwtag DW_TAG_member
3105 .dwattr $C$DW$233, DW_AT_type(*$C$DW$T$48)
3106 .dwattr $C$DW$233, DW_AT_name("CTBIR0")
3107 .dwattr $C$DW$233, DW_AT_TI_symbol_name("CTBIR0")
3108 .dwattr $C$DW$233, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
3109 .dwattr $C$DW$233, DW_AT_accessibility(DW_ACCESS_public)
3110 .dwattr $C$DW$233, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_ctrl.h")
3111 .dwattr $C$DW$233, DW_AT_decl_line(0x68)
3112 .dwattr $C$DW$233, DW_AT_decl_column(0x15)
3113$C$DW$234 .dwtag DW_TAG_member
3114 .dwattr $C$DW$234, DW_AT_type(*$C$DW$T$85)
3115 .dwattr $C$DW$234, DW_AT_name("CTBIR0_bit")
3116 .dwattr $C$DW$234, DW_AT_TI_symbol_name("CTBIR0_bit")
3117 .dwattr $C$DW$234, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
3118 .dwattr $C$DW$234, DW_AT_accessibility(DW_ACCESS_public)
3119 .dwattr $C$DW$234, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_ctrl.h")
3120 .dwattr $C$DW$234, DW_AT_decl_line(0x6f)
3121 .dwattr $C$DW$234, DW_AT_decl_column(0x05)
3122 .dwendtag $C$DW$T$86
3123
3124 .dwattr $C$DW$T$86, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_ctrl.h")
3125 .dwattr $C$DW$T$86, DW_AT_decl_line(0x67)
3126 .dwattr $C$DW$T$86, DW_AT_decl_column(0x08)
3127
3128$C$DW$T$88 .dwtag DW_TAG_union_type
3129 .dwattr $C$DW$T$88, DW_AT_byte_size(0x04)
3130$C$DW$235 .dwtag DW_TAG_member
3131 .dwattr $C$DW$235, DW_AT_type(*$C$DW$T$48)
3132 .dwattr $C$DW$235, DW_AT_name("CTBIR1")
3133 .dwattr $C$DW$235, DW_AT_TI_symbol_name("CTBIR1")
3134 .dwattr $C$DW$235, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
3135 .dwattr $C$DW$235, DW_AT_accessibility(DW_ACCESS_public)
3136 .dwattr $C$DW$235, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_ctrl.h")
3137 .dwattr $C$DW$235, DW_AT_decl_line(0x75)
3138 .dwattr $C$DW$235, DW_AT_decl_column(0x15)
3139$C$DW$236 .dwtag DW_TAG_member
3140 .dwattr $C$DW$236, DW_AT_type(*$C$DW$T$87)
3141 .dwattr $C$DW$236, DW_AT_name("CTBIR1_bit")
3142 .dwattr $C$DW$236, DW_AT_TI_symbol_name("CTBIR1_bit")
3143 .dwattr $C$DW$236, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
3144 .dwattr $C$DW$236, DW_AT_accessibility(DW_ACCESS_public)
3145 .dwattr $C$DW$236, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_ctrl.h")
3146 .dwattr $C$DW$236, DW_AT_decl_line(0x7c)
3147 .dwattr $C$DW$236, DW_AT_decl_column(0x05)
3148 .dwendtag $C$DW$T$88
3149
3150 .dwattr $C$DW$T$88, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_ctrl.h")
3151 .dwattr $C$DW$T$88, DW_AT_decl_line(0x74)
3152 .dwattr $C$DW$T$88, DW_AT_decl_column(0x08)
3153
3154$C$DW$T$90 .dwtag DW_TAG_union_type
3155 .dwattr $C$DW$T$90, DW_AT_byte_size(0x04)
3156$C$DW$237 .dwtag DW_TAG_member
3157 .dwattr $C$DW$237, DW_AT_type(*$C$DW$T$48)
3158 .dwattr $C$DW$237, DW_AT_name("CTPPR0")
3159 .dwattr $C$DW$237, DW_AT_TI_symbol_name("CTPPR0")
3160 .dwattr $C$DW$237, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
3161 .dwattr $C$DW$237, DW_AT_accessibility(DW_ACCESS_public)
3162 .dwattr $C$DW$237, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_ctrl.h")
3163 .dwattr $C$DW$237, DW_AT_decl_line(0x82)
3164 .dwattr $C$DW$237, DW_AT_decl_column(0x15)
3165$C$DW$238 .dwtag DW_TAG_member
3166 .dwattr $C$DW$238, DW_AT_type(*$C$DW$T$89)
3167 .dwattr $C$DW$238, DW_AT_name("CTPPR0_bit")
3168 .dwattr $C$DW$238, DW_AT_TI_symbol_name("CTPPR0_bit")
3169 .dwattr $C$DW$238, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
3170 .dwattr $C$DW$238, DW_AT_accessibility(DW_ACCESS_public)
3171 .dwattr $C$DW$238, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_ctrl.h")
3172 .dwattr $C$DW$238, DW_AT_decl_line(0x87)
3173 .dwattr $C$DW$238, DW_AT_decl_column(0x05)
3174 .dwendtag $C$DW$T$90
3175
3176 .dwattr $C$DW$T$90, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_ctrl.h")
3177 .dwattr $C$DW$T$90, DW_AT_decl_line(0x81)
3178 .dwattr $C$DW$T$90, DW_AT_decl_column(0x08)
3179
3180$C$DW$T$92 .dwtag DW_TAG_union_type
3181 .dwattr $C$DW$T$92, DW_AT_byte_size(0x04)
3182$C$DW$239 .dwtag DW_TAG_member
3183 .dwattr $C$DW$239, DW_AT_type(*$C$DW$T$48)
3184 .dwattr $C$DW$239, DW_AT_name("CTPPR1")
3185 .dwattr $C$DW$239, DW_AT_TI_symbol_name("CTPPR1")
3186 .dwattr $C$DW$239, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
3187 .dwattr $C$DW$239, DW_AT_accessibility(DW_ACCESS_public)
3188 .dwattr $C$DW$239, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_ctrl.h")
3189 .dwattr $C$DW$239, DW_AT_decl_line(0x8d)
3190 .dwattr $C$DW$239, DW_AT_decl_column(0x15)
3191$C$DW$240 .dwtag DW_TAG_member
3192 .dwattr $C$DW$240, DW_AT_type(*$C$DW$T$91)
3193 .dwattr $C$DW$240, DW_AT_name("CTPPR1_bit")
3194 .dwattr $C$DW$240, DW_AT_TI_symbol_name("CTPPR1_bit")
3195 .dwattr $C$DW$240, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
3196 .dwattr $C$DW$240, DW_AT_accessibility(DW_ACCESS_public)
3197 .dwattr $C$DW$240, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_ctrl.h")
3198 .dwattr $C$DW$240, DW_AT_decl_line(0x92)
3199 .dwattr $C$DW$240, DW_AT_decl_column(0x05)
3200 .dwendtag $C$DW$T$92
3201
3202 .dwattr $C$DW$T$92, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/am335x/pru_ctrl.h")
3203 .dwattr $C$DW$T$92, DW_AT_decl_line(0x8c)
3204 .dwattr $C$DW$T$92, DW_AT_decl_column(0x08)
3205
3206$C$DW$T$19 .dwtag DW_TAG_structure_type
3207 .dwattr $C$DW$T$19, DW_AT_name("__TI_wildcard")
3208 .dwattr $C$DW$T$19, DW_AT_declaration
3209 .dwendtag $C$DW$T$19
3210
3211$C$DW$T$105 .dwtag DW_TAG_pointer_type
3212 .dwattr $C$DW$T$105, DW_AT_type(*$C$DW$T$19)
3213 .dwattr $C$DW$T$105, DW_AT_address_class(0x20)
3214$C$DW$T$2 .dwtag DW_TAG_unspecified_type
3215 .dwattr $C$DW$T$2, DW_AT_name("void")
3216$C$DW$T$3 .dwtag DW_TAG_pointer_type
3217 .dwattr $C$DW$T$3, DW_AT_type(*$C$DW$T$2)
3218 .dwattr $C$DW$T$3, DW_AT_address_class(0x20)
3219$C$DW$T$106 .dwtag DW_TAG_const_type
3220 .dwattr $C$DW$T$106, DW_AT_type(*$C$DW$T$2)
3221$C$DW$T$107 .dwtag DW_TAG_pointer_type
3222 .dwattr $C$DW$T$107, DW_AT_type(*$C$DW$T$106)
3223 .dwattr $C$DW$T$107, DW_AT_address_class(0x20)
3224$C$DW$T$4 .dwtag DW_TAG_base_type
3225 .dwattr $C$DW$T$4, DW_AT_encoding(DW_ATE_boolean)
3226 .dwattr $C$DW$T$4, DW_AT_name("bool")
3227 .dwattr $C$DW$T$4, DW_AT_byte_size(0x01)
3228$C$DW$T$5 .dwtag DW_TAG_base_type
3229 .dwattr $C$DW$T$5, DW_AT_encoding(DW_ATE_signed_char)
3230 .dwattr $C$DW$T$5, DW_AT_name("signed char")
3231 .dwattr $C$DW$T$5, DW_AT_byte_size(0x01)
3232$C$DW$T$6 .dwtag DW_TAG_base_type
3233 .dwattr $C$DW$T$6, DW_AT_encoding(DW_ATE_unsigned_char)
3234 .dwattr $C$DW$T$6, DW_AT_name("unsigned char")
3235 .dwattr $C$DW$T$6, DW_AT_byte_size(0x01)
3236$C$DW$T$112 .dwtag DW_TAG_typedef, DW_AT_name("uint8_t")
3237 .dwattr $C$DW$T$112, DW_AT_type(*$C$DW$T$6)
3238 .dwattr $C$DW$T$112, DW_AT_language(DW_LANG_C)
3239 .dwattr $C$DW$T$112, DW_AT_decl_file("/home/a0273976local/ti-cgt-pru_2.1.4/include/stdint.h")
3240 .dwattr $C$DW$T$112, DW_AT_decl_line(0x2b)
3241 .dwattr $C$DW$T$112, DW_AT_decl_column(0x1c)
3242$C$DW$T$7 .dwtag DW_TAG_base_type
3243 .dwattr $C$DW$T$7, DW_AT_encoding(DW_ATE_signed_char)
3244 .dwattr $C$DW$T$7, DW_AT_name("wchar_t")
3245 .dwattr $C$DW$T$7, DW_AT_byte_size(0x04)
3246$C$DW$T$8 .dwtag DW_TAG_base_type
3247 .dwattr $C$DW$T$8, DW_AT_encoding(DW_ATE_signed)
3248 .dwattr $C$DW$T$8, DW_AT_name("short")
3249 .dwattr $C$DW$T$8, DW_AT_byte_size(0x02)
3250$C$DW$T$113 .dwtag DW_TAG_typedef, DW_AT_name("int16_t")
3251 .dwattr $C$DW$T$113, DW_AT_type(*$C$DW$T$8)
3252 .dwattr $C$DW$T$113, DW_AT_language(DW_LANG_C)
3253 .dwattr $C$DW$T$113, DW_AT_decl_file("/home/a0273976local/ti-cgt-pru_2.1.4/include/stdint.h")
3254 .dwattr $C$DW$T$113, DW_AT_decl_line(0x2c)
3255 .dwattr $C$DW$T$113, DW_AT_decl_column(0x1d)
3256$C$DW$T$9 .dwtag DW_TAG_base_type
3257 .dwattr $C$DW$T$9, DW_AT_encoding(DW_ATE_unsigned)
3258 .dwattr $C$DW$T$9, DW_AT_name("unsigned short")
3259 .dwattr $C$DW$T$9, DW_AT_byte_size(0x02)
3260$C$DW$T$115 .dwtag DW_TAG_typedef, DW_AT_name("uint16_t")
3261 .dwattr $C$DW$T$115, DW_AT_type(*$C$DW$T$9)
3262 .dwattr $C$DW$T$115, DW_AT_language(DW_LANG_C)
3263 .dwattr $C$DW$T$115, DW_AT_decl_file("/home/a0273976local/ti-cgt-pru_2.1.4/include/stdint.h")
3264 .dwattr $C$DW$T$115, DW_AT_decl_line(0x2d)
3265 .dwattr $C$DW$T$115, DW_AT_decl_column(0x1c)
3266$C$DW$T$116 .dwtag DW_TAG_const_type
3267 .dwattr $C$DW$T$116, DW_AT_type(*$C$DW$T$115)
3268$C$DW$T$10 .dwtag DW_TAG_base_type
3269 .dwattr $C$DW$T$10, DW_AT_encoding(DW_ATE_signed)
3270 .dwattr $C$DW$T$10, DW_AT_name("int")
3271 .dwattr $C$DW$T$10, DW_AT_byte_size(0x04)
3272$C$DW$T$123 .dwtag DW_TAG_typedef, DW_AT_name("int32_t")
3273 .dwattr $C$DW$T$123, DW_AT_type(*$C$DW$T$10)
3274 .dwattr $C$DW$T$123, DW_AT_language(DW_LANG_C)
3275 .dwattr $C$DW$T$123, DW_AT_decl_file("/home/a0273976local/ti-cgt-pru_2.1.4/include/stdint.h")
3276 .dwattr $C$DW$T$123, DW_AT_decl_line(0x2e)
3277 .dwattr $C$DW$T$123, DW_AT_decl_column(0x1d)
3278$C$DW$T$124 .dwtag DW_TAG_volatile_type
3279 .dwattr $C$DW$T$124, DW_AT_type(*$C$DW$T$123)
3280
3281$C$DW$T$125 .dwtag DW_TAG_array_type
3282 .dwattr $C$DW$T$125, DW_AT_type(*$C$DW$T$124)
3283 .dwattr $C$DW$T$125, DW_AT_language(DW_LANG_C)
3284 .dwattr $C$DW$T$125, DW_AT_byte_size(0x28)
3285$C$DW$241 .dwtag DW_TAG_subrange_type
3286 .dwattr $C$DW$241, DW_AT_upper_bound(0x09)
3287 .dwendtag $C$DW$T$125
3288
3289$C$DW$T$11 .dwtag DW_TAG_base_type
3290 .dwattr $C$DW$T$11, DW_AT_encoding(DW_ATE_unsigned)
3291 .dwattr $C$DW$T$11, DW_AT_name("unsigned int")
3292 .dwattr $C$DW$T$11, DW_AT_byte_size(0x04)
3293$C$DW$T$33 .dwtag DW_TAG_typedef, DW_AT_name("uint32_t")
3294 .dwattr $C$DW$T$33, DW_AT_type(*$C$DW$T$11)
3295 .dwattr $C$DW$T$33, DW_AT_language(DW_LANG_C)
3296 .dwattr $C$DW$T$33, DW_AT_decl_file("/home/a0273976local/ti-cgt-pru_2.1.4/include/stdint.h")
3297 .dwattr $C$DW$T$33, DW_AT_decl_line(0x2f)
3298 .dwattr $C$DW$T$33, DW_AT_decl_column(0x1c)
3299
3300$C$DW$T$34 .dwtag DW_TAG_array_type
3301 .dwattr $C$DW$T$34, DW_AT_type(*$C$DW$T$33)
3302 .dwattr $C$DW$T$34, DW_AT_language(DW_LANG_C)
3303 .dwattr $C$DW$T$34, DW_AT_byte_size(0x04)
3304$C$DW$242 .dwtag DW_TAG_subrange_type
3305 .dwattr $C$DW$242, DW_AT_upper_bound(0x00)
3306 .dwendtag $C$DW$T$34
3307
3308
3309$C$DW$T$35 .dwtag DW_TAG_array_type
3310 .dwattr $C$DW$T$35, DW_AT_type(*$C$DW$T$33)
3311 .dwattr $C$DW$T$35, DW_AT_language(DW_LANG_C)
3312 .dwattr $C$DW$T$35, DW_AT_byte_size(0x08)
3313$C$DW$243 .dwtag DW_TAG_subrange_type
3314 .dwattr $C$DW$243, DW_AT_upper_bound(0x01)
3315 .dwendtag $C$DW$T$35
3316
3317
3318$C$DW$T$46 .dwtag DW_TAG_array_type
3319 .dwattr $C$DW$T$46, DW_AT_type(*$C$DW$T$33)
3320 .dwattr $C$DW$T$46, DW_AT_language(DW_LANG_C)
3321 .dwattr $C$DW$T$46, DW_AT_byte_size(0x0c)
3322$C$DW$244 .dwtag DW_TAG_subrange_type
3323 .dwattr $C$DW$244, DW_AT_upper_bound(0x02)
3324 .dwendtag $C$DW$T$46
3325
3326
3327$C$DW$T$132 .dwtag DW_TAG_array_type
3328 .dwattr $C$DW$T$132, DW_AT_type(*$C$DW$T$33)
3329 .dwattr $C$DW$T$132, DW_AT_language(DW_LANG_C)
3330 .dwattr $C$DW$T$132, DW_AT_byte_size(0x18)
3331$C$DW$245 .dwtag DW_TAG_subrange_type
3332 .dwattr $C$DW$245, DW_AT_upper_bound(0x05)
3333 .dwendtag $C$DW$T$132
3334
3335
3336$C$DW$T$133 .dwtag DW_TAG_array_type
3337 .dwattr $C$DW$T$133, DW_AT_type(*$C$DW$T$33)
3338 .dwattr $C$DW$T$133, DW_AT_language(DW_LANG_C)
3339 .dwattr $C$DW$T$133, DW_AT_byte_size(0xc0)
3340$C$DW$246 .dwtag DW_TAG_subrange_type
3341 .dwattr $C$DW$246, DW_AT_upper_bound(0x2f)
3342 .dwendtag $C$DW$T$133
3343
3344$C$DW$T$48 .dwtag DW_TAG_volatile_type
3345 .dwattr $C$DW$T$48, DW_AT_type(*$C$DW$T$33)
3346$C$DW$T$12 .dwtag DW_TAG_base_type
3347 .dwattr $C$DW$T$12, DW_AT_encoding(DW_ATE_signed)
3348 .dwattr $C$DW$T$12, DW_AT_name("long")
3349 .dwattr $C$DW$T$12, DW_AT_byte_size(0x04)
3350$C$DW$T$13 .dwtag DW_TAG_base_type
3351 .dwattr $C$DW$T$13, DW_AT_encoding(DW_ATE_unsigned)
3352 .dwattr $C$DW$T$13, DW_AT_name("unsigned long")
3353 .dwattr $C$DW$T$13, DW_AT_byte_size(0x04)
3354$C$DW$T$14 .dwtag DW_TAG_base_type
3355 .dwattr $C$DW$T$14, DW_AT_encoding(DW_ATE_signed)
3356 .dwattr $C$DW$T$14, DW_AT_name("long long")
3357 .dwattr $C$DW$T$14, DW_AT_byte_size(0x08)
3358$C$DW$T$15 .dwtag DW_TAG_base_type
3359 .dwattr $C$DW$T$15, DW_AT_encoding(DW_ATE_unsigned)
3360 .dwattr $C$DW$T$15, DW_AT_name("unsigned long long")
3361 .dwattr $C$DW$T$15, DW_AT_byte_size(0x08)
3362$C$DW$T$16 .dwtag DW_TAG_base_type
3363 .dwattr $C$DW$T$16, DW_AT_encoding(DW_ATE_float)
3364 .dwattr $C$DW$T$16, DW_AT_name("float")
3365 .dwattr $C$DW$T$16, DW_AT_byte_size(0x04)
3366$C$DW$T$17 .dwtag DW_TAG_base_type
3367 .dwattr $C$DW$T$17, DW_AT_encoding(DW_ATE_float)
3368 .dwattr $C$DW$T$17, DW_AT_name("double")
3369 .dwattr $C$DW$T$17, DW_AT_byte_size(0x08)
3370$C$DW$T$18 .dwtag DW_TAG_base_type
3371 .dwattr $C$DW$T$18, DW_AT_encoding(DW_ATE_float)
3372 .dwattr $C$DW$T$18, DW_AT_name("long double")
3373 .dwattr $C$DW$T$18, DW_AT_byte_size(0x08)
3374
3375$C$DW$T$93 .dwtag DW_TAG_structure_type
3376 .dwattr $C$DW$T$93, DW_AT_name("my_resource_table")
3377 .dwattr $C$DW$T$93, DW_AT_byte_size(0x14)
3378$C$DW$247 .dwtag DW_TAG_member
3379 .dwattr $C$DW$247, DW_AT_type(*$C$DW$T$94)
3380 .dwattr $C$DW$247, DW_AT_name("base")
3381 .dwattr $C$DW$247, DW_AT_TI_symbol_name("base")
3382 .dwattr $C$DW$247, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
3383 .dwattr $C$DW$247, DW_AT_accessibility(DW_ACCESS_public)
3384 .dwattr $C$DW$247, DW_AT_decl_file("resource_table_empty.h")
3385 .dwattr $C$DW$247, DW_AT_decl_line(0x39)
3386 .dwattr $C$DW$247, DW_AT_decl_column(0x18)
3387$C$DW$248 .dwtag DW_TAG_member
3388 .dwattr $C$DW$248, DW_AT_type(*$C$DW$T$34)
3389 .dwattr $C$DW$248, DW_AT_name("offset")
3390 .dwattr $C$DW$248, DW_AT_TI_symbol_name("offset")
3391 .dwattr $C$DW$248, DW_AT_data_member_location[DW_OP_plus_uconst 0x10]
3392 .dwattr $C$DW$248, DW_AT_accessibility(DW_ACCESS_public)
3393 .dwattr $C$DW$248, DW_AT_decl_file("resource_table_empty.h")
3394 .dwattr $C$DW$248, DW_AT_decl_line(0x3b)
3395 .dwattr $C$DW$248, DW_AT_decl_column(0x0b)
3396 .dwendtag $C$DW$T$93
3397
3398 .dwattr $C$DW$T$93, DW_AT_decl_file("resource_table_empty.h")
3399 .dwattr $C$DW$T$93, DW_AT_decl_line(0x38)
3400 .dwattr $C$DW$T$93, DW_AT_decl_column(0x08)
3401
3402$C$DW$T$94 .dwtag DW_TAG_structure_type
3403 .dwattr $C$DW$T$94, DW_AT_name("resource_table")
3404 .dwattr $C$DW$T$94, DW_AT_byte_size(0x10)
3405$C$DW$249 .dwtag DW_TAG_member
3406 .dwattr $C$DW$249, DW_AT_type(*$C$DW$T$33)
3407 .dwattr $C$DW$249, DW_AT_name("ver")
3408 .dwattr $C$DW$249, DW_AT_TI_symbol_name("ver")
3409 .dwattr $C$DW$249, DW_AT_data_member_location[DW_OP_plus_uconst 0x0]
3410 .dwattr $C$DW$249, DW_AT_accessibility(DW_ACCESS_public)
3411 .dwattr $C$DW$249, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/rsc_types.h")
3412 .dwattr $C$DW$249, DW_AT_decl_line(0x57)
3413 .dwattr $C$DW$249, DW_AT_decl_column(0x0b)
3414$C$DW$250 .dwtag DW_TAG_member
3415 .dwattr $C$DW$250, DW_AT_type(*$C$DW$T$33)
3416 .dwattr $C$DW$250, DW_AT_name("num")
3417 .dwattr $C$DW$250, DW_AT_TI_symbol_name("num")
3418 .dwattr $C$DW$250, DW_AT_data_member_location[DW_OP_plus_uconst 0x4]
3419 .dwattr $C$DW$250, DW_AT_accessibility(DW_ACCESS_public)
3420 .dwattr $C$DW$250, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/rsc_types.h")
3421 .dwattr $C$DW$250, DW_AT_decl_line(0x58)
3422 .dwattr $C$DW$250, DW_AT_decl_column(0x0b)
3423$C$DW$251 .dwtag DW_TAG_member
3424 .dwattr $C$DW$251, DW_AT_type(*$C$DW$T$35)
3425 .dwattr $C$DW$251, DW_AT_name("reserved")
3426 .dwattr $C$DW$251, DW_AT_TI_symbol_name("reserved")
3427 .dwattr $C$DW$251, DW_AT_data_member_location[DW_OP_plus_uconst 0x8]
3428 .dwattr $C$DW$251, DW_AT_accessibility(DW_ACCESS_public)
3429 .dwattr $C$DW$251, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/rsc_types.h")
3430 .dwattr $C$DW$251, DW_AT_decl_line(0x59)
3431 .dwattr $C$DW$251, DW_AT_decl_column(0x0b)
3432 .dwendtag $C$DW$T$94
3433
3434 .dwattr $C$DW$T$94, DW_AT_decl_file("/home/a0273976local/pru-software-support-package/include/rsc_types.h")
3435 .dwattr $C$DW$T$94, DW_AT_decl_line(0x56)
3436 .dwattr $C$DW$T$94, DW_AT_decl_column(0x08)
3437 .dwattr $C$DW$CU, DW_AT_language(DW_LANG_C)
3438
3439;***************************************************************
3440;* DWARF CIE ENTRIES *
3441;***************************************************************
3442
3443$C$DW$CIE .dwcie 14
3444 .dwcfi cfa_register, 8
3445 .dwcfi cfa_offset, 0
3446 .dwcfi undefined, 0
3447 .dwcfi undefined, 1
3448 .dwcfi undefined, 2
3449 .dwcfi undefined, 3
3450 .dwcfi undefined, 4
3451 .dwcfi undefined, 5
3452 .dwcfi undefined, 6
3453 .dwcfi undefined, 7
3454 .dwcfi same_value, 8
3455 .dwcfi same_value, 9
3456 .dwcfi same_value, 10
3457 .dwcfi same_value, 11
3458 .dwcfi undefined, 12
3459 .dwcfi undefined, 13
3460 .dwcfi undefined, 14
3461 .dwcfi undefined, 15
3462 .dwcfi same_value, 16
3463 .dwcfi same_value, 17
3464 .dwcfi same_value, 18
3465 .dwcfi same_value, 19
3466 .dwcfi same_value, 20
3467 .dwcfi same_value, 21
3468 .dwcfi same_value, 22
3469 .dwcfi same_value, 23
3470 .dwcfi same_value, 24
3471 .dwcfi same_value, 25
3472 .dwcfi same_value, 26
3473 .dwcfi same_value, 27
3474 .dwcfi same_value, 28
3475 .dwcfi same_value, 29
3476 .dwcfi same_value, 30
3477 .dwcfi same_value, 31
3478 .dwcfi same_value, 32
3479 .dwcfi same_value, 33
3480 .dwcfi same_value, 34
3481 .dwcfi same_value, 35
3482 .dwcfi same_value, 36
3483 .dwcfi same_value, 37
3484 .dwcfi same_value, 38
3485 .dwcfi same_value, 39
3486 .dwcfi same_value, 40
3487 .dwcfi same_value, 41
3488 .dwcfi same_value, 42
3489 .dwcfi same_value, 43
3490 .dwcfi same_value, 44
3491 .dwcfi same_value, 45
3492 .dwcfi same_value, 46
3493 .dwcfi same_value, 47
3494 .dwcfi same_value, 48
3495 .dwcfi same_value, 49
3496 .dwcfi same_value, 50
3497 .dwcfi same_value, 51
3498 .dwcfi same_value, 52
3499 .dwcfi same_value, 53
3500 .dwcfi same_value, 54
3501 .dwcfi same_value, 55
3502 .dwcfi undefined, 56
3503 .dwcfi undefined, 57
3504 .dwcfi undefined, 58
3505 .dwcfi undefined, 59
3506 .dwcfi undefined, 60
3507 .dwcfi undefined, 61
3508 .dwcfi undefined, 62
3509 .dwcfi undefined, 63
3510 .dwcfi undefined, 64
3511 .dwcfi undefined, 65
3512 .dwcfi undefined, 66
3513 .dwcfi undefined, 67
3514 .dwcfi undefined, 68
3515 .dwcfi undefined, 69
3516 .dwcfi undefined, 70
3517 .dwcfi undefined, 71
3518 .dwcfi undefined, 72
3519 .dwcfi undefined, 73
3520 .dwcfi undefined, 74
3521 .dwcfi undefined, 75
3522 .dwcfi undefined, 76
3523 .dwcfi undefined, 77
3524 .dwcfi undefined, 78
3525 .dwcfi undefined, 79
3526 .dwcfi undefined, 80
3527 .dwcfi undefined, 81
3528 .dwcfi undefined, 82
3529 .dwcfi undefined, 83
3530 .dwcfi undefined, 84
3531 .dwcfi undefined, 85
3532 .dwcfi undefined, 86
3533 .dwcfi undefined, 87
3534 .dwcfi undefined, 88
3535 .dwcfi undefined, 89
3536 .dwcfi undefined, 90
3537 .dwcfi undefined, 91
3538 .dwcfi undefined, 92
3539 .dwcfi undefined, 93
3540 .dwcfi undefined, 94
3541 .dwcfi undefined, 95
3542 .dwcfi undefined, 96
3543 .dwcfi undefined, 97
3544 .dwcfi undefined, 98
3545 .dwcfi undefined, 99
3546 .dwcfi undefined, 100
3547 .dwcfi undefined, 101
3548 .dwcfi undefined, 102
3549 .dwcfi undefined, 103
3550 .dwcfi undefined, 104
3551 .dwcfi undefined, 105
3552 .dwcfi undefined, 106
3553 .dwcfi undefined, 107
3554 .dwcfi undefined, 108
3555 .dwcfi undefined, 109
3556 .dwcfi undefined, 110
3557 .dwcfi undefined, 111
3558 .dwcfi undefined, 112
3559 .dwcfi undefined, 113
3560 .dwcfi undefined, 114
3561 .dwcfi undefined, 115
3562 .dwcfi undefined, 116
3563 .dwcfi undefined, 117
3564 .dwcfi undefined, 118
3565 .dwcfi undefined, 119
3566 .dwcfi undefined, 120
3567 .dwcfi undefined, 121
3568 .dwcfi undefined, 122
3569 .dwcfi undefined, 123
3570 .dwcfi undefined, 124
3571 .dwcfi undefined, 125
3572 .dwcfi undefined, 126
3573 .dwcfi undefined, 127
3574 .dwcfi undefined, 128
3575 .dwcfi undefined, 129
3576 .dwcfi undefined, 130
3577 .dwcfi undefined, 131
3578 .dwcfi undefined, 132
3579 .dwcfi undefined, 133
3580 .dwcfi undefined, 134
3581 .dwendentry
3582
3583;***************************************************************
3584;* DWARF REGISTER MAP *
3585;***************************************************************
3586
3587$C$DW$252 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R0_b0")
3588 .dwattr $C$DW$252, DW_AT_location[DW_OP_reg0]
3589$C$DW$253 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R0_b1")
3590 .dwattr $C$DW$253, DW_AT_location[DW_OP_reg1]
3591$C$DW$254 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R0_b2")
3592 .dwattr $C$DW$254, DW_AT_location[DW_OP_reg2]
3593$C$DW$255 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R0_b3")
3594 .dwattr $C$DW$255, DW_AT_location[DW_OP_reg3]
3595$C$DW$256 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R1_b0")
3596 .dwattr $C$DW$256, DW_AT_location[DW_OP_reg4]
3597$C$DW$257 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R1_b1")
3598 .dwattr $C$DW$257, DW_AT_location[DW_OP_reg5]
3599$C$DW$258 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R1_b2")
3600 .dwattr $C$DW$258, DW_AT_location[DW_OP_reg6]
3601$C$DW$259 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R1_b3")
3602 .dwattr $C$DW$259, DW_AT_location[DW_OP_reg7]
3603$C$DW$260 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R2_b0")
3604 .dwattr $C$DW$260, DW_AT_location[DW_OP_reg8]
3605$C$DW$261 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R2_b1")
3606 .dwattr $C$DW$261, DW_AT_location[DW_OP_reg9]
3607$C$DW$262 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R2_b2")
3608 .dwattr $C$DW$262, DW_AT_location[DW_OP_reg10]
3609$C$DW$263 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R2_b3")
3610 .dwattr $C$DW$263, DW_AT_location[DW_OP_reg11]
3611$C$DW$264 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R3_b0")
3612 .dwattr $C$DW$264, DW_AT_location[DW_OP_reg12]
3613$C$DW$265 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R3_b1")
3614 .dwattr $C$DW$265, DW_AT_location[DW_OP_reg13]
3615$C$DW$266 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R3_b2")
3616 .dwattr $C$DW$266, DW_AT_location[DW_OP_reg14]
3617$C$DW$267 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R3_b3")
3618 .dwattr $C$DW$267, DW_AT_location[DW_OP_reg15]
3619$C$DW$268 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R4_b0")
3620 .dwattr $C$DW$268, DW_AT_location[DW_OP_reg16]
3621$C$DW$269 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R4_b1")
3622 .dwattr $C$DW$269, DW_AT_location[DW_OP_reg17]
3623$C$DW$270 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R4_b2")
3624 .dwattr $C$DW$270, DW_AT_location[DW_OP_reg18]
3625$C$DW$271 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R4_b3")
3626 .dwattr $C$DW$271, DW_AT_location[DW_OP_reg19]
3627$C$DW$272 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R5_b0")
3628 .dwattr $C$DW$272, DW_AT_location[DW_OP_reg20]
3629$C$DW$273 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R5_b1")
3630 .dwattr $C$DW$273, DW_AT_location[DW_OP_reg21]
3631$C$DW$274 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R5_b2")
3632 .dwattr $C$DW$274, DW_AT_location[DW_OP_reg22]
3633$C$DW$275 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R5_b3")
3634 .dwattr $C$DW$275, DW_AT_location[DW_OP_reg23]
3635$C$DW$276 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R6_b0")
3636 .dwattr $C$DW$276, DW_AT_location[DW_OP_reg24]
3637$C$DW$277 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R6_b1")
3638 .dwattr $C$DW$277, DW_AT_location[DW_OP_reg25]
3639$C$DW$278 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R6_b2")
3640 .dwattr $C$DW$278, DW_AT_location[DW_OP_reg26]
3641$C$DW$279 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R6_b3")
3642 .dwattr $C$DW$279, DW_AT_location[DW_OP_reg27]
3643$C$DW$280 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R7_b0")
3644 .dwattr $C$DW$280, DW_AT_location[DW_OP_reg28]
3645$C$DW$281 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R7_b1")
3646 .dwattr $C$DW$281, DW_AT_location[DW_OP_reg29]
3647$C$DW$282 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R7_b2")
3648 .dwattr $C$DW$282, DW_AT_location[DW_OP_reg30]
3649$C$DW$283 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R7_b3")
3650 .dwattr $C$DW$283, DW_AT_location[DW_OP_reg31]
3651$C$DW$284 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R8_b0")
3652 .dwattr $C$DW$284, DW_AT_location[DW_OP_regx 0x20]
3653$C$DW$285 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R8_b1")
3654 .dwattr $C$DW$285, DW_AT_location[DW_OP_regx 0x21]
3655$C$DW$286 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R8_b2")
3656 .dwattr $C$DW$286, DW_AT_location[DW_OP_regx 0x22]
3657$C$DW$287 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R8_b3")
3658 .dwattr $C$DW$287, DW_AT_location[DW_OP_regx 0x23]
3659$C$DW$288 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R9_b0")
3660 .dwattr $C$DW$288, DW_AT_location[DW_OP_regx 0x24]
3661$C$DW$289 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R9_b1")
3662 .dwattr $C$DW$289, DW_AT_location[DW_OP_regx 0x25]
3663$C$DW$290 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R9_b2")
3664 .dwattr $C$DW$290, DW_AT_location[DW_OP_regx 0x26]
3665$C$DW$291 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R9_b3")
3666 .dwattr $C$DW$291, DW_AT_location[DW_OP_regx 0x27]
3667$C$DW$292 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R10_b0")
3668 .dwattr $C$DW$292, DW_AT_location[DW_OP_regx 0x28]
3669$C$DW$293 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R10_b1")
3670 .dwattr $C$DW$293, DW_AT_location[DW_OP_regx 0x29]
3671$C$DW$294 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R10_b2")
3672 .dwattr $C$DW$294, DW_AT_location[DW_OP_regx 0x2a]
3673$C$DW$295 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R10_b3")
3674 .dwattr $C$DW$295, DW_AT_location[DW_OP_regx 0x2b]
3675$C$DW$296 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R11_b0")
3676 .dwattr $C$DW$296, DW_AT_location[DW_OP_regx 0x2c]
3677$C$DW$297 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R11_b1")
3678 .dwattr $C$DW$297, DW_AT_location[DW_OP_regx 0x2d]
3679$C$DW$298 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R11_b2")
3680 .dwattr $C$DW$298, DW_AT_location[DW_OP_regx 0x2e]
3681$C$DW$299 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R11_b3")
3682 .dwattr $C$DW$299, DW_AT_location[DW_OP_regx 0x2f]
3683$C$DW$300 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R12_b0")
3684 .dwattr $C$DW$300, DW_AT_location[DW_OP_regx 0x30]
3685$C$DW$301 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R12_b1")
3686 .dwattr $C$DW$301, DW_AT_location[DW_OP_regx 0x31]
3687$C$DW$302 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R12_b2")
3688 .dwattr $C$DW$302, DW_AT_location[DW_OP_regx 0x32]
3689$C$DW$303 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R12_b3")
3690 .dwattr $C$DW$303, DW_AT_location[DW_OP_regx 0x33]
3691$C$DW$304 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R13_b0")
3692 .dwattr $C$DW$304, DW_AT_location[DW_OP_regx 0x34]
3693$C$DW$305 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R13_b1")
3694 .dwattr $C$DW$305, DW_AT_location[DW_OP_regx 0x35]
3695$C$DW$306 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R13_b2")
3696 .dwattr $C$DW$306, DW_AT_location[DW_OP_regx 0x36]
3697$C$DW$307 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R13_b3")
3698 .dwattr $C$DW$307, DW_AT_location[DW_OP_regx 0x37]
3699$C$DW$308 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R14_b0")
3700 .dwattr $C$DW$308, DW_AT_location[DW_OP_regx 0x38]
3701$C$DW$309 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R14_b1")
3702 .dwattr $C$DW$309, DW_AT_location[DW_OP_regx 0x39]
3703$C$DW$310 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R14_b2")
3704 .dwattr $C$DW$310, DW_AT_location[DW_OP_regx 0x3a]
3705$C$DW$311 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R14_b3")
3706 .dwattr $C$DW$311, DW_AT_location[DW_OP_regx 0x3b]
3707$C$DW$312 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R15_b0")
3708 .dwattr $C$DW$312, DW_AT_location[DW_OP_regx 0x3c]
3709$C$DW$313 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R15_b1")
3710 .dwattr $C$DW$313, DW_AT_location[DW_OP_regx 0x3d]
3711$C$DW$314 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R15_b2")
3712 .dwattr $C$DW$314, DW_AT_location[DW_OP_regx 0x3e]
3713$C$DW$315 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R15_b3")
3714 .dwattr $C$DW$315, DW_AT_location[DW_OP_regx 0x3f]
3715$C$DW$316 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R16_b0")
3716 .dwattr $C$DW$316, DW_AT_location[DW_OP_regx 0x40]
3717$C$DW$317 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R16_b1")
3718 .dwattr $C$DW$317, DW_AT_location[DW_OP_regx 0x41]
3719$C$DW$318 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R16_b2")
3720 .dwattr $C$DW$318, DW_AT_location[DW_OP_regx 0x42]
3721$C$DW$319 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R16_b3")
3722 .dwattr $C$DW$319, DW_AT_location[DW_OP_regx 0x43]
3723$C$DW$320 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R17_b0")
3724 .dwattr $C$DW$320, DW_AT_location[DW_OP_regx 0x44]
3725$C$DW$321 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R17_b1")
3726 .dwattr $C$DW$321, DW_AT_location[DW_OP_regx 0x45]
3727$C$DW$322 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R17_b2")
3728 .dwattr $C$DW$322, DW_AT_location[DW_OP_regx 0x46]
3729$C$DW$323 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R17_b3")
3730 .dwattr $C$DW$323, DW_AT_location[DW_OP_regx 0x47]
3731$C$DW$324 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R18_b0")
3732 .dwattr $C$DW$324, DW_AT_location[DW_OP_regx 0x48]
3733$C$DW$325 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R18_b1")
3734 .dwattr $C$DW$325, DW_AT_location[DW_OP_regx 0x49]
3735$C$DW$326 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R18_b2")
3736 .dwattr $C$DW$326, DW_AT_location[DW_OP_regx 0x4a]
3737$C$DW$327 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R18_b3")
3738 .dwattr $C$DW$327, DW_AT_location[DW_OP_regx 0x4b]
3739$C$DW$328 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R19_b0")
3740 .dwattr $C$DW$328, DW_AT_location[DW_OP_regx 0x4c]
3741$C$DW$329 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R19_b1")
3742 .dwattr $C$DW$329, DW_AT_location[DW_OP_regx 0x4d]
3743$C$DW$330 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R19_b2")
3744 .dwattr $C$DW$330, DW_AT_location[DW_OP_regx 0x4e]
3745$C$DW$331 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R19_b3")
3746 .dwattr $C$DW$331, DW_AT_location[DW_OP_regx 0x4f]
3747$C$DW$332 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R20_b0")
3748 .dwattr $C$DW$332, DW_AT_location[DW_OP_regx 0x50]
3749$C$DW$333 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R20_b1")
3750 .dwattr $C$DW$333, DW_AT_location[DW_OP_regx 0x51]
3751$C$DW$334 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R20_b2")
3752 .dwattr $C$DW$334, DW_AT_location[DW_OP_regx 0x52]
3753$C$DW$335 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R20_b3")
3754 .dwattr $C$DW$335, DW_AT_location[DW_OP_regx 0x53]
3755$C$DW$336 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R21_b0")
3756 .dwattr $C$DW$336, DW_AT_location[DW_OP_regx 0x54]
3757$C$DW$337 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R21_b1")
3758 .dwattr $C$DW$337, DW_AT_location[DW_OP_regx 0x55]
3759$C$DW$338 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R21_b2")
3760 .dwattr $C$DW$338, DW_AT_location[DW_OP_regx 0x56]
3761$C$DW$339 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R21_b3")
3762 .dwattr $C$DW$339, DW_AT_location[DW_OP_regx 0x57]
3763$C$DW$340 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R22_b0")
3764 .dwattr $C$DW$340, DW_AT_location[DW_OP_regx 0x58]
3765$C$DW$341 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R22_b1")
3766 .dwattr $C$DW$341, DW_AT_location[DW_OP_regx 0x59]
3767$C$DW$342 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R22_b2")
3768 .dwattr $C$DW$342, DW_AT_location[DW_OP_regx 0x5a]
3769$C$DW$343 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R22_b3")
3770 .dwattr $C$DW$343, DW_AT_location[DW_OP_regx 0x5b]
3771$C$DW$344 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R23_b0")
3772 .dwattr $C$DW$344, DW_AT_location[DW_OP_regx 0x5c]
3773$C$DW$345 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R23_b1")
3774 .dwattr $C$DW$345, DW_AT_location[DW_OP_regx 0x5d]
3775$C$DW$346 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R23_b2")
3776 .dwattr $C$DW$346, DW_AT_location[DW_OP_regx 0x5e]
3777$C$DW$347 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R23_b3")
3778 .dwattr $C$DW$347, DW_AT_location[DW_OP_regx 0x5f]
3779$C$DW$348 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R24_b0")
3780 .dwattr $C$DW$348, DW_AT_location[DW_OP_regx 0x60]
3781$C$DW$349 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R24_b1")
3782 .dwattr $C$DW$349, DW_AT_location[DW_OP_regx 0x61]
3783$C$DW$350 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R24_b2")
3784 .dwattr $C$DW$350, DW_AT_location[DW_OP_regx 0x62]
3785$C$DW$351 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R24_b3")
3786 .dwattr $C$DW$351, DW_AT_location[DW_OP_regx 0x63]
3787$C$DW$352 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R25_b0")
3788 .dwattr $C$DW$352, DW_AT_location[DW_OP_regx 0x64]
3789$C$DW$353 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R25_b1")
3790 .dwattr $C$DW$353, DW_AT_location[DW_OP_regx 0x65]
3791$C$DW$354 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R25_b2")
3792 .dwattr $C$DW$354, DW_AT_location[DW_OP_regx 0x66]
3793$C$DW$355 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R25_b3")
3794 .dwattr $C$DW$355, DW_AT_location[DW_OP_regx 0x67]
3795$C$DW$356 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R26_b0")
3796 .dwattr $C$DW$356, DW_AT_location[DW_OP_regx 0x68]
3797$C$DW$357 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R26_b1")
3798 .dwattr $C$DW$357, DW_AT_location[DW_OP_regx 0x69]
3799$C$DW$358 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R26_b2")
3800 .dwattr $C$DW$358, DW_AT_location[DW_OP_regx 0x6a]
3801$C$DW$359 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R26_b3")
3802 .dwattr $C$DW$359, DW_AT_location[DW_OP_regx 0x6b]
3803$C$DW$360 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R27_b0")
3804 .dwattr $C$DW$360, DW_AT_location[DW_OP_regx 0x6c]
3805$C$DW$361 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R27_b1")
3806 .dwattr $C$DW$361, DW_AT_location[DW_OP_regx 0x6d]
3807$C$DW$362 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R27_b2")
3808 .dwattr $C$DW$362, DW_AT_location[DW_OP_regx 0x6e]
3809$C$DW$363 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R27_b3")
3810 .dwattr $C$DW$363, DW_AT_location[DW_OP_regx 0x6f]
3811$C$DW$364 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R28_b0")
3812 .dwattr $C$DW$364, DW_AT_location[DW_OP_regx 0x70]
3813$C$DW$365 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R28_b1")
3814 .dwattr $C$DW$365, DW_AT_location[DW_OP_regx 0x71]
3815$C$DW$366 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R28_b2")
3816 .dwattr $C$DW$366, DW_AT_location[DW_OP_regx 0x72]
3817$C$DW$367 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R28_b3")
3818 .dwattr $C$DW$367, DW_AT_location[DW_OP_regx 0x73]
3819$C$DW$368 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R29_b0")
3820 .dwattr $C$DW$368, DW_AT_location[DW_OP_regx 0x74]
3821$C$DW$369 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R29_b1")
3822 .dwattr $C$DW$369, DW_AT_location[DW_OP_regx 0x75]
3823$C$DW$370 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R29_b2")
3824 .dwattr $C$DW$370, DW_AT_location[DW_OP_regx 0x76]
3825$C$DW$371 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R29_b3")
3826 .dwattr $C$DW$371, DW_AT_location[DW_OP_regx 0x77]
3827$C$DW$372 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R30_b0")
3828 .dwattr $C$DW$372, DW_AT_location[DW_OP_regx 0x78]
3829$C$DW$373 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R30_b1")
3830 .dwattr $C$DW$373, DW_AT_location[DW_OP_regx 0x79]
3831$C$DW$374 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R30_b2")
3832 .dwattr $C$DW$374, DW_AT_location[DW_OP_regx 0x7a]
3833$C$DW$375 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R30_b3")
3834 .dwattr $C$DW$375, DW_AT_location[DW_OP_regx 0x7b]
3835$C$DW$376 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R31_b0")
3836 .dwattr $C$DW$376, DW_AT_location[DW_OP_regx 0x7c]
3837$C$DW$377 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R31_b1")
3838 .dwattr $C$DW$377, DW_AT_location[DW_OP_regx 0x7d]
3839$C$DW$378 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R31_b2")
3840 .dwattr $C$DW$378, DW_AT_location[DW_OP_regx 0x7e]
3841$C$DW$379 .dwtag DW_TAG_TI_assign_register, DW_AT_name("R31_b3")
3842 .dwattr $C$DW$379, DW_AT_location[DW_OP_regx 0x7f]
3843 .dwendtag $C$DW$CU
3844
diff --git a/PRU_ADS8688_Controller/gen/PRU_ADS8688_Controller.map b/PRU_ADS8688_Controller/gen/PRU_ADS8688_Controller.map
new file mode 100644
index 0000000..a6ef12a
--- /dev/null
+++ b/PRU_ADS8688_Controller/gen/PRU_ADS8688_Controller.map
@@ -0,0 +1,293 @@
1******************************************************************************
2 PRU Linker Unix v2.1.4
3******************************************************************************
4>> Linked Wed Nov 22 12:19:17 2017
5
6OUTPUT FILE NAME: <gen/PRU_ADS8688_Controller.out>
7ENTRY POINT SYMBOL: "_c_int00_noinit_noargs_noexit" address: 00000000
8
9
10MEMORY CONFIGURATION
11
12 name origin length used unused attr fill
13---------------------- -------- --------- -------- -------- ---- --------
14PAGE 0:
15 PRU_IMEM 00000000 00002000 00000584 00001a7c RWIX
16
17PAGE 1:
18 PRU_DMEM_0_1 00000000 00002000 00000204 00001dfc RWIX
19 PRU_DMEM_1_0 00002000 00002000 00000000 00002000 RWIX
20
21PAGE 2:
22 PRU_SHAREDMEM 00010000 00003000 00000000 00003000 RWIX
23 PRU_INTC 00020000 00001504 00000000 00001504 RWIX
24 PRU_CFG 00026000 00000044 00000044 00000000 RWIX
25 PRU_UART 00028000 00000038 00000000 00000038 RWIX
26 PRU_IEP 0002e000 0000031c 00000000 0000031c RWIX
27 PRU_ECAP 00030000 00000060 00000000 00000060 RWIX
28 RSVD27 00032000 00000100 00000000 00000100 RWIX
29 RSVD21 00032400 00000100 00000000 00000100 RWIX
30 L3OCMC 40000000 00010000 00000000 00010000 RWIX
31 MCASP0_DMA 46000000 00000100 00000000 00000100 RWIX
32 UART1 48022000 00000088 00000000 00000088 RWIX
33 UART2 48024000 00000088 00000000 00000088 RWIX
34 I2C1 4802a000 000000d8 00000000 000000d8 RWIX
35 MCSPI0 48030000 000001a4 00000000 000001a4 RWIX
36 DMTIMER2 48040000 0000005c 00000000 0000005c RWIX
37 MMCHS0 48060000 00000300 00000000 00000300 RWIX
38 MBX0 480c8000 00000140 00000000 00000140 RWIX
39 SPINLOCK 480ca000 00000880 00000000 00000880 RWIX
40 I2C2 4819c000 000000d8 00000000 000000d8 RWIX
41 MCSPI1 481a0000 000001a4 00000000 000001a4 RWIX
42 DCAN0 481cc000 000001e8 00000000 000001e8 RWIX
43 DCAN1 481d0000 000001e8 00000000 000001e8 RWIX
44 PWMSS0 48300000 000002c4 00000000 000002c4 RWIX
45 PWMSS1 48302000 000002c4 00000000 000002c4 RWIX
46 PWMSS2 48304000 000002c4 00000000 000002c4 RWIX
47 RSVD13 48310000 00000100 00000000 00000100 RWIX
48 RSVD10 48318000 00000100 00000000 00000100 RWIX
49 TPCC 49000000 00001098 00000000 00001098 RWIX
50 GEMAC 4a100000 0000128c 00000000 0000128c RWIX
51 DDR 80000000 1f800000 00000000 1f800000 RWIX
52 PRUADC_DDR_CARVEOUT 9f800000 00800000 00000000 00800000 RWIX
53
54
55SECTION ALLOCATION MAP
56
57 output attributes/
58section page origin length input sections
59-------- ---- ---------- ---------- ----------------
60.text:_c_int00*
61* 0 00000000 00000014
62 00000000 00000014 rtspruv3_le.lib : boot_special.obj (.text:_c_int00_noinit_noargs_noexit)
63
64.text 0 00000014 00000570
65 00000014 00000288 PRU_ADS8688_Controller.object (.text:main)
66 0000029c 00000114 rtspruv3_le.lib : divu_c.obj (.text:__pruabi_divu)
67 000003b0 00000100 PRU_ADS8688_Controller.object (.text:adc_init)
68 000004b0 00000048 PRU_ADS8688_Controller.object (.text:send_command)
69 000004f8 0000003c PRU_ADS8688_Controller.object (.text:receive_data)
70 00000534 00000034 rtspruv3_le.lib : memcpy.obj (.text)
71 00000568 0000000c PRU_ADS8688_Controller.object (.text:send_delay)
72 00000574 00000008 rtspruv3_le.lib : exit.obj (.text:abort)
73 0000057c 00000008 : exit.obj (.text:loader_exit)
74
75.stack 1 00000000 00000100 UNINITIALIZED
76 00000000 00000004 rtspruv3_le.lib : boot.obj (.stack)
77 00000004 000000fc --HOLE--
78
79.bss 1 00000100 000000f0 UNINITIALIZED
80 00000100 000000c0 (.common:chan_data_temp)
81 000001c0 00000018 (.common:config_buf)
82 000001d8 00000018 (.common:data_buf)
83
84.cinit 1 00000000 00000000 UNINITIALIZED
85
86.resource_table
87* 1 000001f0 00000014
88 000001f0 00000014 PRU_ADS8688_Controller.object (.resource_table:retain)
89
90.creg.PRU_CFG.noload.near
91* 2 00026000 00000044 NOLOAD SECTION
92 00026000 00000044 PRU_ADS8688_Controller.object (.creg.PRU_CFG.noload.near)
93
94.creg.PRU_CFG.near
95* 2 00026044 00000000 UNINITIALIZED
96
97.creg.PRU_CFG.noload.far
98* 2 00026044 00000000 NOLOAD SECTION
99
100.creg.PRU_CFG.far
101* 2 00026044 00000000 UNINITIALIZED
102
103
104SEGMENT ATTRIBUTES
105
106 id tag seg value
107 -- --- --- -----
108 0 PHA_PAGE 1 1
109 1 PHA_PAGE 2 1
110
111
112GLOBAL SYMBOLS: SORTED ALPHABETICALLY BY Name
113
114page address name
115---- ------- ----
1160 0000057c C$$EXIT
1172 00026000 CT_CFG
118abs 481cc000 __PRU_CREG_BASE_DCAN0
119abs 481d0000 __PRU_CREG_BASE_DCAN1
120abs 80000000 __PRU_CREG_BASE_DDR
121abs 48040000 __PRU_CREG_BASE_DMTIMER2
122abs 4a100000 __PRU_CREG_BASE_GEMAC
123abs 4802a000 __PRU_CREG_BASE_I2C1
124abs 4819c000 __PRU_CREG_BASE_I2C2
125abs 40000000 __PRU_CREG_BASE_L3OCMC
126abs 480c8000 __PRU_CREG_BASE_MBX0
127abs 46000000 __PRU_CREG_BASE_MCASP0_DMA
128abs 48030000 __PRU_CREG_BASE_MCSPI0
129abs 481a0000 __PRU_CREG_BASE_MCSPI1
130abs 48060000 __PRU_CREG_BASE_MMCHS0
131abs 00026000 __PRU_CREG_BASE_PRU_CFG
132abs 00000000 __PRU_CREG_BASE_PRU_DMEM_0_1
133abs 00002000 __PRU_CREG_BASE_PRU_DMEM_1_0
134abs 00030000 __PRU_CREG_BASE_PRU_ECAP
135abs 0002e000 __PRU_CREG_BASE_PRU_IEP
136abs 00020000 __PRU_CREG_BASE_PRU_INTC
137abs 00010000 __PRU_CREG_BASE_PRU_SHAREDMEM
138abs 00028000 __PRU_CREG_BASE_PRU_UART
139abs 48300000 __PRU_CREG_BASE_PWMSS0
140abs 48302000 __PRU_CREG_BASE_PWMSS1
141abs 48304000 __PRU_CREG_BASE_PWMSS2
142abs 48318000 __PRU_CREG_BASE_RSVD10
143abs 48310000 __PRU_CREG_BASE_RSVD13
144abs 00032400 __PRU_CREG_BASE_RSVD21
145abs 00032000 __PRU_CREG_BASE_RSVD27
146abs 480ca000 __PRU_CREG_BASE_SPINLOCK
147abs 49000000 __PRU_CREG_BASE_TPCC
148abs 48022000 __PRU_CREG_BASE_UART1
149abs 48024000 __PRU_CREG_BASE_UART2
150abs 0000000e __PRU_CREG_DCAN0
151abs 0000000f __PRU_CREG_DCAN1
152abs 0000001f __PRU_CREG_DDR
153abs 00000001 __PRU_CREG_DMTIMER2
154abs 00000009 __PRU_CREG_GEMAC
155abs 00000002 __PRU_CREG_I2C1
156abs 00000011 __PRU_CREG_I2C2
157abs 0000001e __PRU_CREG_L3OCMC
158abs 00000016 __PRU_CREG_MBX0
159abs 00000008 __PRU_CREG_MCASP0_DMA
160abs 00000006 __PRU_CREG_MCSPI0
161abs 00000010 __PRU_CREG_MCSPI1
162abs 00000005 __PRU_CREG_MMCHS0
163abs 00000004 __PRU_CREG_PRU_CFG
164abs 00000018 __PRU_CREG_PRU_DMEM_0_1
165abs 00000019 __PRU_CREG_PRU_DMEM_1_0
166abs 00000003 __PRU_CREG_PRU_ECAP
167abs 0000001a __PRU_CREG_PRU_IEP
168abs 00000000 __PRU_CREG_PRU_INTC
169abs 0000001c __PRU_CREG_PRU_SHAREDMEM
170abs 00000007 __PRU_CREG_PRU_UART
171abs 00000012 __PRU_CREG_PWMSS0
172abs 00000013 __PRU_CREG_PWMSS1
173abs 00000014 __PRU_CREG_PWMSS2
174abs 0000000a __PRU_CREG_RSVD10
175abs 0000000d __PRU_CREG_RSVD13
176abs 00000015 __PRU_CREG_RSVD21
177abs 0000001b __PRU_CREG_RSVD27
178abs 00000017 __PRU_CREG_SPINLOCK
179abs 0000001d __PRU_CREG_TPCC
180abs 0000000b __PRU_CREG_UART1
181abs 0000000c __PRU_CREG_UART2
1821 00000100 __TI_STACK_END
183abs 00000100 __TI_STACK_SIZE
184abs ffffffff __binit__
185abs ffffffff __c_args__
1860 0000029c __pruabi_divu
1870 00000000 _c_int00_noinit_noargs_noexit
1881 00000000 _stack
1890 00000574 abort
1900 000003b0 adc_init
191abs ffffffff binit
1921 00000100 chan_data_temp
1931 000001c0 config_buf
1941 000001d8 data_buf
1950 00000014 main
1960 00000534 memcpy
1971 000001f0 pru_remoteproc_ResourceTable
1980 000004f8 receive_data
1990 000004b0 send_command
2000 00000568 send_delay
201
202
203GLOBAL SYMBOLS: SORTED BY Symbol Address
204
205page address name
206---- ------- ----
2070 00000000 _c_int00_noinit_noargs_noexit
2080 00000014 main
2090 0000029c __pruabi_divu
2100 000003b0 adc_init
2110 000004b0 send_command
2120 000004f8 receive_data
2130 00000534 memcpy
2140 00000568 send_delay
2150 00000574 abort
2160 0000057c C$$EXIT
2171 00000000 _stack
2181 00000100 __TI_STACK_END
2191 00000100 chan_data_temp
2201 000001c0 config_buf
2211 000001d8 data_buf
2221 000001f0 pru_remoteproc_ResourceTable
2232 00026000 CT_CFG
224abs 00000000 __PRU_CREG_BASE_PRU_DMEM_0_1
225abs 00000000 __PRU_CREG_PRU_INTC
226abs 00000001 __PRU_CREG_DMTIMER2
227abs 00000002 __PRU_CREG_I2C1
228abs 00000003 __PRU_CREG_PRU_ECAP
229abs 00000004 __PRU_CREG_PRU_CFG
230abs 00000005 __PRU_CREG_MMCHS0
231abs 00000006 __PRU_CREG_MCSPI0
232abs 00000007 __PRU_CREG_PRU_UART
233abs 00000008 __PRU_CREG_MCASP0_DMA
234abs 00000009 __PRU_CREG_GEMAC
235abs 0000000a __PRU_CREG_RSVD10
236abs 0000000b __PRU_CREG_UART1
237abs 0000000c __PRU_CREG_UART2
238abs 0000000d __PRU_CREG_RSVD13
239abs 0000000e __PRU_CREG_DCAN0
240abs 0000000f __PRU_CREG_DCAN1
241abs 00000010 __PRU_CREG_MCSPI1
242abs 00000011 __PRU_CREG_I2C2
243abs 00000012 __PRU_CREG_PWMSS0
244abs 00000013 __PRU_CREG_PWMSS1
245abs 00000014 __PRU_CREG_PWMSS2
246abs 00000015 __PRU_CREG_RSVD21
247abs 00000016 __PRU_CREG_MBX0
248abs 00000017 __PRU_CREG_SPINLOCK
249abs 00000018 __PRU_CREG_PRU_DMEM_0_1
250abs 00000019 __PRU_CREG_PRU_DMEM_1_0
251abs 0000001a __PRU_CREG_PRU_IEP
252abs 0000001b __PRU_CREG_RSVD27
253abs 0000001c __PRU_CREG_PRU_SHAREDMEM
254abs 0000001d __PRU_CREG_TPCC
255abs 0000001e __PRU_CREG_L3OCMC
256abs 0000001f __PRU_CREG_DDR
257abs 00000100 __TI_STACK_SIZE
258abs 00002000 __PRU_CREG_BASE_PRU_DMEM_1_0
259abs 00010000 __PRU_CREG_BASE_PRU_SHAREDMEM
260abs 00020000 __PRU_CREG_BASE_PRU_INTC
261abs 00026000 __PRU_CREG_BASE_PRU_CFG
262abs 00028000 __PRU_CREG_BASE_PRU_UART
263abs 0002e000 __PRU_CREG_BASE_PRU_IEP
264abs 00030000 __PRU_CREG_BASE_PRU_ECAP
265abs 00032000 __PRU_CREG_BASE_RSVD27
266abs 00032400 __PRU_CREG_BASE_RSVD21
267abs 40000000 __PRU_CREG_BASE_L3OCMC
268abs 46000000 __PRU_CREG_BASE_MCASP0_DMA
269abs 48022000 __PRU_CREG_BASE_UART1
270abs 48024000 __PRU_CREG_BASE_UART2
271abs 4802a000 __PRU_CREG_BASE_I2C1
272abs 48030000 __PRU_CREG_BASE_MCSPI0
273abs 48040000 __PRU_CREG_BASE_DMTIMER2
274abs 48060000 __PRU_CREG_BASE_MMCHS0
275abs 480c8000 __PRU_CREG_BASE_MBX0
276abs 480ca000 __PRU_CREG_BASE_SPINLOCK
277abs 4819c000 __PRU_CREG_BASE_I2C2
278abs 481a0000 __PRU_CREG_BASE_MCSPI1
279abs 481cc000 __PRU_CREG_BASE_DCAN0
280abs 481d0000 __PRU_CREG_BASE_DCAN1
281abs 48300000 __PRU_CREG_BASE_PWMSS0
282abs 48302000 __PRU_CREG_BASE_PWMSS1
283abs 48304000 __PRU_CREG_BASE_PWMSS2
284abs 48310000 __PRU_CREG_BASE_RSVD13
285abs 48318000 __PRU_CREG_BASE_RSVD10
286abs 49000000 __PRU_CREG_BASE_TPCC
287abs 4a100000 __PRU_CREG_BASE_GEMAC
288abs 80000000 __PRU_CREG_BASE_DDR
289abs ffffffff __binit__
290abs ffffffff __c_args__
291abs ffffffff binit
292
293[85 symbols]
diff --git a/PRU_ADS8688_Controller/gen/PRU_ADS8688_Controller.object b/PRU_ADS8688_Controller/gen/PRU_ADS8688_Controller.object
new file mode 100644
index 0000000..c471edf
--- /dev/null
+++ b/PRU_ADS8688_Controller/gen/PRU_ADS8688_Controller.object
Binary files differ
diff --git a/PRU_ADS8688_Controller/gen/PRU_ADS8688_Controller.out b/PRU_ADS8688_Controller/gen/PRU_ADS8688_Controller.out
new file mode 100644
index 0000000..1b7a1ca
--- /dev/null
+++ b/PRU_ADS8688_Controller/gen/PRU_ADS8688_Controller.out
Binary files differ
diff --git a/PRU_ADS8688_Controller/gen/PRU_ADS8688_Controller.pp b/PRU_ADS8688_Controller/gen/PRU_ADS8688_Controller.pp
new file mode 100644
index 0000000..9a49348
--- /dev/null
+++ b/PRU_ADS8688_Controller/gen/PRU_ADS8688_Controller.pp
@@ -0,0 +1,8 @@
1gen/PRU_ADS8688_Controller.object: PRU_ADS8688_Controller.c
2gen/PRU_ADS8688_Controller.object: /home/a0273976local/ti-cgt-pru_2.1.4/include/stdint.h
3gen/PRU_ADS8688_Controller.object: /home/a0273976local/pru-software-support-package/include/am335x/pru_cfg.h
4gen/PRU_ADS8688_Controller.object: /home/a0273976local/pru-software-support-package/include/am335x/pru_ctrl.h
5gen/PRU_ADS8688_Controller.object: resource_table_empty.h
6gen/PRU_ADS8688_Controller.object: /home/a0273976local/ti-cgt-pru_2.1.4/include/stddef.h
7gen/PRU_ADS8688_Controller.object: /home/a0273976local/pru-software-support-package/include/rsc_types.h
8gen/PRU_ADS8688_Controller.object: /home/a0273976local/pru-software-support-package/include/pru_types.h
diff --git a/PRU_ADS8688_Controller/resource_table_empty.h b/PRU_ADS8688_Controller/resource_table_empty.h
new file mode 100644
index 0000000..f298472
--- /dev/null
+++ b/PRU_ADS8688_Controller/resource_table_empty.h
@@ -0,0 +1,72 @@
1/*
2 * Copyright (C) 2017 Texas Instruments Incorporated - http://www.ti.com/
3 *
4 *
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions
7 * are met:
8 *
9 * * Redistributions of source code must retain the above copyright
10 * notice, this list of conditions and the following disclaimer.
11 *
12 * * Redistributions in binary form must reproduce the above copyright
13 * notice, this list of conditions and the following disclaimer in the
14 * documentation and/or other materials provided with the
15 * distribution.
16 *
17 * * Neither the name of Texas Instruments Incorporated nor the names of
18 * its contributors may be used to endorse or promote products derived
19 * from this software without specific prior written permission.
20 *
21 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
22 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
23 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
24 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
25 * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
26 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
27 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
28 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
29 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
30 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
31 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
32 */
33
34/*
35 * ======== resource_table_empty.h ========
36 *
37 * Define the resource table entries for all PRU cores. This will be
38 * incorporated into corresponding base images, and used by the remoteproc
39 * on the host-side to allocated/reserve resources. Note the remoteproc
40 * driver requires that all PRU firmware be built with a resource table.
41 *
42 * This file contains an empty resource table. It can be used either as:
43 *
44 * 1) A template, or
45 * 2) As-is if a PRU application does not need to configure PRU_INTC
46 * or interact with the rpmsg driver
47 *
48 */
49
50#ifndef _RSC_TABLE_PRU_H_
51#define _RSC_TABLE_PRU_H_
52
53#include <stddef.h>
54#include <rsc_types.h>
55
56struct my_resource_table {
57 struct resource_table base;
58
59 uint32_t offset[1]; /* Should match 'num' in actual definition */
60};
61
62#pragma DATA_SECTION(pru_remoteproc_ResourceTable, ".resource_table")
63#pragma RETAIN(pru_remoteproc_ResourceTable)
64struct my_resource_table pru_remoteproc_ResourceTable = {
65 1, /* we're the first version that implements this */
66 0, /* number of entries in the table */
67 0, 0, /* reserved, must be zero */
68 0, /* offset[0] */
69};
70
71#endif /* _RSC_TABLE_PRU_H_ */
72
diff --git a/PRU_ADS8688_Interface/.PRU_ADS8688_Interface.asm.swp b/PRU_ADS8688_Interface/.PRU_ADS8688_Interface.asm.swp
new file mode 100644
index 0000000..2e000ea
--- /dev/null
+++ b/PRU_ADS8688_Interface/.PRU_ADS8688_Interface.asm.swp
Binary files differ
diff --git a/PRU_ADS8688_Interface/AM335x_PRU.cmd b/PRU_ADS8688_Interface/AM335x_PRU.cmd
new file mode 100644
index 0000000..d697474
--- /dev/null
+++ b/PRU_ADS8688_Interface/AM335x_PRU.cmd
@@ -0,0 +1,117 @@
1/*
2 * Copyright (C) 2017 Texas Instruments Incorporated - http://www.ti.com/
3 *
4 *
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions
7 * are met:
8 *
9 * * Redistributions of source code must retain the above copyright
10 * notice, this list of conditions and the following disclaimer.
11 *
12 * * Redistributions in binary form must reproduce the above copyright
13 * notice, this list of conditions and the following disclaimer in the
14 * documentation and/or other materials provided with the
15 * distribution.
16 *
17 * * Neither the name of Texas Instruments Incorporated nor the names of
18 * its contributors may be used to endorse or promote products derived
19 * from this software without specific prior written permission.
20 *
21 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
22 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
23 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
24 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
25 * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
26 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
27 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
28 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
29 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
30 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
31 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
32 *
33 *
34 * AM335x_PRU.cmd
35 * Description: This file is a linker command file that can be used for
36 * linking PRU programs built with the C compiler and the
37 * resulting .out file on an AM335x device.
38 */
39
40/* Link using C conventions */
41-cr
42
43/* Specify the System Memory Map */
44MEMORY
45{
46 PAGE 0:
47 PRU_IMEM : org = 0x00000000 len = 0x00002000 /* 8kB PRU0 Instruction RAM */
48
49 PAGE 1:
50
51 /* RAM */
52
53 PRU_DMEM_0_1 : org = 0x00000000 len = 0x00002000 CREGISTER=24 /* 8kB PRU Data RAM 0_1 */
54 PRU_DMEM_1_0 : org = 0x00002000 len = 0x00002000 CREGISTER=25 /* 8kB PRU Data RAM 1_0 */
55
56 PAGE 2:
57 PRU_SHAREDMEM : org = 0x00010000 len = 0x00003000 CREGISTER=28 /* 12kB Shared RAM */
58
59 DDR : org = 0x80000000 len = 0x00000100 CREGISTER=31
60 L3OCMC : org = 0x40000000 len = 0x00010000 CREGISTER=30
61
62
63 /* Peripherals */
64
65 PRU_CFG : org = 0x00026000 len = 0x00000044 CREGISTER=4
66 PRU_ECAP : org = 0x00030000 len = 0x00000060 CREGISTER=3
67 PRU_IEP : org = 0x0002E000 len = 0x0000031C CREGISTER=26
68 PRU_INTC : org = 0x00020000 len = 0x00001504 CREGISTER=0
69 PRU_UART : org = 0x00028000 len = 0x00000038 CREGISTER=7
70
71 DCAN0 : org = 0x481CC000 len = 0x000001E8 CREGISTER=14
72 DCAN1 : org = 0x481D0000 len = 0x000001E8 CREGISTER=15
73 DMTIMER2 : org = 0x48040000 len = 0x0000005C CREGISTER=1
74 PWMSS0 : org = 0x48300000 len = 0x000002C4 CREGISTER=18
75 PWMSS1 : org = 0x48302000 len = 0x000002C4 CREGISTER=19
76 PWMSS2 : org = 0x48304000 len = 0x000002C4 CREGISTER=20
77 GEMAC : org = 0x4A100000 len = 0x0000128C CREGISTER=9
78 I2C1 : org = 0x4802A000 len = 0x000000D8 CREGISTER=2
79 I2C2 : org = 0x4819C000 len = 0x000000D8 CREGISTER=17
80 MBX0 : org = 0x480C8000 len = 0x00000140 CREGISTER=22
81 MCASP0_DMA : org = 0x46000000 len = 0x00000100 CREGISTER=8
82 MCSPI0 : org = 0x48030000 len = 0x000001A4 CREGISTER=6
83 MCSPI1 : org = 0x481A0000 len = 0x000001A4 CREGISTER=16
84 MMCHS0 : org = 0x48060000 len = 0x00000300 CREGISTER=5
85 SPINLOCK : org = 0x480CA000 len = 0x00000880 CREGISTER=23
86 TPCC : org = 0x49000000 len = 0x00001098 CREGISTER=29
87 UART1 : org = 0x48022000 len = 0x00000088 CREGISTER=11
88 UART2 : org = 0x48024000 len = 0x00000088 CREGISTER=12
89
90 RSVD10 : org = 0x48318000 len = 0x00000100 CREGISTER=10
91 RSVD13 : org = 0x48310000 len = 0x00000100 CREGISTER=13
92 RSVD21 : org = 0x00032400 len = 0x00000100 CREGISTER=21
93 RSVD27 : org = 0x00032000 len = 0x00000100 CREGISTER=27
94
95}
96
97/* Specify the sections allocation into memory */
98SECTIONS {
99 /* Forces _c_int00 to the start of PRU IRAM. Not necessary when loading
100 an ELF file, but useful when loading a binary */
101 .text:_c_int00* > 0x0, PAGE 0
102
103 .text > PRU_IMEM, PAGE 0
104 .stack > PRU_DMEM_0_1, PAGE 1
105 .bss > PRU_DMEM_0_1, PAGE 1
106 .cio > PRU_DMEM_0_1, PAGE 1
107 .data > PRU_DMEM_0_1, PAGE 1
108 .switch > PRU_DMEM_0_1, PAGE 1
109 .sysmem > PRU_DMEM_0_1, PAGE 1
110 .cinit > PRU_DMEM_0_1, PAGE 1
111 .rodata > PRU_DMEM_0_1, PAGE 1
112 .rofardata > PRU_DMEM_0_1, PAGE 1
113 .farbss > PRU_DMEM_0_1, PAGE 1
114 .fardata > PRU_DMEM_0_1, PAGE 1
115
116 .resource_table > PRU_DMEM_0_1, PAGE 1
117}
diff --git a/PRU_ADS8688_Interface/Makefile b/PRU_ADS8688_Interface/Makefile
new file mode 100644
index 0000000..f2b8cc3
--- /dev/null
+++ b/PRU_ADS8688_Interface/Makefile
@@ -0,0 +1,125 @@
1# PRU_CGT environment variable must point to the TI PRU code gen tools directory. E.g.:
2#(Desktop Linux) export PRU_CGT=/path/to/pru/code/gen/tools/ti-cgt-pru_2.x.y
3#(Windows) set PRU_CGT=C:/path/to/pru/code/gen/tools/ti-cgt-pru_2.x.y
4#(ARM Linux*) export PRU_CGT=/usr/share/ti/cgt-pru
5#
6# *ARM Linux also needs to create a symbolic link to the /usr/bin/ directory in
7# order to use the same Makefile
8#(ARM Linux) ln -s /usr/bin/ /usr/share/ti/cgt-pru/bin
9
10ifndef PRU_CGT
11define ERROR_BODY
12
13*******************************************************************************
14PRU_CGT environment variable is not set. Examples given:
15(Desktop Linux) export PRU_CGT=/path/to/pru/code/gen/tools/ti-cgt-pru_2.1.2
16(Windows) set PRU_CGT=C:/path/to/pru/code/gen/tools/ti-cgt-pru_2.1.2
17(ARM Linux*) export PRU_CGT=/usr/share/ti/cgt-pru
18
19*ARM Linux also needs to create a symbolic link to the /usr/bin/ directory in
20order to use the same Makefile
21(ARM Linux) ln -s /usr/bin/ /usr/share/ti/cgt-pru/bin
22*******************************************************************************
23
24endef
25$(error $(ERROR_BODY))
26endif
27
28# PRU_SSP environment variable must point to the PRU Software Support Package. E.g.:
29#(Desktop Linux) export PRU_SSP=/path/to/pru_software_support_package
30#(Windows) set PRU_SSP=C:/path/to/pru_software_support_package
31#(ARM Linux*) export PRU_SSP=/path/to/pru_software_support_package
32
33ifndef PRU_SSP
34define ERROR_BODY
35
36*******************************************************************************
37PRU_SSP environment variable must point to the PRU Software Support Package. E.g.:
38(Desktop Linux) export PRU_SSP=/path/to/pru_software_support_package
39(Windows) set PRU_SSP=C:/path/to/pru_software_support_package
40(ARM Linux*) export PRU_SSP=/path/to/pru_software_support_package
41PRU_CGT environment variable is not set. Examples given:
42*******************************************************************************
43
44endef
45$(error $(ERROR_BODY))
46endif
47
48MKFILE_PATH := $(abspath $(lastword $(MAKEFILE_LIST)))
49CURRENT_DIR := $(notdir $(patsubst %/,%,$(dir $(MKFILE_PATH))))
50PROJ_NAME=$(CURRENT_DIR)
51LINKER_COMMAND_FILE=./AM335x_PRU.cmd
52LIBS=--library=$(PRU_SSP)/lib/rpmsg_lib.lib
53INCLUDE=--include_path=$(PRU_SSP)/include --include_path=$(PRU_SSP)/include/am335x
54STACK_SIZE=0x100
55HEAP_SIZE=0x100
56GEN_DIR=gen
57
58#Common compiler and linker flags (Defined in 'PRU Optimizing C/C++ Compiler User's Guide)
59CFLAGS=-v3 -o2 --display_error_number --endian=little --hardware_mac=on --asm_directory=$(GEN_DIR) --obj_directory=$(GEN_DIR) --pp_directory=$(GEN_DIR) -ppd -ppa
60#Linker flags (Defined in 'PRU Optimizing C/C++ Compiler User's Guide)
61LFLAGS=--reread_libs --warn_sections --stack_size=$(STACK_SIZE) --heap_size=$(HEAP_SIZE)
62
63TARGET=$(GEN_DIR)/$(PROJ_NAME).out
64MAP=$(GEN_DIR)/$(PROJ_NAME).map
65OBJECTS=$(patsubst %.asm,$(GEN_DIR)/%.object,$(wildcard *.asm))
66OBJECTS+=$(patsubst %.c,$(GEN_DIR)/%.object,$(wildcard *.c))
67
68
69all: printStart $(TARGET) printEnd
70
71printStart:
72 @echo ''
73 @echo '************************************************************'
74 @echo 'Building project: $(PROJ_NAME)'
75
76printEnd:
77 @echo ''
78 @echo 'Output files can be found in the "$(GEN_DIR)" directory'
79 @echo ''
80 @echo 'Finished building project: $(PROJ_NAME)'
81 @echo '************************************************************'
82 @echo ''
83
84# Invokes the linker (-z flag) to make the .out file
85$(TARGET): $(OBJECTS) $(LINKER_COMMAND_FILE)
86 @echo ''
87 @echo 'Building target: $@'
88 @echo 'Invoking: PRU Linker'
89 $(PRU_CGT)/bin/clpru $(CFLAGS) -z -i$(PRU_CGT)/lib -i$(PRU_CGT)/include $(LFLAGS) -o $(TARGET) $(OBJECTS) -m$(MAP) $(LINKER_COMMAND_FILE) --library=libc.a $(LIBS)
90 @echo 'Finished building target: $@'
91
92# Invokes the compiler on all assembly files in the directory to create the object files
93$(GEN_DIR)/%.object: %.asm
94 @mkdir -p $(GEN_DIR)
95 @echo ''
96 @echo 'Building file: $<'
97 @echo 'Invoking: PRU Compiler'
98 $(PRU_CGT)/bin/clpru --include_path=$(PRU_CGT)/include $(INCLUDE) $(CFLAGS) -fe $@ $<
99
100# Invokes the compiler on all c files in the directory to create the object files
101$(GEN_DIR)/%.object: %.c
102 @mkdir -p $(GEN_DIR)
103 @echo ''
104 @echo 'Building file: $<'
105 @echo 'Invoking: PRU Compiler'
106 $(PRU_CGT)/bin/clpru -k --include_path=$(PRU_CGT)/include $(INCLUDE) $(CFLAGS) -fe $@ $<
107
108.PHONY: all clean
109
110# Remove the $(GEN_DIR) directory
111clean:
112 @echo ''
113 @echo '************************************************************'
114 @echo 'Cleaning project: $(PROJ_NAME)'
115 @echo ''
116 @echo 'Removing files in the "$(GEN_DIR)" directory'
117 @rm -rf $(GEN_DIR)
118 @echo ''
119 @echo 'Finished cleaning project: $(PROJ_NAME)'
120 @echo '************************************************************'
121 @echo ''
122
123# Includes the dependencies that the compiler creates (-ppd and -ppa flags)
124-include $(OBJECTS:%.object=%.pp)
125
diff --git a/PRU_ADS8688_Interface/PRU_ADS8688_Interface.asm b/PRU_ADS8688_Interface/PRU_ADS8688_Interface.asm
new file mode 100644
index 0000000..564b699
--- /dev/null
+++ b/PRU_ADS8688_Interface/PRU_ADS8688_Interface.asm
@@ -0,0 +1,342 @@
1;
2; Copyright (C) 2017 Texas Instruments Incorporated - http://www.ti.com/
3;
4;
5; Redistribution and use in source and binary forms, with or without
6; modification, are permitted provided that the following conditions
7; are met:
8;
9; * Redistributions of source code must retain the above copyright
10; notice, this list of conditions and the following disclaimer.
11;
12; * Redistributions in binary form must reproduce the above copyright
13; notice, this list of conditions and the following disclaimer in the
14; documentation and/or other materials provided with the
15; distribution.
16;
17; * Neither the name of Texas Instruments Incorporated nor the names of
18; its contributors may be used to endorse or promote products derived
19; from this software without specific prior written permission.
20;
21; THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
22; "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
23; LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
24; A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
25; OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
26; SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
27; LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
28; DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
29; THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
30; (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
31; OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
32
33; Resource table needed for remoteproc Linux driver
34 .global ||pru_remoteproc_ResourceTable||
35 .sect ".resource_table:retain", RW
36 .retain
37 .align 1
38 .elfsym ||pru_remoteproc_ResourceTable||,SYM_SIZE(20)
39||pru_remoteproc_ResourceTable||:
40 .bits 1,32 ; pru_remoteproc_ResourceTable.base.ver @ 0
41 .bits 0,32 ; pru_remoteproc_ResourceTable.base.num @ 32
42 .bits 0,32 ; pru_remoteproc_ResourceTable.base.reserved[0] @ 64
43 .bits 0,32 ; pru_remoteproc_ResourceTable.base.reserved[1] @ 96
44 .bits 0,32 ; pru_remoteproc_ResourceTable.offset[0] @ 128
45
46; Pins used to mimic the SPI interfaces
47sclk_pin .set 13
48cs12_pin .set 6
49cs34_pin .set 6
50cs56_pin .set 6
51mosi1_pin .set 7
52mosi2_pin .set 8
53mosi3_pin .set 9
54mosi4_pin .set 10
55mosi5_pin .set 11
56mosi6_pin .set 12
57miso1_pin .set 0
58miso2_pin .set 1
59miso3_pin .set 2
60miso4_pin .set 3
61miso5_pin .set 4
62miso6_pin .set 5
63
64; Request/response register bit mapping
65send_ready_bit .set 0
66send_ack_bit .set 1
67send_done_bit .set 2
68
69start_bit .set 0
70continuous_bit .set 1
71recv_ready_bit .set 2
72recv_ack_bit .set 3
73
74; Register to contain the worst case delay to check for overflow
75worst_delay_reg .set r6
76
77; Specific register numbers shared through the Scratchpads */
78status_reg .set r28
79request_reg .set r29
80adc1_config_reg .set r15
81adc2_config_reg .set r16
82adc3_config_reg .set r17
83adc4_config_reg .set r18
84adc5_config_reg .set r19
85adc6_config_reg .set r20
86cycle_count_reg .set r21
87adc1_result_reg .set r22
88adc2_result_reg .set r23
89adc3_result_reg .set r24
90adc4_result_reg .set r25
91adc5_result_reg .set r26
92adc6_result_reg .set r27
93
94; Macros to take the clock pin high and low
95 .sect ".text"
96clock_high .macro
97 set r30, r30, sclk_pin
98 .endm
99clock_low .macro
100 clr r30, r30, sclk_pin
101 .endm
102
103; Macro to poke the ADC configurations into specific bits (pins)
104config_bit .macro reg, bit, pin
105 qbbs label1?, reg, bit
106 jmp label2?
107label1?:
108 set r8, r8, pin
109label2?:
110 .endm
111; Macro to handle a configuration cycle
112config_cycle .macro bit
113 mov r8, r9
114 config_bit adc1_config_reg, bit, mosi1_pin
115 config_bit adc2_config_reg, bit, mosi2_pin
116 config_bit adc3_config_reg, bit, mosi3_pin
117 config_bit adc4_config_reg, bit, mosi4_pin
118 clock_high
119 config_bit adc5_config_reg, bit, mosi5_pin
120 config_bit adc6_config_reg, bit, mosi6_pin
121 mov r30, r8
122 nop
123 nop
124 nop
125 nop
126 clock_low
127 .endm
128
129; Macro to pick the ADC data from each specific bit (pin)
130read_bit .macro reg, bit, pin
131 qbbs label3?, r11, pin
132 jmp label4?
133label3?:
134 set reg, reg, bit
135label4?:
136 .endm
137; Macro to handle a read cycle
138read_cycle .macro bit
139 mov r11, r31
140 clock_low
141 read_bit adc1_result_reg, bit, miso1_pin
142 read_bit adc2_result_reg, bit, miso2_pin
143 read_bit adc3_result_reg, bit, miso3_pin
144 read_bit adc4_result_reg, bit, miso4_pin
145 nop
146 clock_high
147 read_bit adc5_result_reg, bit, miso5_pin
148 read_bit adc6_result_reg, bit, miso6_pin
149 nop
150 nop
151 nop
152 nop
153 .endm
154
155 .sect ".text:main"
156 .clink
157 .global ||main||
158
159||main||:
160 ; Set all pins high
161 LDI32 r30, 0xffffffff
162 ; Load the values used to set and clear all CS pins in a single cycle
163 ZERO &r13, 4
164 OR r13, r13, (1 << cs12_pin)
165 OR r13, r13, (1 << cs34_pin)
166 OR r13, r13, (1 << cs56_pin)
167 NOT r12, r13
168
169 ; r9 is used as a known starting point for creating the configuration cycle
170 ; need the SCLK pin to be high becuase when the data is pushed to the pins
171 ; the clock needs to be high
172 LDI32 r9, (1 << sclk_pin)
173
174 ; Load r6 with the worst case delay to check for overflow
175 LDI32 r6, 0x00ffffff
176
177 ; Configure cycle counter
178 ; Load r0 with PRU_CTRL registers offset
179 LDI32 r0, 0x24000
180 ; Clear the CTR_EN bit
181 LBBO &r1, r0, 0, 4
182 CLR r1, r1, 0x3
183 SBBO &r1, r0, 0, 4
184 ; Reset the COUNTER register to 0
185 LDI32 r3, 0x0
186 SBBO &r3, r0, 12, 4
187 ; Set the CTR_EN bit to kick off the cycle counter
188 LBBO &r1, r0, 0, 4
189 SET r1, r1, 0x3
190 SBBO &r1, r0, 0, 4
191
192 ; zero out the result registers
193 zero &adc1_result_reg, 24
194
195 ; clear the status register
196 ZERO &status_reg, 4
197 XOUT 11, &status_reg.b0, 4
198
199||$C$L1||:
200 .newblock
201 ; Set ready bit and clear ack bit and push to the scratchpad
202 CLR status_reg, status_reg, send_ack_bit
203 SET status_reg, status_reg, send_ready_bit
204 XOUT 11, &status_reg.b0, 4
205
206 ; Tight loop to check to check for start or continuous bit
207check_start:
208 XIN 11, &request_reg.b0, 4
209 QBBS continuous, request_reg, continuous_bit
210 QBBS start, request_reg, start_bit
211 JMP check_start
212
213 ; Continuous bit is set so we wait for the cycles between sample to expire
214continuous:
215 ; If continuous AND start bits are set then we reset the cycle counter
216 ; because this is the first iteration and we don't know where the cycle
217 ; counter is. If the start bit is clear then we jump down past the cycle
218 ; counter reset becuase the cycle counter contains the number of cycles
219 ; since the last sample
220 QBBC no_reset, request_reg, start_bit
221 ; reset cycle counter
222 zero &r3, 4
223 SBBO &r3, r0, 12, 4
224no_reset:
225 ; Pull in the new cycle count between samples value from the scratchpad
226 XIN 10, &cycle_count_reg.b0, 4
227 ; Get current cycle count
228 LBBO &r4, r0, 12, 4
229 ; Subtract current elapsed cycles from cycles between samples
230 SUB cycle_count_reg, cycle_count_reg, r4
231 ; Subtract cycles between getting the count and checking it
232 SUB cycle_count_reg, cycle_count_reg, 8
233 ; Check if the remaining count is even or odd
234 QBBC even, cycle_count_reg, 0
235 ; Subtract 2 more cycles if the remainging count is odd
236 SUB cycle_count_reg, cycle_count_reg, 2
237even:
238 ; Skip the wait if the counter has rolled over, otherwise we would wait
239 ; for more than 20 seconds for the counter to expire
240 QBLT reached, cycle_count_reg, worst_delay_reg
241 ; Wait until cycle count is reached
242not_reached:
243 SUB cycle_count_reg, cycle_count_reg, 2
244 QBLT not_reached, cycle_count_reg, 2
245reached:
246 ; Reset_cycle_counter
247 zero &r3, 4
248 SBBO &r3, r0, 12, 4
249
250start:
251 ; Pull the configurations for each ADC from the scratchpad registers
252 XIN 10, &adc1_config_reg.b0, 24
253
254 ; Clear the ready bit and set the ack bit
255 CLR status_reg, status_reg, send_ready_bit
256 SET status_reg, status_reg, send_ack_bit
257 XOUT 11, &status_reg.b0, 4
258
259 ; Take all CS low to start the acquisition
260 AND r30, r30, r12
261 ; Send the configuration data from the scratchpad registers one cycle at a time
262 config_cycle 15
263 config_cycle 14
264 config_cycle 13
265 config_cycle 12
266 config_cycle 11
267 config_cycle 10
268 config_cycle 9
269 config_cycle 8
270 config_cycle 7
271 config_cycle 6
272 config_cycle 5
273 config_cycle 4
274 config_cycle 3
275 config_cycle 2
276 config_cycle 1
277 config_cycle 0
278 nop
279 nop
280 nop
281 nop
282 nop
283 nop
284 nop
285 nop
286 nop
287 clock_high
288 nop
289 nop
290 nop
291 nop
292 nop
293 nop
294 nop
295 nop
296 ; Read the data from the ADCs and place it into the result registers one cycle at a time
297 read_cycle 15
298 read_cycle 14
299 read_cycle 13
300 read_cycle 12
301 read_cycle 11
302 read_cycle 10
303 read_cycle 9
304 read_cycle 8
305 read_cycle 7
306 read_cycle 6
307 read_cycle 5
308 read_cycle 4
309 read_cycle 3
310 read_cycle 2
311 read_cycle 1
312 read_cycle 0
313
314 ; Take all CS high
315 OR r30, r30, r13
316
317 ; Wait until the controller is ready for data
318check_ready:
319 XIN 11, &request_reg.b0, 4
320 QBBC check_ready, request_reg, recv_ready_bit
321
322 ; Controller is ready, put the result data in the scratchpad register
323 XOUT 12, &adc1_result_reg.b0, 24
324
325 ; Set the done bit
326 SET status_reg, status_reg, send_done_bit
327 XOUT 11, &status_reg.b0, 4
328
329 ; Wait until the controller acknowledges the data
330check_ack:
331 XIN 11, &request_reg.b0, 4
332 QBBC check_ack, request_reg, recv_ack_bit
333
334 ; Clear the done bit
335 CLR status_reg, status_reg, send_done_bit
336 XOUT 11, &status_reg.b0, 4
337
338 ; Clear the local result register for the next set of results
339 zero &adc1_result_reg, 24
340
341 ; Jump to the top of the loop
342 JMP ||$C$L1||
diff --git a/PRU_ADS8688_Interface/gen/PRU_ADS8688_Interface.map b/PRU_ADS8688_Interface/gen/PRU_ADS8688_Interface.map
new file mode 100644
index 0000000..694b421
--- /dev/null
+++ b/PRU_ADS8688_Interface/gen/PRU_ADS8688_Interface.map
@@ -0,0 +1,248 @@
1******************************************************************************
2 PRU Linker Unix v2.1.4
3******************************************************************************
4>> Linked Wed Nov 22 12:19:17 2017
5
6OUTPUT FILE NAME: <gen/PRU_ADS8688_Interface.out>
7ENTRY POINT SYMBOL: "_c_int00_noinit_noargs_noexit" address: 00000000
8
9
10MEMORY CONFIGURATION
11
12 name origin length used unused attr fill
13---------------------- -------- --------- -------- -------- ---- --------
14PAGE 0:
15 PRU_IMEM 00000000 00002000 00000e68 00001198 RWIX
16
17PAGE 1:
18 PRU_DMEM_0_1 00000000 00002000 00000114 00001eec RWIX
19 PRU_DMEM_1_0 00002000 00002000 00000000 00002000 RWIX
20
21PAGE 2:
22 PRU_SHAREDMEM 00010000 00003000 00000000 00003000 RWIX
23 PRU_INTC 00020000 00001504 00000000 00001504 RWIX
24 PRU_CFG 00026000 00000044 00000000 00000044 RWIX
25 PRU_UART 00028000 00000038 00000000 00000038 RWIX
26 PRU_IEP 0002e000 0000031c 00000000 0000031c RWIX
27 PRU_ECAP 00030000 00000060 00000000 00000060 RWIX
28 RSVD27 00032000 00000100 00000000 00000100 RWIX
29 RSVD21 00032400 00000100 00000000 00000100 RWIX
30 L3OCMC 40000000 00010000 00000000 00010000 RWIX
31 MCASP0_DMA 46000000 00000100 00000000 00000100 RWIX
32 UART1 48022000 00000088 00000000 00000088 RWIX
33 UART2 48024000 00000088 00000000 00000088 RWIX
34 I2C1 4802a000 000000d8 00000000 000000d8 RWIX
35 MCSPI0 48030000 000001a4 00000000 000001a4 RWIX
36 DMTIMER2 48040000 0000005c 00000000 0000005c RWIX
37 MMCHS0 48060000 00000300 00000000 00000300 RWIX
38 MBX0 480c8000 00000140 00000000 00000140 RWIX
39 SPINLOCK 480ca000 00000880 00000000 00000880 RWIX
40 I2C2 4819c000 000000d8 00000000 000000d8 RWIX
41 MCSPI1 481a0000 000001a4 00000000 000001a4 RWIX
42 DCAN0 481cc000 000001e8 00000000 000001e8 RWIX
43 DCAN1 481d0000 000001e8 00000000 000001e8 RWIX
44 PWMSS0 48300000 000002c4 00000000 000002c4 RWIX
45 PWMSS1 48302000 000002c4 00000000 000002c4 RWIX
46 PWMSS2 48304000 000002c4 00000000 000002c4 RWIX
47 RSVD13 48310000 00000100 00000000 00000100 RWIX
48 RSVD10 48318000 00000100 00000000 00000100 RWIX
49 TPCC 49000000 00001098 00000000 00001098 RWIX
50 GEMAC 4a100000 0000128c 00000000 0000128c RWIX
51 DDR 80000000 00000100 00000000 00000100 RWIX
52
53
54SECTION ALLOCATION MAP
55
56 output attributes/
57section page origin length input sections
58-------- ---- ---------- ---------- ----------------
59.text:_c_int00*
60* 0 00000000 00000014
61 00000000 00000014 rtspruv3_le.lib : boot_special.obj (.text:_c_int00_noinit_noargs_noexit)
62
63.text 0 00000014 00000e54
64 00000014 00000e44 PRU_ADS8688_Interface.object (.text:main)
65 00000e58 00000008 rtspruv3_le.lib : exit.obj (.text:abort)
66 00000e60 00000008 : exit.obj (.text:loader_exit)
67
68.stack 1 00000000 00000100 UNINITIALIZED
69 00000000 00000004 rtspruv3_le.lib : boot.obj (.stack)
70 00000004 000000fc --HOLE--
71
72.cinit 1 00000000 00000000 UNINITIALIZED
73
74.resource_table
75* 1 00000100 00000014
76 00000100 00000014 PRU_ADS8688_Interface.object (.resource_table:retain)
77
78
79SEGMENT ATTRIBUTES
80
81 id tag seg value
82 -- --- --- -----
83 0 PHA_PAGE 1 1
84 1 PHA_PAGE 2 1
85
86
87GLOBAL SYMBOLS: SORTED ALPHABETICALLY BY Name
88
89page address name
90---- ------- ----
910 00000e60 C$$EXIT
92abs 481cc000 __PRU_CREG_BASE_DCAN0
93abs 481d0000 __PRU_CREG_BASE_DCAN1
94abs 80000000 __PRU_CREG_BASE_DDR
95abs 48040000 __PRU_CREG_BASE_DMTIMER2
96abs 4a100000 __PRU_CREG_BASE_GEMAC
97abs 4802a000 __PRU_CREG_BASE_I2C1
98abs 4819c000 __PRU_CREG_BASE_I2C2
99abs 40000000 __PRU_CREG_BASE_L3OCMC
100abs 480c8000 __PRU_CREG_BASE_MBX0
101abs 46000000 __PRU_CREG_BASE_MCASP0_DMA
102abs 48030000 __PRU_CREG_BASE_MCSPI0
103abs 481a0000 __PRU_CREG_BASE_MCSPI1
104abs 48060000 __PRU_CREG_BASE_MMCHS0
105abs 00026000 __PRU_CREG_BASE_PRU_CFG
106abs 00000000 __PRU_CREG_BASE_PRU_DMEM_0_1
107abs 00002000 __PRU_CREG_BASE_PRU_DMEM_1_0
108abs 00030000 __PRU_CREG_BASE_PRU_ECAP
109abs 0002e000 __PRU_CREG_BASE_PRU_IEP
110abs 00020000 __PRU_CREG_BASE_PRU_INTC
111abs 00010000 __PRU_CREG_BASE_PRU_SHAREDMEM
112abs 00028000 __PRU_CREG_BASE_PRU_UART
113abs 48300000 __PRU_CREG_BASE_PWMSS0
114abs 48302000 __PRU_CREG_BASE_PWMSS1
115abs 48304000 __PRU_CREG_BASE_PWMSS2
116abs 48318000 __PRU_CREG_BASE_RSVD10
117abs 48310000 __PRU_CREG_BASE_RSVD13
118abs 00032400 __PRU_CREG_BASE_RSVD21
119abs 00032000 __PRU_CREG_BASE_RSVD27
120abs 480ca000 __PRU_CREG_BASE_SPINLOCK
121abs 49000000 __PRU_CREG_BASE_TPCC
122abs 48022000 __PRU_CREG_BASE_UART1
123abs 48024000 __PRU_CREG_BASE_UART2
124abs 0000000e __PRU_CREG_DCAN0
125abs 0000000f __PRU_CREG_DCAN1
126abs 0000001f __PRU_CREG_DDR
127abs 00000001 __PRU_CREG_DMTIMER2
128abs 00000009 __PRU_CREG_GEMAC
129abs 00000002 __PRU_CREG_I2C1
130abs 00000011 __PRU_CREG_I2C2
131abs 0000001e __PRU_CREG_L3OCMC
132abs 00000016 __PRU_CREG_MBX0
133abs 00000008 __PRU_CREG_MCASP0_DMA
134abs 00000006 __PRU_CREG_MCSPI0
135abs 00000010 __PRU_CREG_MCSPI1
136abs 00000005 __PRU_CREG_MMCHS0
137abs 00000004 __PRU_CREG_PRU_CFG
138abs 00000018 __PRU_CREG_PRU_DMEM_0_1
139abs 00000019 __PRU_CREG_PRU_DMEM_1_0
140abs 00000003 __PRU_CREG_PRU_ECAP
141abs 0000001a __PRU_CREG_PRU_IEP
142abs 00000000 __PRU_CREG_PRU_INTC
143abs 0000001c __PRU_CREG_PRU_SHAREDMEM
144abs 00000007 __PRU_CREG_PRU_UART
145abs 00000012 __PRU_CREG_PWMSS0
146abs 00000013 __PRU_CREG_PWMSS1
147abs 00000014 __PRU_CREG_PWMSS2
148abs 0000000a __PRU_CREG_RSVD10
149abs 0000000d __PRU_CREG_RSVD13
150abs 00000015 __PRU_CREG_RSVD21
151abs 0000001b __PRU_CREG_RSVD27
152abs 00000017 __PRU_CREG_SPINLOCK
153abs 0000001d __PRU_CREG_TPCC
154abs 0000000b __PRU_CREG_UART1
155abs 0000000c __PRU_CREG_UART2
1561 00000100 __TI_STACK_END
157abs 00000100 __TI_STACK_SIZE
158abs ffffffff __binit__
159abs ffffffff __c_args__
1600 00000000 _c_int00_noinit_noargs_noexit
1611 00000000 _stack
1620 00000e58 abort
163abs ffffffff binit
1640 00000014 main
1651 00000100 pru_remoteproc_ResourceTable
166
167
168GLOBAL SYMBOLS: SORTED BY Symbol Address
169
170page address name
171---- ------- ----
1720 00000000 _c_int00_noinit_noargs_noexit
1730 00000014 main
1740 00000e58 abort
1750 00000e60 C$$EXIT
1761 00000000 _stack
1771 00000100 __TI_STACK_END
1781 00000100 pru_remoteproc_ResourceTable
179abs 00000000 __PRU_CREG_BASE_PRU_DMEM_0_1
180abs 00000000 __PRU_CREG_PRU_INTC
181abs 00000001 __PRU_CREG_DMTIMER2
182abs 00000002 __PRU_CREG_I2C1
183abs 00000003 __PRU_CREG_PRU_ECAP
184abs 00000004 __PRU_CREG_PRU_CFG
185abs 00000005 __PRU_CREG_MMCHS0
186abs 00000006 __PRU_CREG_MCSPI0
187abs 00000007 __PRU_CREG_PRU_UART
188abs 00000008 __PRU_CREG_MCASP0_DMA
189abs 00000009 __PRU_CREG_GEMAC
190abs 0000000a __PRU_CREG_RSVD10
191abs 0000000b __PRU_CREG_UART1
192abs 0000000c __PRU_CREG_UART2
193abs 0000000d __PRU_CREG_RSVD13
194abs 0000000e __PRU_CREG_DCAN0
195abs 0000000f __PRU_CREG_DCAN1
196abs 00000010 __PRU_CREG_MCSPI1
197abs 00000011 __PRU_CREG_I2C2
198abs 00000012 __PRU_CREG_PWMSS0
199abs 00000013 __PRU_CREG_PWMSS1
200abs 00000014 __PRU_CREG_PWMSS2
201abs 00000015 __PRU_CREG_RSVD21
202abs 00000016 __PRU_CREG_MBX0
203abs 00000017 __PRU_CREG_SPINLOCK
204abs 00000018 __PRU_CREG_PRU_DMEM_0_1
205abs 00000019 __PRU_CREG_PRU_DMEM_1_0
206abs 0000001a __PRU_CREG_PRU_IEP
207abs 0000001b __PRU_CREG_RSVD27
208abs 0000001c __PRU_CREG_PRU_SHAREDMEM
209abs 0000001d __PRU_CREG_TPCC
210abs 0000001e __PRU_CREG_L3OCMC
211abs 0000001f __PRU_CREG_DDR
212abs 00000100 __TI_STACK_SIZE
213abs 00002000 __PRU_CREG_BASE_PRU_DMEM_1_0
214abs 00010000 __PRU_CREG_BASE_PRU_SHAREDMEM
215abs 00020000 __PRU_CREG_BASE_PRU_INTC
216abs 00026000 __PRU_CREG_BASE_PRU_CFG
217abs 00028000 __PRU_CREG_BASE_PRU_UART
218abs 0002e000 __PRU_CREG_BASE_PRU_IEP
219abs 00030000 __PRU_CREG_BASE_PRU_ECAP
220abs 00032000 __PRU_CREG_BASE_RSVD27
221abs 00032400 __PRU_CREG_BASE_RSVD21
222abs 40000000 __PRU_CREG_BASE_L3OCMC
223abs 46000000 __PRU_CREG_BASE_MCASP0_DMA
224abs 48022000 __PRU_CREG_BASE_UART1
225abs 48024000 __PRU_CREG_BASE_UART2
226abs 4802a000 __PRU_CREG_BASE_I2C1
227abs 48030000 __PRU_CREG_BASE_MCSPI0
228abs 48040000 __PRU_CREG_BASE_DMTIMER2
229abs 48060000 __PRU_CREG_BASE_MMCHS0
230abs 480c8000 __PRU_CREG_BASE_MBX0
231abs 480ca000 __PRU_CREG_BASE_SPINLOCK
232abs 4819c000 __PRU_CREG_BASE_I2C2
233abs 481a0000 __PRU_CREG_BASE_MCSPI1
234abs 481cc000 __PRU_CREG_BASE_DCAN0
235abs 481d0000 __PRU_CREG_BASE_DCAN1
236abs 48300000 __PRU_CREG_BASE_PWMSS0
237abs 48302000 __PRU_CREG_BASE_PWMSS1
238abs 48304000 __PRU_CREG_BASE_PWMSS2
239abs 48310000 __PRU_CREG_BASE_RSVD13
240abs 48318000 __PRU_CREG_BASE_RSVD10
241abs 49000000 __PRU_CREG_BASE_TPCC
242abs 4a100000 __PRU_CREG_BASE_GEMAC
243abs 80000000 __PRU_CREG_BASE_DDR
244abs ffffffff __binit__
245abs ffffffff __c_args__
246abs ffffffff binit
247
248[75 symbols]
diff --git a/PRU_ADS8688_Interface/gen/PRU_ADS8688_Interface.object b/PRU_ADS8688_Interface/gen/PRU_ADS8688_Interface.object
new file mode 100644
index 0000000..cebdba0
--- /dev/null
+++ b/PRU_ADS8688_Interface/gen/PRU_ADS8688_Interface.object
Binary files differ
diff --git a/PRU_ADS8688_Interface/gen/PRU_ADS8688_Interface.out b/PRU_ADS8688_Interface/gen/PRU_ADS8688_Interface.out
new file mode 100644
index 0000000..640f5ee
--- /dev/null
+++ b/PRU_ADS8688_Interface/gen/PRU_ADS8688_Interface.out
Binary files differ
diff --git a/dts/am335x-boneblack-pruadc.dts b/dts/am335x-boneblack-pruadc.dts
new file mode 100755
index 0000000..f79df53
--- /dev/null
+++ b/dts/am335x-boneblack-pruadc.dts
@@ -0,0 +1,78 @@
1/*
2 * Copyright (C) 2017 Texas Instruments Incorporated - http://www.ti.com/
3 *
4 * This program is free software; you can redistribute it and/or modify
5 * it under the terms of the GNU General Public License version 2 as
6 * published by the Free Software Foundation.
7 */
8
9#include "am335x-boneblack.dts"
10
11&am33xx_pinmux {
12 pru_adc_bone_pins: pru_adc_bone_pins {
13 pinctrl-single,pins = <
14 0x0a0 0x2e /* MISO_1, lcd_data0, MUX_MODE6 | INPUT, P8.45, PRU1[0] GPI/GPO */
15 0x0a4 0x2e /* MISO_2, lcd_data1, MUX_MODE6 | INPUT, P8.46, PRU1[1] GPI/GPO */
16 0x0a8 0x2e /* MISO_3, lcd_data2, MUX_MODE6 | INPUT, P8.43, PRU1[2] GPI/GPO */
17 0x0ac 0x2e /* MISO_4, lcd_data3, MUX_MODE6 | INPUT, P8.44, PRU1[3] GPI/GPO */
18 0x0b0 0x2e /* MISO_5, lcd_data4, MUX_MODE6 | INPUT, P8.41, PRU1[4] GPI/GPO */
19 0x0b4 0x2e /* MISO_6, lcd_data5, MUX_MODE6 | INPUT, P8.42, PRU1[5] GPI/GPO */
20 0x0b8 0x05 /* CS_12, lcd_data6, MUX_MODE5 | OUTPUT, P8.39, PRU1[6] GPI/GPO */
21 0x0bc 0x05 /* MOSI_1, lcd_data7, MUX_MODE5 | OUTPUT, P8.40, PRU1[7] GPI/GPO */
22 0x0e0 0x05 /* MOSI_2, lcd_vsync, MUX_MODE5 | OUTPUT, P8.27, PRU1[8] GPI/GPO */
23 0x0e4 0x05 /* MOSI_3, lcd_hsync, MUX_MODE5 | OUTPUT, P8.29, PRU1[9] GPI/GPO */
24 0x0e8 0x05 /* MOSI_4, lcd_pclk, MUX_MODE5 | OUTPUT, P8.28, PRU1[10] GPI/GPO */
25 0x0ec 0x05 /* MOSI_5, lcd_ac_bias_en, MUX_MODE5 | OUTPUT, P8.30, PRU1[11] GPI/GPO */
26 0x080 0x05 /* MOSI_6, gpmc_csn1, MUX_MODE5 | OUTPUT, P8.21, PRU1[12] GPI/GPO */
27 0x084 0x05 /* SCLK_OUT, gpmc_csn2, MUX_MODE5 | OUTPUT, P8.20, PRU1[13] GPI/GPO */
28 >;
29 };
30};
31
32&pruss {
33 pinctrl-names = "default";
34 pinctrl-0 = <&pru_adc_bone_pins>;
35};
36
37/* Reserve 256kB DDR memory for the ping/pong buffers */
38/{
39 reserved-memory {
40 #address-cells = <1>;
41 #size-cells = <1>;
42 ranges;
43
44 pruadc_reserved: pruadc_reserved@0x9ffc0000 {
45 reg = <0x9ffc0000 0x00040000>;
46 no-map;
47 status = "okay";
48 };
49 };
50
51 hdmi {
52 status = "disabled";
53 };
54};
55
56/* Disable the following nodes due to pin mux conflicts with PRU signals needed */
57&tda19988 {
58 status = "disabled";
59};
60
61&lcdc {
62 status = "disabled";
63};
64
65&mcasp0 {
66 status = "disabled";
67};
68
69&mmc2 {
70 status = "disabled";
71};
72
73/{
74 sound {
75 status = "disabled";
76 };
77};
78
diff --git a/run.sh b/run.sh
new file mode 100755
index 0000000..502898d
--- /dev/null
+++ b/run.sh
@@ -0,0 +1,13 @@
1#!/bin/bash
2
3echo stop > /sys/class/remoteproc/remoteproc1/state
4echo stop > /sys/class/remoteproc/remoteproc2/state
5
6sleep 1
7
8echo start > /sys/class/remoteproc/remoteproc1/state
9echo start > /sys/class/remoteproc/remoteproc2/state
10
11sleep 1
12
13./ARM_User_Space_App.out