Change requset type parameter back to uint8_t (fix type cast), support USB indicator pulse

This commit is contained in:
Nathan Conrad 2019-09-14 18:07:12 -04:00
parent 6e00886ffb
commit 64bfec79b2
5 changed files with 68 additions and 22 deletions

View File

@ -36,12 +36,12 @@
/* Blink pattern /* Blink pattern
* - 250 ms : device not mounted * - 250 ms : device not mounted
* - 1000 ms : device mounted * - 0 ms : device mounted
* - 2500 ms : device is suspended * - 2500 ms : device is suspended
*/ */
enum { enum {
BLINK_NOT_MOUNTED = 250, BLINK_NOT_MOUNTED = 250,
BLINK_MOUNTED = 1000, BLINK_MOUNTED = 0,
BLINK_SUSPENDED = 2500, BLINK_SUSPENDED = 2500,
}; };
@ -97,17 +97,46 @@ void tud_resume_cb(void)
} }
//--------------------------------------------------------------------+ //--------------------------------------------------------------------+
// BLINKING TASK // BLINKING TASK + Indicator pulse
//--------------------------------------------------------------------+ //--------------------------------------------------------------------+
volatile uint8_t doPulse = false;
// called from USB context
void led_indicator_pulse(void) {
doPulse = true;
}
void led_blinking_task(void) void led_blinking_task(void)
{ {
static uint32_t start_ms = 0; static uint32_t start_ms = 0;
static bool led_state = false; static bool led_state = false;
if(blink_interval_ms == BLINK_MOUNTED) // Mounted
{
if(doPulse)
{
led_state = true;
board_led_write(true);
start_ms = board_millis();
doPulse = false;
}
else if (led_state == true)
{
if ( board_millis() - start_ms < 750) //Spec says blink must be between 500 and 1000 ms.
{
return; // not enough time
}
led_state = false;
board_led_write(false);
}
}
else
{
// Blink every interval ms
if ( board_millis() - start_ms < blink_interval_ms) return; // not enough time
start_ms += blink_interval_ms;
// Blink every interval ms board_led_write(led_state);
if ( board_millis() - start_ms < blink_interval_ms) return; // not enough time led_state = 1 - led_state; // toggle
start_ms += blink_interval_ms; }
board_led_write(led_state);
led_state = 1 - led_state; // toggle
} }

View File

@ -0,0 +1,5 @@
#ifndef MAIN_H
#define MAIN_H
void led_indicator_pulse(void);
#endif

View File

