X-Git-Url: http://git.mutantstargoat.com/user/nuclear/?p=rpikern;a=blobdiff_plain;f=src%2Fmain.c;h=db2ab86bfd2542e28df01e7c15ba2ee840ae4761;hp=97fcda79efe429e79b40482fde592f3080f2d4a1;hb=32ccc707bc0821d7ff4248fe9f58e92e9c6ebef9;hpb=993155fee2327f1f3cda285c9548bbb09688a3f3 diff --git a/src/main.c b/src/main.c index 97fcda7..db2ab86 100644 --- a/src/main.c +++ b/src/main.c @@ -1,39 +1,81 @@ #include "config.h" +#include #include #include +#include #include "asm.h" +#include "rpi.h" +#include "contty.h" #include "serial.h" +#include "video.h" void dbgled(int x); -void exit(int x); + +static void cmdrun(char *cmd); int main(void) { - disable_intr(); - - dbgled(2); + int lastnl = 0; + static char cmdbuf[256]; + static int cmdend; + rpi_init(); init_serial(115200); - ser_printstr("starting rpkern\n"); + con_init(); + + printf("Detected raspberry pi %d, I/O base: %x\n", rpi_model, rpi_iobase); + video_init(); + + printf("Going interactive\n"); for(;;) { - int c = ser_getchar(); - if(c == -1) { - ser_printstr("error!\n"); - } else { - ser_printstr("got: "); + int c = getchar(); + + switch(c) { + case '\r': + case '\n': + if(!lastnl) { + ser_printstr("\r\n"); + cmdbuf[cmdend] = 0; + cmdend = 0; + cmdrun(cmdbuf); + } + lastnl = 1; + break; + + case -1: + lastnl = 0; + printf("error!\n"); + break; + + default: + lastnl = 0; ser_putchar(c); - ser_putchar('\r'); - ser_putchar('\n'); + if(cmdend < sizeof cmdbuf) { + cmdbuf[cmdend++] = c; + } } } return 0; } -void panic(void) +static void cmdrun(char *cmd) { - dbgled(1); - exit(0); + char *ptr, *args; + + while(*cmd && isspace(*cmd)) cmd++; + ptr = cmd; + while(*ptr && !isspace(*ptr)) ptr++; + *ptr = 0; + args = ptr + 1; + + if(strcmp(cmd, "help") == 0) { + printf("help not implemented yet\n"); + } else if(strcmp(cmd, "ver") == 0) { + printf("rpikern version 0.0\n"); + } else { + printf("Unknown command: %s\n", cmd); + } }