9 JTDO remap PB3, SPI1_SCK'
10 NJTRST remap PB4, SPI1_MISO'
12 JTDI remap PA15, SPI1_NSS'
15 AFIO_MAPR_SWJ_CFG_JTAG_OFF_SW_ON (frees
20 #include <libopencm3/stm32/gpio.h>
21 #include <libopencm3/stm32/rcc.h>
22 #include <libopencm3/stm32/timer.h>
23 #include <libopencm3/stm32/dma.h>
26 /* Number of array elements */
27 #define NELEMS(x) (sizeof x/sizeof *x)
32 #define CONCAT(x,y) x ## y
33 #define EVALUATOR(x,y) CONCAT(x,y)
35 #define GPIO_(X) CONCAT(GPIO, X)
87 #define P_BUSREQ GPIOD
89 #define P_BUSACK GPIOA
91 //#define P_HALT GPIOA
103 #define ADp1_PORT GPIOA
105 #define ADp2_OFS ADp1_WIDTH
108 #define ADp2_PORT GPIOC
110 #define ADp3_OFS (ADp2_OFS+ADp2_WIDTH)
112 #define ADp3_SHIFT 10
113 #define ADp3_PORT GPIOC
115 #define ADunbuff1_WIDTH 1
116 #define ADunbuff1_SHIFT 8
117 #define ADunbuff1_PORT GPIOA
119 #define ADunbuff2_WIDTH 2
120 #define ADunbuff2_SHIFT 6
121 #define ADunbuff2_PORT GPIOC
123 #define ADunbuff3_WIDTH 3
124 #define ADunbuff3_SHIFT 10
125 #define ADunbuff3_PORT GPIOC
130 #define DB_PORT GPIOB
132 #define GPIO_ME GPIO_(ME)
133 #define GPIO_RD GPIO_(RD)
134 #define GPIO_WR GPIO_(WR)
135 #define GPIO_BUSREQ GPIO_(BUSREQ)
136 #define GPIO_BUSACK GPIO_(BUSACK)
137 //#define GPIO_HALT GPIO_(HALT)
138 #define GPIO_IOE GPIO_(IOE)
139 #define GPIO_NMI GPIO_(NMI)
140 #define GPIO_RST GPIO_(RST)
142 #define Z80_O_ME BBIO_PERIPH(P_ME+ODR, ME)
143 #define Z80_O_RD BBIO_PERIPH(P_RD+ODR, RD)
144 #define Z80_O_WR BBIO_PERIPH(P_WR+ODR, WR)
145 #define Z80_O_BUSREQ BBIO_PERIPH(P_BUSREQ+ODR, BUSREQ)
146 #define Z80_O_NMI BBIO_PERIPH(P_NMI+ODR, NMI)
147 #define Z80_O_RST BBIO_PERIPH(P_RST+ODR, RST)
149 #define Z80_I_BUSACK BBIO_PERIPH(P_BUSACK+IDR, BUSACK)
150 //#define Z80_I_HALT BBIO_PERIPH(P_HALT+IDR, HALT)
153 #define MASK(n) ((1<<n)-1)
155 #define IOFIELD_SET(src, ofs, width, shift) \
156 ((((src>>ofs) & MASK(width)) << shift) | ((((~src>>ofs) & MASK(width)) << shift) << 16))
158 #define IOFIELD_GET(src, width, shift) \
159 ((src>>shift) & MASK(width))
161 #define CNF_MODE_I_F (GPIO_CNF_INPUT_FLOAT<<2 |GPIO_MODE_INPUT)
162 #define CNF_MODE_O_PP (GPIO_CNF_OUTPUT_PUSHPULL<<2 | GPIO_MODE_OUTPUT_10_MHZ)
164 #define DB_MODE_INPUT ( (CNF_MODE_I_F << (4 * 0)) \
165 | (CNF_MODE_I_F << (4 * 1)) \
166 | (CNF_MODE_I_F << (4 * 2)) \
167 | (CNF_MODE_I_F << (4 * 3)) \
168 | (CNF_MODE_I_F << (4 * 4)) \
169 | (CNF_MODE_I_F << (4 * 5)) \
170 | (CNF_MODE_I_F << (4 * 6)) \
171 | (CNF_MODE_I_F << (4 * 7)))
173 #define DB_MODE_OUTPUT ( (CNF_MODE_O_PP << (4 * 0)) \
174 | (CNF_MODE_O_PP << (4 * 1)) \
175 | (CNF_MODE_O_PP << (4 * 2)) \
176 | (CNF_MODE_O_PP << (4 * 3)) \
177 | (CNF_MODE_O_PP << (4 * 4)) \
178 | (CNF_MODE_O_PP << (4 * 5)) \
179 | (CNF_MODE_O_PP << (4 * 6)) \
180 | (CNF_MODE_O_PP << (4 * 7)))
183 /*--------------------------------------------------------------------------*/
185 volatile uint8_t z80_inbuf
[256];
186 static uint32_t inbuf_ndt
;
188 /*--------------------------------------------------------------------------*/
190 #define TIM16_BDTR TIM_BDTR(TIM16)
192 static void tim16_setup(void)
194 RCC_APB2RSTR
|= (1<<17);
195 RCC_APB2RSTR
&= ~(1<<17);
197 TIM16_BDTR
= TIM_BDTR_MOE
;
200 | TIM_CCMR1_OC1M_FORCE_LOW
201 /* | TIM_CCMR1_OC1M_FORCE_HIGH */
202 /* | TIM_CCMR1_OC1M_PWM2 */
204 /* | TIM_CCMR1_OC1PE */
205 /* | TIM_CCMR1_OC1FE */
206 | TIM_CCMR1_CC1S_OUT
;
208 TIM16_CCER
= TIM_CCER_CC1NE
211 TIM16_ARR
= 48; /* default */
212 TIM16_CCR1
= 1; /* */
215 /*--------------------------------------------------------------------------*/
217 static void tim1_setup(void)
219 RCC_APB2RSTR
|= RCC_APB2RSTR_TIM1RST
;
220 RCC_APB2RSTR
&= ~RCC_APB2RSTR_TIM1RST
;
226 /* | TIM_SMCR_ETF_CK_INT_N_2 */
231 TIM1_DIER
= TIM_DIER_TDE
;
235 | TIM_CCMR1_OC1M_FORCE_LOW
236 /* | TIM_CCMR1_OC1M_FORCE_HIGH */
237 /* | TIM_CCMR1_OC1M_PWM2 */
239 /* | TIM_CCMR1_OC1PE */
240 /* | TIM_CCMR1_OC1FE */
241 | TIM_CCMR1_CC1S_OUT
;
243 TIM1_SMCR
|= TIM_SMCR_SMS_TM
;
244 /* | TIM_SMCR_SMS_ECM1 */
247 /*--------------------------------------------------------------------------*/
249 static void dma4_setup(void)
258 DMA1_CMAR4
= (uint32_t) &z80_inbuf
[0];
260 #if (DB_SHIFT == 0) || (DB_SHIFT == 8)
261 DMA1_CPAR4
= DB_PORT
+ IDR
+ DB_SHIFT
/8;
263 #error "Databus not byte aligned!"
266 DMA1_CNDTR4
= inbuf_ndt
= NELEMS(z80_inbuf
);
268 DMA1_CCR4
|= DMA_CCR_EN
;
271 /*--------------------------------------------------------------------------*/
273 void tim16_set(int mode
)
277 cc_mode
= TIM_CCMR1_CC1S_OUT
;
279 TIM16_CR1
= TIM_CR1_OPM
;
282 cc_mode
|= TIM_CCMR1_OC1M_FORCE_LOW
;
284 cc_mode
|= TIM_CCMR1_OC1M_FORCE_HIGH
;
287 cc_mode
|= TIM_CCMR1_OC1M_PWM2
;
290 TIM16_CCMR1
= cc_mode
;
293 TIM16_CR1
|= TIM_CR1_CEN
;
296 /*--------------------------------------------------------------------------*/
301 * A0..A6, A8..A13 are buffered. No need to disable.
302 * A7, A14..A18: set to input.
305 static void z80_setup_adrbus_tristate(void)
308 gpio_set_mode(ADunbuff1_PORT
, GPIO_MODE_INPUT
,
309 GPIO_CNF_INPUT_FLOAT
, MASK(ADunbuff1_WIDTH
) << ADunbuff1_SHIFT
);
310 gpio_set_mode(ADunbuff2_PORT
, GPIO_MODE_INPUT
, GPIO_CNF_INPUT_FLOAT
,
311 (MASK(ADunbuff2_WIDTH
) << ADunbuff2_SHIFT
) | (MASK(ADunbuff3_WIDTH
) << ADunbuff3_SHIFT
));
313 GPIO_CRH(GPIOA
) = (GPIO_CRH(GPIOA
) & ~(0x0f << (4 * 0)))
314 | (CNF_MODE_I_F
<< (4 * 0));
315 GPIO_CRL(GPIOC
) = (GPIO_CRL(GPIOC
) & ~((0x0f << (4 * 6)) | (0x0f << (4 * 7))))
316 | ((CNF_MODE_I_F
<< (4 * 6)) | (CNF_MODE_I_F
<< (4 * 7)));
317 GPIO_CRH(GPIOC
) = (GPIO_CRH(GPIOC
) & ~((0x0f << (4*2)) | (0x0f << (4*3)) | (0x0f << (4*4))))
318 | ((CNF_MODE_I_F
<< (4*2)) | (CNF_MODE_I_F
<< (4*3)) | (CNF_MODE_I_F
<< (4*4)));
323 static void z80_setup_adrbus_active(void)
326 gpio_set_mode(ADunbuff1_PORT
, GPIO_MODE_OUTPUT_10_MHZ
,
327 GPIO_CNF_OUTPUT_PUSHPULL
, MASK(ADunbuff1_WIDTH
) << ADunbuff1_SHIFT
);
328 gpio_set_mode(ADunbuff2_PORT
, GPIO_MODE_OUTPUT_10_MHZ
, GPIO_CNF_OUTPUT_PUSHPULL
,
329 (MASK(ADunbuff2_WIDTH
) << ADunbuff2_SHIFT
) | (MASK(ADunbuff3_WIDTH
) << ADunbuff3_SHIFT
));
331 GPIO_CRH(GPIOA
) = (GPIO_CRH(GPIOA
) & ~(0x0f << (4 * 0)))
332 | (CNF_MODE_O_PP
<< (4 * 0));
333 GPIO_CRL(GPIOC
) = (GPIO_CRL(GPIOC
) & ~((0x0f << (4 * 6)) | (0x0f << (4 * 7))))
334 | ((CNF_MODE_O_PP
<< (4 * 6)) | (CNF_MODE_O_PP
<< (4 * 7)));
335 GPIO_CRH(GPIOC
) = (GPIO_CRH(GPIOC
) & ~((0x0f << (4*2)) | (0x0f << (4*3)) | (0x0f << (4*4))))
336 | ((CNF_MODE_O_PP
<< (4*2)) | (CNF_MODE_O_PP
<< (4*3)) | (CNF_MODE_O_PP
<< (4*4)));
341 static void z80_setup_dbus_in(void)
343 GPIO_CRH(DB_PORT
) = DB_MODE_INPUT
;
346 static void z80_setup_dbus_out(void)
348 GPIO_CRH(DB_PORT
) = DB_MODE_OUTPUT
;
352 static void z80_setaddress(uint32_t addr
)
354 GPIO_BSRR(ADp1_PORT
) = IOFIELD_SET(addr
, ADp1_OFS
, ADp1_WIDTH
, ADp1_SHIFT
);
355 GPIO_BSRR(ADp2_PORT
) = IOFIELD_SET(addr
, ADp2_OFS
, ADp2_WIDTH
, ADp2_SHIFT
);
356 GPIO_BSRR(ADp3_PORT
) = IOFIELD_SET(addr
, ADp3_OFS
, ADp3_WIDTH
, ADp3_SHIFT
);
359 void z80_setup_bus(void)
365 gpio_set_mode(P_RST
, GPIO_MODE_OUTPUT_10_MHZ
,
366 GPIO_CNF_OUTPUT_ALTFN_PUSHPULL
, GPIO_RST
);
368 gpio_set_mode(P_BUSREQ
, GPIO_MODE_OUTPUT_10_MHZ
,
369 GPIO_CNF_OUTPUT_PUSHPULL
, GPIO_BUSREQ
);
371 gpio_set_mode(P_NMI
, GPIO_MODE_OUTPUT_10_MHZ
,
372 GPIO_CNF_OUTPUT_PUSHPULL
, GPIO_NMI
);
376 gpio_set_mode(P_ME
, GPIO_MODE_OUTPUT_2_MHZ
,
377 GPIO_CNF_OUTPUT_PUSHPULL
, GPIO_ME
);
378 gpio_set_mode(P_RD
, GPIO_MODE_OUTPUT_10_MHZ
,
379 GPIO_CNF_OUTPUT_PUSHPULL
, GPIO_RD
| GPIO_WR
);
381 gpio_set_mode(P_BUSACK
, GPIO_MODE_INPUT
,
382 GPIO_CNF_INPUT_FLOAT
, GPIO_BUSACK
| GPIO_IOE
);
385 //while(Z80_I_BUSACK == 1);
387 gpio_set_mode(ADp1_PORT
, GPIO_MODE_OUTPUT_10_MHZ
,
388 GPIO_CNF_OUTPUT_PUSHPULL
, MASK(ADp1_WIDTH
) << ADp1_SHIFT
);
389 gpio_set_mode(ADp2_PORT
, GPIO_MODE_OUTPUT_10_MHZ
,
390 GPIO_CNF_OUTPUT_PUSHPULL
, MASK(ADp2_WIDTH
) << ADp2_SHIFT
);
391 gpio_set_mode(ADp3_PORT
, GPIO_MODE_OUTPUT_10_MHZ
,
392 GPIO_CNF_OUTPUT_PUSHPULL
, MASK(ADp3_WIDTH
) << ADp3_SHIFT
);
397 void z80_get_bus(void)
400 while(Z80_I_BUSACK
== 1);
401 z80_setup_adrbus_active();
404 void z80_release_bus(void)
407 z80_setup_adrbus_tristate();
409 while(Z80_I_BUSACK
== 0);
412 void z80_reset(level_t level
)
414 int x
= level
? -1 : 0;
418 // Z80_O_RST = level;
421 void z80_reset_pulse(void)
426 void z80_busreq(level_t level
)
428 Z80_O_BUSREQ
= level
;
432 int z80_stat_halt(void)
438 void z80_write(uint32_t addr
, uint8_t data
)
440 z80_setaddress(addr
);
442 GPIO_BSRR(DB_PORT
) = IOFIELD_SET(data
, DB_OFS
, DB_WIDTH
, DB_SHIFT
);
443 z80_setup_dbus_out();
449 uint8_t z80_read(uint32_t addr
)
453 z80_setaddress(addr
);
458 data
= IOFIELD_GET(GPIO_IDR(DB_PORT
),DB_WIDTH
, DB_SHIFT
);
466 void z80_memset(uint32_t addr
, uint8_t data
, int length
)
468 z80_setup_dbus_out();
471 z80_setaddress(addr
++);
472 GPIO_BSRR(DB_PORT
) = IOFIELD_SET(data
, DB_OFS
, DB_WIDTH
, DB_SHIFT
);
479 void z80_write_block(uint8_t *src
, uint32_t dest
, uint32_t length
)
483 z80_setup_dbus_out();
486 z80_setaddress(dest
++);
488 GPIO_BSRR(DB_PORT
) = IOFIELD_SET(data
, DB_OFS
, DB_WIDTH
, DB_SHIFT
);
496 0179' rx.bs_mask: ds 1 ; (buf_len - 1)
497 017A' rx.in_idx: ds 1 ;
498 017B' rx.out_idx: ds 1 ;
499 017C' rx.buf: ds rx.buf_len ;
500 018B' rx.buf_end equ $-1 ; last byte (start+len-1)
502 018C' tx.bs_mask: ds 1 ; (buf_len - 1)
503 018D' tx.in_idx: ds 1 ;
504 018E' tx.out_idx: ds 1 ;
505 018F' tx.buf: ds tx.buf_len ;
506 019E' tx.buf_end equ $-1 ; last byte
509 #define fifo_bufsize_mask -3
510 #define fifo_index_in -2
511 #define fifo_index_out -1
522 void z80_fifo_init(void)
525 fifos
[fifo_in
].base
= tx_fifo
;
526 fifos
[fifo_in
].idx_out
= z80_read(tx_fifo
+fifo_index_out
);
527 fifos
[fifo_in
].idx_in
= z80_read(tx_fifo
+fifo_index_in
);
528 fifos
[fifo_in
].mask
= z80_read(tx_fifo
+fifo_bufsize_mask
);
530 fifos
[fifo_out
].base
= rx_fifo
;
531 fifos
[fifo_out
].idx_out
= z80_read(rx_fifo
+fifo_index_out
);
532 fifos
[fifo_out
].idx_in
= z80_read(rx_fifo
+fifo_index_in
);
533 fifos
[fifo_out
].mask
= z80_read(rx_fifo
+fifo_bufsize_mask
);
538 int z80_fifo_is_not_empty(fifo_t f
)
540 uint32_t adr
= fifos
[f
].base
+fifo_index_in
;
547 return idx
!= fifos
[f
].idx_out
;
550 int z80_fifo_is_not_full(fifo_t f
)
555 rc
= ((fifos
[f
].idx_in
+ 1) & fifos
[f
].mask
)
556 != z80_read(fifos
[f
].base
+fifo_index_out
);
562 uint8_t z80_fifo_getc(fifo_t f
)
566 while (!z80_fifo_is_not_empty(f
))
570 idx
= fifos
[f
].idx_out
;
571 rc
= z80_read(fifos
[f
].base
+idx
);
572 fifos
[f
].idx_out
= ++idx
& fifos
[f
].mask
;
573 z80_write(fifos
[f
].base
+fifo_index_out
, fifos
[f
].idx_out
);
580 void z80_fifo_putc(fifo_t f
, uint8_t val
)
584 while (!z80_fifo_is_not_full(f
))
588 idx
= fifos
[f
].idx_in
;
589 z80_write(fifos
[f
].base
+idx
, val
);
590 fifos
[f
].idx_in
= ++idx
& fifos
[f
].mask
;
591 z80_write(fifos
[f
].base
+fifo_index_in
, fifos
[f
].idx_in
);
595 int z80_inbuf_getc(void)
599 if (inbuf_ndt
!= DMA1_CNDTR4
) {
600 c
= z80_inbuf
[NELEMS(z80_inbuf
) - inbuf_ndt
--];
602 inbuf_ndt
= NELEMS(z80_inbuf
);