FreeCalypso > hg > freecalypso-tools
view rvinterf/tmsh/l1cmd.c @ 115:c41511b79b1d
fc-tmsh: rfpr command implemented
author | Mychaela Falconia <falcon@freecalypso.org> |
---|---|
date | Mon, 16 Jan 2017 20:25:48 +0000 |
parents | eb54195fded6 |
children | c91500530216 |
line wrap: on
line source
/* * In this module we are going to implement commands which send * TM3 command packets to the L1TM firmware component: RF calibration * and test modes. */ #include <sys/types.h> #include <stdio.h> #include <string.h> #include <strings.h> #include <stdlib.h> #include "pktmux.h" #include "limits.h" #include "localtypes.h" #include "tm3.h" #include "exitcodes.h" cmd_tminit(argc, argv) char **argv; { u_char cmdpkt[3]; cmdpkt[1] = TM_INIT; send_etm_cmd(cmdpkt, 1); return(0); } cmd_tms(argc, argv) char **argv; { u16 arg; u_char cmdpkt[5]; arg = strtoul(argv[1], 0, 0); cmdpkt[1] = TM_MODE_SET; cmdpkt[2] = arg; cmdpkt[3] = arg >> 8; send_etm_cmd(cmdpkt, 3); return(0); } cmd_tm3ver(argc, argv) char **argv; { u16 arg; u_char cmdpkt[5]; arg = strtoul(argv[1], 0, 16); cmdpkt[1] = VERSION_GET; cmdpkt[2] = arg; cmdpkt[3] = arg >> 8; send_etm_cmd(cmdpkt, 3); return(0); } cmd_rfe(argc, argv) char **argv; { u16 arg; u_char cmdpkt[5]; arg = strtoul(argv[1], 0, 0); cmdpkt[1] = RF_ENABLE; cmdpkt[2] = arg; cmdpkt[3] = arg >> 8; send_etm_cmd(cmdpkt, 3); return(0); } cmd_scw(argc, argv) char **argv; { u16 index, value; u_char cmdpkt[7]; index = strtoul(argv[1], 0, 0); value = strtoul(argv[2], 0, 0); cmdpkt[1] = STATS_CONFIG_WRITE; cmdpkt[2] = index; cmdpkt[3] = index >> 8; cmdpkt[4] = value; cmdpkt[5] = value >> 8; send_etm_cmd(cmdpkt, 5); return(0); } cmd_scr(argc, argv) char **argv; { u16 index; u_char cmdpkt[5]; index = strtoul(argv[1], 0, 0); cmdpkt[1] = STATS_CONFIG_READ; cmdpkt[2] = index; cmdpkt[3] = index >> 8; send_etm_cmd(cmdpkt, 3); return(0); } cmd_sr(argc, argv) char **argv; { u16 type, bitmask; u_char cmdpkt[7]; type = strtoul(argv[1], 0, 0); bitmask = strtoul(argv[2], 0, 16); cmdpkt[1] = STATS_READ; cmdpkt[2] = type; cmdpkt[3] = type >> 8; cmdpkt[4] = bitmask; cmdpkt[5] = bitmask >> 8; send_etm_cmd(cmdpkt, 5); return(0); } cmd_rfpw2(argc, argv) char **argv; { u16 index, value; u_char cmdpkt[7]; index = strtoul(argv[1], 0, 0); value = strtol(argv[2], 0, 0); cmdpkt[1] = RF_PARAM_WRITE; cmdpkt[2] = index; cmdpkt[3] = index >> 8; cmdpkt[4] = value; cmdpkt[5] = value >> 8; send_etm_cmd(cmdpkt, 5); return(0); } cmd_rfpw3(argc, argv) char **argv; { u16 index; u8 val1, val2; u_char cmdpkt[7]; index = strtoul(argv[1], 0, 0); val1 = strtoul(argv[2], 0, 0); val2 = strtoul(argv[3], 0, 0); cmdpkt[1] = RF_PARAM_WRITE; cmdpkt[2] = index; cmdpkt[3] = index >> 8; cmdpkt[4] = val1; cmdpkt[5] = val2; send_etm_cmd(cmdpkt, 5); return(0); } cmd_rfpw(argc, argv) char **argv; { switch (argc) { case 3: return cmd_rfpw2(argc, argv); case 4: return cmd_rfpw3(argc, argv); default: fprintf(stderr, "BUG: wrong argc in cmd_rfpw()\n"); return(ERROR_BUG); } } cmd_rfpr(argc, argv) char **argv; { u16 index; u_char cmdpkt[5]; index = strtoul(argv[1], 0, 0); cmdpkt[1] = RF_PARAM_READ; cmdpkt[2] = index; cmdpkt[3] = index >> 8; send_etm_cmd(cmdpkt, 3); return(0); }