С выравниванием по 8 байт » History » Version 3
krufter_multiclet, 07/19/2013 04:24 PM
1 | 1 | krufter_multiclet | h1. С выравниванием по 8 байт |
---|---|---|---|
2 | 1 | krufter_multiclet | |
3 | 1 | krufter_multiclet | +Для платы HW1-MCp04:+ |
4 | 1 | krufter_multiclet | |
5 | 1 | krufter_multiclet | <pre> |
6 | 1 | krufter_multiclet | .include "HDL50001_pcf.inc" |
7 | 1 | krufter_multiclet | |
8 | 1 | krufter_multiclet | .alias DM_START 0x00000000 ;start address DM for output by uart0 |
9 | 1 | krufter_multiclet | .alias BLOCK_SIZE 0x00000100 ;end address DM for output by uart0 |
10 | 1 | krufter_multiclet | .alias iterator1 2 |
11 | 1 | krufter_multiclet | .alias iterator2 3 |
12 | 1 | krufter_multiclet | .alias iterator3 4 |
13 | 1 | krufter_multiclet | .alias byte_DM 5 |
14 | 1 | krufter_multiclet | |
15 | 1 | krufter_multiclet | .alias UART_DATA UART0_DATA |
16 | 1 | krufter_multiclet | .alias UART_BDR UART0_BDR |
17 | 1 | krufter_multiclet | .alias UART_ST UART0_ST |
18 | 1 | krufter_multiclet | .alias UART_CR UART0_CR |
19 | 1 | krufter_multiclet | |
20 | 1 | krufter_multiclet | .alias UART_PORT_PIN 0x300 |
21 | 1 | krufter_multiclet | .alias UART_PORT_BPS GPIOB_BPS |
22 | 1 | krufter_multiclet | |
23 | 1 | krufter_multiclet | .text |
24 | 1 | krufter_multiclet | |
25 | 1 | krufter_multiclet | ;config uart |
26 | 1 | krufter_multiclet | initUART: |
27 | 1 | krufter_multiclet | jmp read_DM |
28 | 1 | krufter_multiclet | getl 0x00000300 |
29 | 1 | krufter_multiclet | wrl @1, UART_PORT_BPS |
30 | 1 | krufter_multiclet | getl 0x00000104 |
31 | 1 | krufter_multiclet | wrl @1, UART_BDR |
32 | 1 | krufter_multiclet | getl 0x00000003 |
33 | 1 | krufter_multiclet | wrl @1, UART_CR |
34 | 1 | krufter_multiclet | setl #iterator1, 0x00000000 |
35 | 1 | krufter_multiclet | setl #iterator3, 4 ; send to uart fifo 32 bytes |
36 | 1 | krufter_multiclet | complete |
37 | 1 | krufter_multiclet | |
38 | 1 | krufter_multiclet | ; read DM for define address as double word (64 bits) |
39 | 1 | krufter_multiclet | read_DM: |
40 | 1 | krufter_multiclet | getl BLOCK_SIZE |
41 | 1 | krufter_multiclet | subl @1, #iterator1 |
42 | 1 | krufter_multiclet | je @1, stop2 |
43 | 1 | krufter_multiclet | jne @2, out_DM |
44 | 1 | krufter_multiclet | getl #iterator1 |
45 | 1 | krufter_multiclet | addl @1, DM_START |
46 | 1 | krufter_multiclet | rdq @1 |
47 | 1 | krufter_multiclet | setq #byte_DM, @1 |
48 | 1 | krufter_multiclet | addl @4, 0x00000008 |
49 | 1 | krufter_multiclet | setl #iterator1, @1 |
50 | 1 | krufter_multiclet | setl #iterator2, 0 |
51 | 1 | krufter_multiclet | getl #iterator3 |
52 | 1 | krufter_multiclet | subl @1, 1 |
53 | 1 | krufter_multiclet | setl #iterator3, @1 |
54 | 1 | krufter_multiclet | complete |
55 | 1 | krufter_multiclet | |
56 | 1 | krufter_multiclet | out_DM: |
57 | 1 | krufter_multiclet | getl #iterator2 |
58 | 1 | krufter_multiclet | getl 56 ; write to tx fifo 8 bytes |
59 | 1 | krufter_multiclet | subl @1, @2 |
60 | 1 | krufter_multiclet | je @1, full_FIFO |
61 | 1 | krufter_multiclet | jne @2, out_DM |
62 | 1 | krufter_multiclet | getq #byte_DM |
63 | 1 | krufter_multiclet | slrq @1, #iterator2 |
64 | 1 | krufter_multiclet | wrq @1, UART_DATA ; write to tx fifo only one byte |
65 | 1 | krufter_multiclet | getl 8 |
66 | 1 | krufter_multiclet | addl @1, #iterator2 |
67 | 1 | krufter_multiclet | setl #iterator2, @1 |
68 | 1 | krufter_multiclet | complete |
69 | 1 | krufter_multiclet | |
70 | 1 | krufter_multiclet | ; analyze iterator3 for sending all 4*8 bytes |
71 | 1 | krufter_multiclet | full_FIFO: |
72 | 1 | krufter_multiclet | getl #iterator3 |
73 | 1 | krufter_multiclet | getl 0xFFFFFFFF |
74 | 1 | krufter_multiclet | and @1, @2 |
75 | 1 | krufter_multiclet | je @1, buf_TXD |
76 | 1 | krufter_multiclet | jne @2, read_DM |
77 | 1 | krufter_multiclet | complete |
78 | 1 | krufter_multiclet | |
79 | 1 | krufter_multiclet | ; wait for fifo transmitter is empty |
80 | 1 | krufter_multiclet | buf_TXD: |
81 | 1 | krufter_multiclet | rdl UART_ST |
82 | 1 | krufter_multiclet | getl 0x00000004 |
83 | 1 | krufter_multiclet | and @1, @2 |
84 | 1 | krufter_multiclet | je @1, buf_TXD |
85 | 1 | krufter_multiclet | jne @2, read_DM |
86 | 1 | krufter_multiclet | setl #iterator3, 4 |
87 | 1 | krufter_multiclet | complete |
88 | 1 | krufter_multiclet | |
89 | 1 | krufter_multiclet | ; enable led 2,3 |
90 | 1 | krufter_multiclet | stop2: |
91 | 1 | krufter_multiclet | getl 0x1000 |
92 | 1 | krufter_multiclet | complete |
93 | 1 | krufter_multiclet | </pre> |
94 | 1 | krufter_multiclet | |
95 | 3 | krufter_multiclet | +Замечание:+ размер блока BLOCK_SIZE должен быть выравнен на 8 байт. |
96 | 1 | krufter_multiclet | |
97 | 1 | krufter_multiclet | |
98 | 1 | krufter_multiclet | +Для платы LDM-MCp04:+ |
99 | 1 | krufter_multiclet | |
100 | 1 | krufter_multiclet | <pre> |
101 | 1 | krufter_multiclet | .include "HDL50001_pcf.inc" |
102 | 1 | krufter_multiclet | |
103 | 1 | krufter_multiclet | .alias DM_START 0x00000000 ;start address DM for output by uart0 |
104 | 1 | krufter_multiclet | .alias BLOCK_SIZE 0x00000100 ;end address DM for output by uart0 |
105 | 1 | krufter_multiclet | .alias iterator1 2 |
106 | 1 | krufter_multiclet | .alias iterator2 3 |
107 | 1 | krufter_multiclet | .alias iterator3 4 |
108 | 1 | krufter_multiclet | .alias byte_DM 5 |
109 | 1 | krufter_multiclet | |
110 | 1 | krufter_multiclet | .alias UART_DATA UART3_DATA |
111 | 1 | krufter_multiclet | .alias UART_BDR UART3_BDR |
112 | 1 | krufter_multiclet | .alias UART_ST UART3_ST |
113 | 1 | krufter_multiclet | .alias UART_CR UART3_CR |
114 | 1 | krufter_multiclet | |
115 | 1 | krufter_multiclet | .alias UART_PORT_PIN 0x300 |
116 | 1 | krufter_multiclet | .alias UART_PORT_BPS GPIOD_BPS |
117 | 1 | krufter_multiclet | |
118 | 1 | krufter_multiclet | .text |
119 | 1 | krufter_multiclet | |
120 | 1 | krufter_multiclet | ;config uart |
121 | 1 | krufter_multiclet | initUART: |
122 | 1 | krufter_multiclet | jmp read_DM |
123 | 1 | krufter_multiclet | getl 0x00000300 |
124 | 1 | krufter_multiclet | wrl @1, UART_PORT_BPS |
125 | 1 | krufter_multiclet | getl 0x00000104 |
126 | 1 | krufter_multiclet | wrl @1, UART_BDR |
127 | 1 | krufter_multiclet | getl 0x00000003 |
128 | 1 | krufter_multiclet | wrl @1, UART_CR |
129 | 1 | krufter_multiclet | setl #iterator1, 0x00000000 |
130 | 1 | krufter_multiclet | setl #iterator3, 4 ; send to uart fifo 32 bytes |
131 | 1 | krufter_multiclet | complete |
132 | 1 | krufter_multiclet | |
133 | 1 | krufter_multiclet | ; read DM for define address as double word (64 bits) |
134 | 1 | krufter_multiclet | read_DM: |
135 | 1 | krufter_multiclet | getl BLOCK_SIZE |
136 | 1 | krufter_multiclet | subl @1, #iterator1 |
137 | 1 | krufter_multiclet | je @1, stop2 |
138 | 1 | krufter_multiclet | jne @2, out_DM |
139 | 1 | krufter_multiclet | getl #iterator1 |
140 | 1 | krufter_multiclet | addl @1, DM_START |
141 | 1 | krufter_multiclet | rdq @1 |
142 | 1 | krufter_multiclet | setq #byte_DM, @1 |
143 | 1 | krufter_multiclet | addl @4, 0x00000008 |
144 | 1 | krufter_multiclet | setl #iterator1, @1 |
145 | 1 | krufter_multiclet | setl #iterator2, 0 |
146 | 1 | krufter_multiclet | getl #iterator3 |
147 | 1 | krufter_multiclet | subl @1, 1 |
148 | 1 | krufter_multiclet | setl #iterator3, @1 |
149 | 1 | krufter_multiclet | complete |
150 | 1 | krufter_multiclet | |
151 | 1 | krufter_multiclet | out_DM: |
152 | 1 | krufter_multiclet | getl #iterator2 |
153 | 1 | krufter_multiclet | getl 56 ; write to tx fifo 8 bytes |
154 | 1 | krufter_multiclet | subl @1, @2 |
155 | 1 | krufter_multiclet | je @1, full_FIFO |
156 | 1 | krufter_multiclet | jne @2, out_DM |
157 | 1 | krufter_multiclet | getq #byte_DM |
158 | 1 | krufter_multiclet | slrq @1, #iterator2 |
159 | 1 | krufter_multiclet | wrq @1, UART_DATA ; write to tx fifo only one byte |
160 | 1 | krufter_multiclet | getl 8 |
161 | 1 | krufter_multiclet | addl @1, #iterator2 |
162 | 1 | krufter_multiclet | setl #iterator2, @1 |
163 | 1 | krufter_multiclet | complete |
164 | 1 | krufter_multiclet | |
165 | 1 | krufter_multiclet | ; analyze iterator3 for sending all 4*8 bytes |
166 | 1 | krufter_multiclet | full_FIFO: |
167 | 1 | krufter_multiclet | getl #iterator3 |
168 | 1 | krufter_multiclet | getl 0xFFFFFFFF |
169 | 1 | krufter_multiclet | and @1, @2 |
170 | 1 | krufter_multiclet | je @1, buf_TXD |
171 | 1 | krufter_multiclet | jne @2, read_DM |
172 | 1 | krufter_multiclet | complete |
173 | 1 | krufter_multiclet | |
174 | 1 | krufter_multiclet | ; wait for fifo transmitter is empty |
175 | 1 | krufter_multiclet | buf_TXD: |
176 | 1 | krufter_multiclet | rdl UART_ST |
177 | 1 | krufter_multiclet | getl 0x00000004 |
178 | 1 | krufter_multiclet | and @1, @2 |
179 | 1 | krufter_multiclet | je @1, buf_TXD |
180 | 1 | krufter_multiclet | jne @2, read_DM |
181 | 1 | krufter_multiclet | setl #iterator3, 4 |
182 | 1 | krufter_multiclet | complete |
183 | 1 | krufter_multiclet | |
184 | 1 | krufter_multiclet | ; enable led 2,3 |
185 | 1 | krufter_multiclet | stop2: |
186 | 1 | krufter_multiclet | getl 0x1000 |
187 | 1 | krufter_multiclet | complete |
188 | 1 | krufter_multiclet | </pre> |