]> cloudbase.mooo.com Git - z180-stamp.git/blame_incremental - avr/cmd_boot.c
enum command_ret_t --> typedef
[z180-stamp.git] / avr / cmd_boot.c
... / ...
CommitLineData
1
2/*
3 * Misc boot support
4 */
5#include "common.h"
6#include <stdlib.h>
7#include <util/delay.h>
8#include <avr/pgmspace.h>
9
10#include "command.h"
11#include "z80-if.h"
12
13/* ugly hack to get Z180 loadfile into flash memory */
14#define const const FLASH
15#include "../z180/hdrom.h"
16#undef const
17
18
19
20static void z80_load_mem(void)
21{
22 unsigned sec = 0;
23 uint32_t sec_base = hdrom_start;
24
25 printf_P(PSTR("Loading Z180 memory... \n"));
26
27 while (sec < hdrom_sections) {
28 printf_P(PSTR(" From: 0x%.5lX to: 0x%.5lX (%5li bytes)\n"),
29 hdrom_address[sec],
30 hdrom_address[sec]+hdrom_length_of_sections[sec] - 1,
31 hdrom_length_of_sections[sec]);
32
33 z80_bus_cmd(Request);
34 z80_write_block((const FLASH unsigned char *) &hdrom[sec_base], /* src */
35 hdrom_address[sec], /* dest */
36 hdrom_length_of_sections[sec]); /* len */
37 z80_bus_cmd(Release);
38 sec_base+=hdrom_length_of_sections[sec];
39 sec++;
40 }
41}
42
43command_ret_t do_loadf(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
44{
45 (void) cmdtp; (void) flag; (void) argc; (void) argv;
46
47 if (z80_bus_state() & ZST_RUNNING) {
48 printf_P(PSTR("## Can't load while CPU is running!\n"));
49 return CMD_RET_FAILURE;
50 }
51
52 z80_load_mem();
53
54 return CMD_RET_SUCCESS;
55}
56
57
58command_ret_t do_busreq_pulse(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
59{
60 uint16_t count=1;
61
62 (void) cmdtp; (void) flag;
63
64 if (!(z80_bus_state() & ZST_RUNNING)) {
65 printf_P(PSTR("## CPU is not running!\n"));
66 return CMD_RET_FAILURE;
67 }
68
69 if (argc > 1)
70 count = (uint16_t) strtoul(argv[2], NULL, 16);
71
72 z80_bus_cmd(Request);
73 while (count--)
74 z80_bus_cmd(M_Cycle);
75
76 return CMD_RET_SUCCESS;
77}
78
79
80command_ret_t do_go(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
81{
82 uint32_t addr;
83
84 (void) cmdtp; (void) flag;
85
86 if (argc < 2)
87 return CMD_RET_USAGE;
88 addr = strtoul(argv[1], NULL, 16);
89 if (addr >= (1UL<<16)) {
90 printf_P(PSTR("## Startaddress 0x%05lx too high.\n"
91 " (Out of logical address space (0x00000-0x0ffff))\n"),
92 addr);
93 return CMD_RET_FAILURE;
94 }
95
96 if (z80_bus_state() & ZST_RUNNING) {
97 printf_P(PSTR("## CPU allready running!\n"));
98 return CMD_RET_FAILURE;
99 }
100
101 printf_P(PSTR("## Starting application at 0x%04lx ...\n"), addr);
102
103 if (addr != 0) {
104 uint8_t tmp[3];
105 uint_fast8_t i;
106
107 z80_bus_cmd(Request);
108 for (i = 0; i < 3; i++)
109 tmp[i] = z80_read(i);
110 z80_write(0, 0xc3);
111 z80_write(1, addr);
112 z80_write(2, (addr >> 8));
113
114 z80_bus_cmd(Run);
115 z80_bus_cmd(M_Cycle);
116 z80_bus_cmd(M_Cycle);
117 for (i = 0; i < 3; i++)
118 z80_write(i, tmp[i]);
119 } else
120 z80_bus_cmd(Run);
121
122 z80_bus_cmd(Release);
123
124 return CMD_RET_SUCCESS;
125}
126
127command_ret_t do_reset(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
128{
129 (void) cmdtp; (void) flag; (void) argc; (void) argv;
130
131 printf_P(PSTR("## CPU now in reset state.\n"));
132
133 z80_bus_cmd(Reset);
134 return CMD_RET_SUCCESS;
135}
136
137command_ret_t do_restart(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
138{
139 (void) cmdtp; (void) flag; (void) argc; (void) argv;
140
141 z80_bus_cmd(Restart);
142
143 return CMD_RET_SUCCESS;
144}
145