Difference between revisions of "Component: USB Slave (Comms: USB)"

From Flowcode Help
Jump to navigationJump to search
 
Line 17: Line 17:
 
==Component Source Code==
 
==Component Source Code==
  
Please click here to download the component source project: [https://www.flowcode.co.uk/wiki/componentsource/FC_Comp_Source_temp/USBSlave.fcfx FC_Comp_Source_temp/USBSlave.fcfx]
+
Please click here to download the component source project: [https://www.flowcode.co.uk/wiki/componentsource/FC_Comp_Source_USBSlave.fcfx FC_Comp_Source_USBSlave.fcfx]
  
Please click here to view the component source code (Beta): [https://www.flowcode.co.uk/FlowchartView/?wfile=componentsource/FC_Comp_Source_temp/USBSlave.fcfx FC_Comp_Source_temp/USBSlave.fcfx]
+
Please click here to view the component source code (Beta): [https://www.flowcode.co.uk/FlowchartView/?wfile=componentsource/FC_Comp_Source_USBSlave.fcfx FC_Comp_Source_USBSlave.fcfx]
  
 
==Detailed description==
 
==Detailed description==
Line 48: Line 48:
  
 
''<span style="color:red;">No additional examples</span>''
 
''<span style="color:red;">No additional examples</span>''
 +
 +
  
  

Latest revision as of 13:13, 7 February 2023

Author Matrix Ltd.
Version 1.3
Category Comms: USB


USB Slave component

Component to create and communicate using a generic USB communications profile. Has the ability to allow the device to be a slave to the PC. Compatible with simulation and USB enabled microcontroller devices (PIC/dsPIC).

Component Source Code

Please click here to download the component source project: FC_Comp_Source_USBSlave.fcfx

Please click here to view the component source code (Beta): FC_Comp_Source_USBSlave.fcfx

Detailed description

No detailed description exists yet for this component

Examples

No additional examples






Macro reference

CheckRx

Fc9-comp-macro.png CheckRx
Called to check if there is any incoming data waiting to be received. Returns the number of incoming data bytes. Only needed when not running the slave service. 
Fc9-u8-icon.png - BYTE Return


GetByte

Fc9-comp-macro.png GetByte
Retreives the byte at location Idx from the incoming data buffer. 
Fc9-u8-icon.png - BYTE Idx
Specifies the location in the incoming buffer 
Fc9-u8-icon.png - BYTE Return


GetString

Fc9-comp-macro.png GetString
Retreives a string of data from the incoming data buffer starting from location 0 and incrementing up to the NumBytes parameter. 
Fc9-u8-icon.png - BYTE NumBytes
Specifies the maximum number of bytes to try and read. 
Fc9-string-icon.png - STRING Return


Initialise

Fc9-comp-macro.png Initialise
Starts up the USB communications and attempts to enumerate. Returns 0 for a successful startup or 255 for a enumeration timeout. 
Fc9-u8-icon.png - BYTE Return


RunSlaveService

Fc9-comp-macro.png RunSlaveService
Stalls the microcontroller and waits for an incoming message from the USB, when a message is received the macro defined in the USB Slave properties is automatically run. While the macro is running you can choose to send data back to the PC if you wish. 
Fc9-void-icon.png - VOID Return


SendByte

Fc9-comp-macro.png SendByte
Adds the byte onto the end of the outgoing data buffer. 
Fc9-u8-icon.png - BYTE Data
Data byte to transmit to the host 
Fc9-u8-icon.png - BYTE Return


SendByteArray

Fc9-comp-macro.png SendByteArray
Adds an array of bytes onto the end of the outgoing data buffer. 
[[File:]] - Data
Data Bytes To Send 
Fc9-u8-icon.png - BYTE Length
Max number of bytes to try and add to the outgoing buffer. 
Fc9-u8-icon.png - BYTE Return


SendString

Fc9-comp-macro.png SendString
Adds a string of bytes onto the end of the outgoing data buffer. 
Fc9-string-icon.png - STRING Data
Data String To Send 
Fc9-u8-icon.png - BYTE Length
Max number of bytes to try and add to the outgoing buffer. 
Fc9-u8-icon.png - BYTE Return


StopSlaveService

Fc9-comp-macro.png StopSlaveService
Allows the microcontroller to leave the stalled slave mode and resume its normal independant functionality. Must be called from within the slave service routine to work correctly. 
Fc9-void-icon.png - VOID Return


Property reference

Fc9-prop-icon.png Properties
Fc9-conn-icon.png USB Properties
Fc9-type-21-icon.png Vendor ID
USB VID 
Fc9-type-21-icon.png Product ID
USB PID 
Fc9-type-10-icon.png Device Name
USB Device Name 
Fc9-type-10-icon.png Manufacturer
USB Manufacturer 
Fc9-type-14-icon.png Major Version
USB Major Version Number 
Fc9-type-14-icon.png Minor Version
USB Minor Version Number 
Fc9-type-7-icon.png Enumeration Timeout
Specifies if the enumeration (Initialise function) can timeout if taking too long. 
Fc9-type-16-icon.png Country Code
Country code used by some regional based USB devices 
Fc9-type-14-icon.png Maximum Current (mA)
Maximum amount of current the USB host will provide before shutting down the USB channel. 
Fc9-conn-icon.png Slave Macro Properties
Fc9-type-10-icon.png Slave Macro
Flowcode macro to call while the slave service is enabled 
Fc9-type-16-icon.png Macro Parameters
Defines the parameters for the slave service macro allowing data from the host to be automatically passed into the macro. 
Fc9-conn-icon.png USB Driver
Fc9-type-10-icon.png Driver Directory
Directory to save the generated device driver .inf file 
Fc9-type-10-icon.png Driver Filename
Filename assigned to the USB device driver .inf file when generated. 
Fc9-type-7-icon.png Generate Driver
Generates a driver file when set to Yes, Automatically jumps back to No when complete. 
Fc9-conn-icon.png Simulation
Fc9-type-16-icon.png Instance
Hardware instance to communicate with any connected USB slave devices. 
Fc9-type-21-icon.png Timeout (ms)
Simulation host to slave communications timeout in milliseconds 
Fc9-type-10-icon.png Label
Text displayed on the I/O flasher comms component.