@ -25,6 +25,7 @@
#include <strings.h> #include <strings.h>
#include "class/usbtmc/usbtmc_device.h" #include "class/usbtmc/usbtmc_device.h"
#include "main.h"
#if (USBTMC_CFG_ENABLE_488) #if (USBTMC_CFG_ENABLE_488)
usbtmc_response_capabilities_488_t const usbtmc_response_capabilities_488_t const
@ -39,7 +40,7 @@ usbtmcd_app_capabilities =
{ {
.listenOnly = 0, .listenOnly = 0,
.talkOnly = 0, .talkOnly = 0,
.supportsIndicatorPulse = 0 .supportsIndicatorPulse = 1
}, },
.bmDevCapabilities = { .bmDevCapabilities = {
.canEndBulkInOnTermChar = 0 .canEndBulkInOnTermChar = 0
@ -63,7 +64,7 @@ usbtmcd_app_capabilities =
#endif #endif
}; };
static const char idn[] = "TinyUSB,ModelNumber,SerialNumber,FirmwareVer"; static const char idn[] = "TinyUSB,ModelNumber,SerialNumber,FirmwareVer\n";
static uint8_t status; static uint8_t status;
static bool queryReceived = false; static bool queryReceived = false;
@ -96,7 +97,7 @@ bool usbtmcd_app_msgBulkIn_complete(uint8_t rhport)
return true; return true;
} }
static uint8_t noQueryMsg[] = "ERR: No query"; static uint8_t noQueryMsg[] = "ERR: No query\n";
bool usbtmcd_app_msgBulkIn_request(uint8_t rhport, usbtmc_msg_request_dev_dep_in const * request) bool usbtmcd_app_msgBulkIn_request(uint8_t rhport, usbtmc_msg_request_dev_dep_in const * request)
{ {
usbtmc_msg_dev_dep_msg_in_header_t hdr = { usbtmc_msg_dev_dep_msg_in_header_t hdr = {
@ -127,7 +128,7 @@ bool usbtmcd_app_msgBulkIn_request(uint8_t rhport, usbtmc_msg_request_dev_dep_in
} }
// Return status byte, but put the transfer result status code in the rspResult argument. // Return status byte, but put the transfer result status code in the rspResult argument.
uint8_t usbtmcd_app_get_stb(uint8_t rhport, usbtmc_status_enum *rspResult) uint8_t usbtmcd_app_get_stb(uint8_t rhport, uint8_t *rspResult)
{ {
(void)rhport; (void)rhport;
*rspResult = USBTMC_STATUS_SUCCESS; *rspResult = USBTMC_STATUS_SUCCESS;
@ -137,3 +138,7 @@ uint8_t usbtmcd_app_get_stb(uint8_t rhport, usbtmc_status_enum *rspResult)
return status; return status;
} }
bool usbtmcd_app_indicator_pluse(uint8_t rhport, tusb_control_request_t const * msg)
{
led_indicator_pulse();
}

View File

@ -39,17 +39,18 @@
//Limitations (not planned to be implemented): //Limitations (not planned to be implemented):
// "vendor-specific" commands are not handled // "vendor-specific" commands are not handled
// Dealing with "termchar" must be handled by the application layer,
// though additional error checking is does in this module.
// TODO: // TODO:
// USBTMC 3.2.2 error conditions not strictly followed // USBTMC 3.2.2 error conditions not strictly followed
// No local lock-out, REN, or GTL. // No local lock-out, REN, or GTL.
// Cannot issue clear. // Cannot handle clear.
// No "capabilities" supported // Not all "capabilities" supported
// Interrupt-IN endpoint
// 488 MsgID=Trigger
// Clear message available status byte at the correct time? (488 4.3.1.3) // Clear message available status byte at the correct time? (488 4.3.1.3)
// Split transfers // Split transfers
// No CLEAR_FEATURE/HALT (yet) // No CLEAR_FEATURE/HALT no EP (yet)
// No aborting transfers.
#if (TUSB_OPT_DEVICE_ENABLED && CFG_TUD_USBTMC) #if (TUSB_OPT_DEVICE_ENABLED && CFG_TUD_USBTMC)
@ -156,8 +157,11 @@ void usbtmcd_init(void)
{ {
#if USBTMC_CFG_ENABLE_488 #if USBTMC_CFG_ENABLE_488
if(usbtmcd_app_capabilities.bmIntfcCapabilities488.supportsTrigger) if(usbtmcd_app_capabilities.bmIntfcCapabilities488.supportsTrigger)
TU_ASSERT(usbtmcd_app_msg_trigger != NULL,); TU_ASSERT(&usbtmcd_app_msg_trigger != NULL,);
#endif #endif
if(usbtmcd_app_capabilities.bmIntfcCapabilities.supportsIndicatorPulse)
TU_ASSERT(&usbtmcd_app_indicator_pluse != NULL,);
} }
bool usbtmcd_open(uint8_t rhport, tusb_desc_interface_t const * itf_desc, uint16_t *p_length) bool usbtmcd_open(uint8_t rhport, tusb_desc_interface_t const * itf_desc, uint16_t *p_length)
@ -400,8 +404,9 @@ bool usbtmcd_control_request(uint8_t rhport, tusb_control_request_t const * requ
return true; return true;
// USBTMC Optional Requests // USBTMC Optional Requests
case USBTMC_bREQUEST_INDICATOR_PULSE: // Optional case USBTMC_bREQUEST_INDICATOR_PULSE: // Optional
TU_VERIFY(false); TU_VERIFY(usbtmcd_app_capabilities.bmIntfcCapabilities.supportsIndicatorPulse);
return false; TU_VERIFY(usbtmcd_app_indicator_pluse(rhport, request));
return true;
#if (USBTMC_CFG_ENABLE_488) #if (USBTMC_CFG_ENABLE_488)
// USB488 required requests // USB488 required requests

View File

@ -64,8 +64,10 @@ bool usbtmcd_app_msgBulkIn_request(uint8_t rhport, usbtmc_msg_request_dev_dep_in
bool usbtmcd_app_msgBulkIn_complete(uint8_t rhport); bool usbtmcd_app_msgBulkIn_complete(uint8_t rhport);
TU_ATTR_WEAK bool usbtmcd_app_indicator_pluse(uint8_t rhport, tusb_control_request_t const * msg);
#if (USBTMC_CFG_ENABLE_488) #if (USBTMC_CFG_ENABLE_488)
uint8_t usbtmcd_app_get_stb(uint8_t rhport, usbtmc_status_enum *rspResult); uint8_t usbtmcd_app_get_stb(uint8_t rhport, uint8_t *rspResult);
TU_ATTR_WEAK bool usbtmcd_app_msg_trigger(uint8_t rhport, usbtmc_msg_generic_t* msg); TU_ATTR_WEAK bool usbtmcd_app_msg_trigger(uint8_t rhport, usbtmc_msg_generic_t* msg);
//TU_ATTR_WEAK bool usbtmcd_app_go_to_local(uint8_t rhport); //TU_ATTR_WEAK bool usbtmcd_app_go_to_local(uint8_t rhport);
#endif #endif