FreeCalypso > hg > fc-tourmaline
view helpers/str2ind-ver.c @ 280:82665effff30
keypad boot init overhaul: handle initially held-down keys
This change fixes two previous behavioural defects:
1) On Compal phones, the PWR key had to be released before the boot
sequence would proceed at all - it was stuck in an endless IRQ loop
at the point of Nucleus enabling interrupts, before anything else.
2) On both Compal and sane platforms including Luna, if some regular
non-PWR key was held down at boot time, the boot sequence would
proceed and complete normally, but all non-PWR keypad buttons would
be dead for the remainder of that boot cycle.
The fix is a generic solution - no Compal-specific hack ended up being
needed for the special case of their idiotic PWON-to-ROW4 hw wiring.
author | Mychaela Falconia <falcon@freecalypso.org> |
---|---|
date | Fri, 24 Sep 2021 00:47:12 +0000 |
parents | 1fb47f5b597a |
children |
line wrap: on
line source
/* * This utility extracts the timestamp from a str2ind.tab file * and emits the corresponding char *str2ind_version C line. */ #include <stdio.h> #include <stdlib.h> #include <string.h> #include <strings.h> main(argc, argv) char **argv; { FILE *inf; char buf[32], *cp; if (argc != 2) { fprintf(stderr, "usage: %s str2ind.tab\n", argv[0]); exit(1); } inf = fopen(argv[1], "r"); if (!inf) { perror(argv[1]); exit(1); } if (!fgets(buf, sizeof buf, inf)) { inv: fprintf(stderr, "Error: %s does not have the expected first line\n", argv[1]); exit(1); } cp = index(buf, '\n'); if (!cp || cp == buf) goto inv; *cp = '\0'; if (cp[-1] == '\r') *--cp = '\0'; if (cp != buf + 10) goto inv; printf("char *str2ind_version = \"&%s\";\n", buf); exit(0); }