FreeCalypso > hg > freecalypso-tools
view loadtools/old/gtapower.c @ 964:a96cb97b66a2
ringtools/imy: fix duplicate definition of tdma_durations[]
The bug was reported by Vadim Yanitskiy <fixeria@osmocom.org>,
although the present fix is slightly different from the contributed
patch: because main.c doesn't need this tdma_durations[] array
at all, let's simply remove the reference to this array from main.c
rather than turn it into an extern.
I no longer remember my original thought flow that resulted (by mistake)
in tdma_durations[] being multiply defined in main.c and durations.c.
My intent might have been to define all globals in main.c and have
the reference in durations.c be an extern - and I missed that extern -
but without clear memory, I have no certainty. In any case, having
this data array defined in the same module that fills it (durations.c)
is sensible, so let's make it the new way.
author | Mychaela Falconia <falcon@freecalypso.org> |
---|---|
date | Thu, 31 Aug 2023 19:38:18 +0000 |
parents | 62a91abc0300 |
children |
line wrap: on
line source
/* * This module is included only when loadtools are being built to run on the * GTA0x application processor (AP). It provides automated modem power * control, i.e., coordinates modem power control with loadtools operations * for convenience. */ #include <sys/types.h> #include <sys/file.h> #include <stdio.h> #include <stdlib.h> #include <unistd.h> /* * Check this pathname: it is correct for the kernel version I'm using * on my test GTA02, but it differs for some other kernel versions. */ static char modem_powerctl_pathname[] = "/sys/bus/platform/devices/gta02-pm-gsm.0/power_on"; void set_gta_modem_power_ctrl(boolval) { char strbuf[16]; int len, fd; len = sprintf(strbuf, "%d\n", boolval); fd = open(modem_powerctl_pathname, O_WRONLY); if (fd < 0) { perror(modem_powerctl_pathname); exit(1); } write(fd, strbuf, len); close(fd); } void fork_gta_modem_poweron() { int i; i = fork(); if (i < 0) { perror("fork"); exit(1); } if (i) return; printf("Toggling %s\n", modem_powerctl_pathname); set_gta_modem_power_ctrl(0); usleep(350000); set_gta_modem_power_ctrl(1); exit(0); }