modified: source/inlprog.c
-introducing getopt to obtain commandline args modified: source/usb_operations.c -moving USB defn comments in from main
This commit is contained in:
parent
4cbeff1ecf
commit
cfffe554be
|
|
@ -1,84 +1,130 @@
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
|
#include <ctype.h>
|
||||||
#include <assert.h>
|
#include <assert.h>
|
||||||
#include <errno.h>
|
#include <errno.h>
|
||||||
|
#include <unistd.h>
|
||||||
#include <libusb.h>
|
#include <libusb.h>
|
||||||
|
|
||||||
//uncomment to DEBUG this file alone
|
//uncomment to DEBUG this file alone
|
||||||
//#define DEBUG
|
#define DEBUG
|
||||||
//"make debug" to get DEBUG msgs on entire program
|
//"make debug" to get DEBUG msgs on entire program
|
||||||
#include "dbg.h"
|
#include "dbg.h"
|
||||||
|
|
||||||
#include "usb_operations.h"
|
#include "usb_operations.h"
|
||||||
|
|
||||||
//control transfer request types
|
|
||||||
//uint8_t libusb_control_setup::bmRequestType
|
|
||||||
//Request type.
|
|
||||||
// Bits 0:4 determine recipient, see libusb_request_recipient. Bits 5:6 determine type, see libusb_request_type. Bit 7 determines data transfer direction, see libusb_endpoint_direction.
|
|
||||||
//
|
|
||||||
//libusb_request_types:
|
|
||||||
//LIBUSB_REQUEST_TYPE_STANDARD Standard handled by driver during setup/etc
|
|
||||||
//LIBUSB_REQUEST_TYPE_CLASS Class for use with specific device classes like HID.
|
|
||||||
//LIBUSB_REQUEST_TYPE_VENDOR Vendor application specific as we choose which is what we'll be utilizing for all transfers
|
|
||||||
//LIBUSB_REQUEST_TYPE_RESERVED Reserved.
|
|
||||||
//
|
|
||||||
//libusb_request_recipients:
|
|
||||||
//LIBUSB_RECIPIENT_DEVICE Device.
|
|
||||||
//LIBUSB_RECIPIENT_INTERFACE Interface.
|
|
||||||
//LIBUSB_RECIPIENT_ENDPOINT Endpoint.
|
|
||||||
//LIBUSB_RECIPIENT_OTHER Other.
|
|
||||||
//
|
|
||||||
//LIBUSB_ENDPOINT_IN In: device-to-host.
|
|
||||||
//LIBUSB_ENDPOINT_OUT Out: host-to-device.
|
|
||||||
|
|
||||||
// vendor requests also defined in firmware
|
// vendor requests also defined in firmware
|
||||||
// TODO put in combined .h file for both host and fw
|
// TODO put in combined .h file for both host and fw
|
||||||
#define REQ_LED_ON 1
|
#define REQ_LED_ON 1
|
||||||
#define REQ_LED_OFF 2
|
#define REQ_LED_OFF 2
|
||||||
|
|
||||||
//USB timeout
|
|
||||||
#define SEC_5 5000
|
|
||||||
|
|
||||||
int main(int argc, char *argv[])
|
int main(int argc, char *argv[])
|
||||||
{
|
{
|
||||||
|
check(argc > 1, "USAGE: inlretro <action o/f>");
|
||||||
|
|
||||||
|
int o_flag = 0; //LED ON
|
||||||
|
int f_flag = 0; //LED OFF
|
||||||
|
int e_flag = 0; //ERASE
|
||||||
|
int m_flag = 0; //MIRROR
|
||||||
|
char *w_value = NULL; //WRITE FILE
|
||||||
|
char *d_value = NULL; //DUMP FILE
|
||||||
|
char *s_value = NULL; //SAVE FILE
|
||||||
|
char *i_value = NULL; //iNES MAPPER
|
||||||
|
char *b_value = NULL; //BOARD
|
||||||
|
|
||||||
|
int index = 0;
|
||||||
|
int rv = 0;
|
||||||
|
opterr = 0;
|
||||||
|
|
||||||
|
//getopt returns args till done then returns -1
|
||||||
|
//string of possible args : denotes 1 required additional arg
|
||||||
|
//:: denotes optional additional arg follows
|
||||||
|
while( (rv = getopt( argc, argv, "ofemw:d:s:i:b:")) != -1) {
|
||||||
|
|
||||||
|
switch(rv) {
|
||||||
|
case 'o':
|
||||||
|
o_flag = 1;
|
||||||
|
break;
|
||||||
|
case 'f':
|
||||||
|
f_flag = 1;
|
||||||
|
break;
|
||||||
|
case 'e':
|
||||||
|
e_flag = 1;
|
||||||
|
break;
|
||||||
|
case 'm':
|
||||||
|
m_flag = 1;
|
||||||
|
break;
|
||||||
|
case 'w':
|
||||||
|
w_value = optarg;
|
||||||
|
break;
|
||||||
|
case 'd':
|
||||||
|
d_value = optarg;
|
||||||
|
break;
|
||||||
|
case 's':
|
||||||
|
s_value = optarg;
|
||||||
|
break;
|
||||||
|
case 'i':
|
||||||
|
i_value = optarg;
|
||||||
|
break;
|
||||||
|
case 'b':
|
||||||
|
b_value = optarg;
|
||||||
|
break;
|
||||||
|
case '?':
|
||||||
|
if ( optopt == 'w' ) {
|
||||||
|
log_err("Option -%c requires an argument.", optopt);
|
||||||
|
} else if ( optopt == 'd' ) {
|
||||||
|
log_err("Option -%c requires an argument.", optopt);
|
||||||
|
} else if ( optopt == 's' ) {
|
||||||
|
log_err("Option -%c requires an argument.", optopt);
|
||||||
|
} else if ( optopt == 'i' ) {
|
||||||
|
log_err("Option -%c requires an argument.", optopt);
|
||||||
|
} else if ( optopt == 'b' ) {
|
||||||
|
log_err("Option -%c requires an argument.", optopt);
|
||||||
|
} else if ( isprint(optopt)) {
|
||||||
|
log_err("Unknown option -%c .", optopt);
|
||||||
|
} else {
|
||||||
|
log_err("Unknown option character '\\x%x'", optopt);
|
||||||
|
}
|
||||||
|
log_err("Improper arguements passed");
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
sentinel("getopt failed to catch all arg cases");
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
debug("flags= o:%d f:%d e:%d m:%d", o_flag, f_flag, e_flag, m_flag);
|
||||||
|
debug("args= w:%s d:%s s:%s i:%s b:%s", w_value, d_value, s_value, i_value, b_value);
|
||||||
|
for( index = optind; index < argc; index++) {
|
||||||
|
log_err("Non-option arguement: %s \n", argv[index]);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
//context set to NULL since only acting as single user of libusb
|
//context set to NULL since only acting as single user of libusb
|
||||||
libusb_context *context = NULL;
|
libusb_context *context = NULL;
|
||||||
|
//create usb device handle pointer to interact with retro-prog
|
||||||
libusb_device_handle *rprog_handle = NULL;
|
libusb_device_handle *rprog_handle = NULL;
|
||||||
|
|
||||||
rprog_handle = open_usb_device( context );
|
rprog_handle = open_usb_device( context );
|
||||||
check( rprog_handle != NULL, "Unable to open INL retro-prog usb device handle.");
|
check( rprog_handle != NULL, "Unable to open INL retro-prog usb device handle.");
|
||||||
|
|
||||||
|
|
||||||
int xfr_cnt = 0;
|
int xfr_cnt = 0;
|
||||||
//uint8_t buffer8[8]; //8 is max payload for low speed devices' data packet
|
//uint8_t buffer8[8]; //8 is max payload for low speed devices' data packet
|
||||||
//uint8_t buffer128[128]; //128 largest power of 2 for non-LONG_TRANSFERS with V-USB
|
//uint8_t buffer128[128]; //128 largest power of 2 for non-LONG_TRANSFERS with V-USB
|
||||||
uint8_t buffer254[254]; //254 is max for non-LONG_TRANSFERS with V-USB
|
uint8_t buffer254[254]; //254 is max for non-LONG_TRANSFERS with V-USB
|
||||||
//uint8_t buffer16k[16384]; //16384 is max for LONG_TRANSFERS with V-USB
|
//uint8_t buffer16k[16384]; //16384 is max for LONG_TRANSFERS with V-USB
|
||||||
|
|
||||||
if (argc < 2) {
|
if (o_flag) { //ON send REQ_LED_ON
|
||||||
printf("USAGE: inlretro <action o/f>\n");
|
|
||||||
exit(1);
|
|
||||||
}
|
|
||||||
char action = argv[1][0];
|
|
||||||
|
|
||||||
switch (action) {
|
|
||||||
case 'o': //ON send REQ_LED_ON
|
|
||||||
xfr_cnt = usb_write_to_device( rprog_handle,
|
xfr_cnt = usb_write_to_device( rprog_handle,
|
||||||
REQ_LED_ON, (unsigned char *)buffer254, sizeof(buffer254) );
|
REQ_LED_ON, (unsigned char *)buffer254, sizeof(buffer254) );
|
||||||
printf("total bytes xfrd: %d \n", xfr_cnt);
|
printf("total bytes xfrd: %d \n", xfr_cnt);
|
||||||
break;
|
}
|
||||||
|
if (f_flag) { //OFF send REQ_LED_OFF
|
||||||
case 'f':
|
|
||||||
xfr_cnt = usb_write_to_device( rprog_handle,
|
xfr_cnt = usb_write_to_device( rprog_handle,
|
||||||
REQ_LED_OFF, (unsigned char *)buffer254, sizeof(buffer254) );
|
REQ_LED_OFF, (unsigned char *)buffer254, sizeof(buffer254) );
|
||||||
printf("total bytes xfrd: %d \n", xfr_cnt);
|
printf("total bytes xfrd: %d \n", xfr_cnt);
|
||||||
|
|
||||||
break;
|
|
||||||
|
|
||||||
default:
|
|
||||||
printf("Invalid action o-on f-off\n");
|
|
||||||
exit(1);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
close_usb( context, rprog_handle);
|
close_usb( context, rprog_handle);
|
||||||
|
|
|
||||||
|
|
@ -12,6 +12,29 @@
|
||||||
|
|
||||||
#include "usb_operations.h"
|
#include "usb_operations.h"
|
||||||
|
|
||||||
|
//USB timeout
|
||||||
|
#define SEC_5 5000
|
||||||
|
|
||||||
|
//control transfer request types
|
||||||
|
//uint8_t libusb_control_setup::bmRequestType
|
||||||
|
//Request type.
|
||||||
|
// Bits 0:4 determine recipient, see libusb_request_recipient. Bits 5:6 determine type, see libusb_request_type. Bit 7 determines data transfer direction, see libusb_endpoint_direction.
|
||||||
|
//
|
||||||
|
//libusb_request_types:
|
||||||
|
//LIBUSB_REQUEST_TYPE_STANDARD Standard handled by driver during setup/etc
|
||||||
|
//LIBUSB_REQUEST_TYPE_CLASS Class for use with specific device classes like HID.
|
||||||
|
//LIBUSB_REQUEST_TYPE_VENDOR Vendor application specific as we choose which is what we'll be utilizing for all transfers
|
||||||
|
//LIBUSB_REQUEST_TYPE_RESERVED Reserved.
|
||||||
|
//
|
||||||
|
//libusb_request_recipients:
|
||||||
|
//LIBUSB_RECIPIENT_DEVICE Device.
|
||||||
|
//LIBUSB_RECIPIENT_INTERFACE Interface.
|
||||||
|
//LIBUSB_RECIPIENT_ENDPOINT Endpoint.
|
||||||
|
//LIBUSB_RECIPIENT_OTHER Other.
|
||||||
|
//
|
||||||
|
//LIBUSB_ENDPOINT_IN In: device-to-host.
|
||||||
|
//LIBUSB_ENDPOINT_OUT Out: host-to-device.
|
||||||
|
|
||||||
libusb_device_handle * open_usb_device( libusb_context *context )
|
libusb_device_handle * open_usb_device( libusb_context *context )
|
||||||
{
|
{
|
||||||
int rv = 0;
|
int rv = 0;
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue