123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906 |
- /*
- This software is subject to the license described in the License.txt file
- included with this software distribution. You may not use this file except
- in compliance with this license.
- Copyright (c) Dynastream Innovations Inc. 2016
- All rights reserved.
- */
- #include <stdio.h>
- #include <assert.h>
- #include "demo.h"
- #include "types.h"
- #include "antdefines.h"
- #include "antmessage.h"
- #include "libant.h"
- #include <stdio.h>
- #include <assert.h>
- #define ENABLE_EXTENDED_MESSAGES // Un - comment to enable extended messages.
- #define USER_BAUDRATE (57600) // For AP1, use 50000; for AT3/AP2, use 57600
- #define USER_RADIOFREQ (35) // RF Frequency + 2400 MHz
- #define USER_ANTCHANNEL (0) // ANT channel to use
- #define USER_DEVICENUM (49) // Device number
- #define USER_DEVICETYPE (1) // Device type
- #define USER_TRANSTYPE (1) // Transmission type
- #define USER_NETWORK_KEY {0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,}
- #define USER_NETWORK_NUM (0) // The network key is assigned to this network number
- #define MAX_CHANNEL_EVENT_SIZE (MESG_MAX_SIZE_VALUE) // Channel event buffer size, assumes worst case extended message size
- #define MAX_RESPONSE_SIZE (MESG_MAX_SIZE_VALUE) // Protocol response buffer size
- // Indexes into message recieved from ANT
- #define MESSAGE_BUFFER_DATA1_INDEX ((UCHAR) 0)
- #define MESSAGE_BUFFER_DATA2_INDEX ((UCHAR) 1)
- #define MESSAGE_BUFFER_DATA3_INDEX ((UCHAR) 2)
- #define MESSAGE_BUFFER_DATA4_INDEX ((UCHAR) 3)
- #define MESSAGE_BUFFER_DATA5_INDEX ((UCHAR) 4)
- #define MESSAGE_BUFFER_DATA6_INDEX ((UCHAR) 5)
- #define MESSAGE_BUFFER_DATA7_INDEX ((UCHAR) 6)
- #define MESSAGE_BUFFER_DATA8_INDEX ((UCHAR) 7)
- #define MESSAGE_BUFFER_DATA9_INDEX ((UCHAR) 8)
- #define MESSAGE_BUFFER_DATA10_INDEX ((UCHAR) 9)
- #define MESSAGE_BUFFER_DATA11_INDEX ((UCHAR) 10)
- #define MESSAGE_BUFFER_DATA12_INDEX ((UCHAR) 11)
- #define MESSAGE_BUFFER_DATA13_INDEX ((UCHAR) 12)
- #define MESSAGE_BUFFER_DATA14_INDEX ((UCHAR) 13)
- // Local Variables
- static UCHAR ucChannelType; // Channel type as chosen by user (master or slave)
- static UCHAR aucChannelBuffer[MAX_CHANNEL_EVENT_SIZE];
- static UCHAR aucResponseBuffer[MAX_RESPONSE_SIZE];
- static UCHAR aucTransmitBuffer[ANT_STANDARD_DATA_PAYLOAD_SIZE];
- static BOOL bDone;
- static BOOL bDisplay;
- static BOOL bBroadcasting;
- static UCHAR ucDeviceNumber;
- // Declare callback functions into the library.
- static BOOL Test_ChannelCallback(UCHAR ucChannel_, UCHAR ucEvent_);
- static BOOL Test_ResponseCallback(UCHAR ucChannel_, UCHAR ucMessageId_);
- static void PrintMenu();
- ////////////////////////////////////////////////////////////////////////////////
- // main
- //
- // Usage:
- //
- // c:\DEMO_DLL.exe [device_no] [channel_type]
- //
- // ... where
- //
- // device_no: USB Device port, starting at 0
- // channel_type: Master = 0, Slave = 1
- //
- // ... example
- //
- // c:\Demo_DLL.exe 0 0
- //
- // Comment to USB port 0 and open a Master channel
- //
- // If optional arguements are not supplied, user will
- // be prompted to enter these after the program starts.
- //
- ////////////////////////////////////////////////////////////////////////////////
- int main(int argc, char **argv)
- {
- ucDeviceNumber = 0xFF;
- UCHAR ucChannelType = CHANNEL_TYPE_INVALID;
- if(argc > 2)
- {
- ucDeviceNumber = (UCHAR) atoi(argv[1]);
- ucChannelType = (UCHAR) atoi(argv[2]);
- }
- Test_Init(ucDeviceNumber,ucChannelType);
- Test_Start();
- return 0;
- }
- ////////////////////////////////////////////////////////////////////////////////
- // Test_Init
- //
- // Initialize test parameters.
- //
- // ucDeviceNumber_: USB Device Number (0 for first USB stick plugged and so on)
- // If not specified on command line, 0xFF is passed in as invalid.
- // ucChannelType_: ANT Channel Type. 0 = Master, 1 = Slave
- // If not specified, 2 is passed in as invalid.
- //
- ////////////////////////////////////////////////////////////////////////////////
- void Test_Init(UCHAR ucDeviceNumber_, UCHAR ucChannelType_)
- {
- BOOL bStatus;
- // Load the ANT DLL functions.
- if(!ANT_Load())
- {
- printf("Failed to load ANT Library\n");
- exit(0);
- }
- // Get library version
- if(ANT_LibVersionSupport())
- {
- printf("ANT Library Version %s\n", ANT_LibVersion());
- }
- // If no device number was specified on the command line,
- // prompt the user for input.
- if(ucDeviceNumber_ == 0xFF)
- {
- printf("Device number?\n"); fflush(stdout);
- scanf("%u", &ucDeviceNumber_);
- char st[1024];
- fgets(st, sizeof(st), stdin);
- sscanf(st, "%u", &ucDeviceNumber_);
- }
- ucChannelType = ucChannelType_;
- bDone = FALSE;
- bDisplay = TRUE;
- bBroadcasting = FALSE;
- // The device number depends on how many USB sticks have been
- // plugged into the PC. The first USB stick plugged will be 0
- // the next 1 and so on.
- //
- // The Baud Rate depends on the ANT solution being used. AP1
- // is 50000, all others are 57600
- bStatus = ANT_Init(ucDeviceNumber_, USER_BAUDRATE);
- assert(bStatus);
- // Assign callback functions. One for serial message responses
- // and the other for channel events. Each channel event can have
- // its own callback function defined. Since we are only
- // going to open one channel, setup one callback function
- // for the channel callback
- ANT_AssignResponseFunction(Test_ResponseCallback, aucResponseBuffer);
- ANT_AssignChannelEventFunction(USER_ANTCHANNEL,Test_ChannelCallback, aucChannelBuffer);
- printf("Initialization was successful!\n"); fflush(stdout);
- return;
- }
- ////////////////////////////////////////////////////////////////////////////////
- // Test_Start
- //
- // Start the Test program.
- //
- ////////////////////////////////////////////////////////////////////////////////
- void Test_Start()
- {
- // Print out the menu to start
- PrintMenu();
- // If the channel type has not been set at the command line,
- // prompt the user to specify now.
- do
- {
- if(ucChannelType == CHANNEL_TYPE_INVALID)
- {
- printf("Channel Type? (Master = 0, Slave = 1)\n");
- char st[1024];
- fgets(st, sizeof(st), stdin);
- sscanf(st, "%u", &ucChannelType);
- }
- if(ucChannelType != 0 && ucChannelType != 1)
- {
- ucChannelType = CHANNEL_TYPE_INVALID;
- printf("Error: invalid channel type\n");
- }
- } while(ucChannelType == CHANNEL_TYPE_INVALID);
- // Reset system
- printf("Resetting module...\n");
- ANT_ResetSystem(); // Soft reset
- ANT_Nap(1000); // Need to delay after a reset
- // Set Network key to start of ANT initialization
- printf("Setting network key...\n");
- UCHAR ucNetKey[8] = USER_NETWORK_KEY;
- ANT_SetNetworkKey(USER_NETWORK_NUM, ucNetKey);
- while(!bDone)
- {
- UCHAR ucChar;
- char st[1024];
- fgets(st, sizeof(st), stdin);
- sscanf(st, "%c", &ucChar);
- switch(ucChar)
- {
- case 'M':
- case 'm':
- {
- // Printout options
- PrintMenu();
- break;
- }
- case 'Q':
- case 'q':
- {
- // Quit
- printf("Closing channel...\n");
- bBroadcasting = FALSE;
- ANT_CloseChannel(USER_ANTCHANNEL);
- break;
- }
- case 'A':
- case 'a':
- {
- // Send Acknowledged data
- UCHAR aucTempBuffer[] = {1,2,3,4,5,6,7,8};
- ANT_SendAcknowledgedData(USER_ANTCHANNEL, aucTempBuffer);
- break;
- }
- case 'B':
- case 'b':
- {
- // Send Burst Data (10 packets)
- UCHAR aucTempBuffer[8*10];
- for (int i = 0; i < 8*10; i++)
- aucTempBuffer[i] = i;
- ANT_SendBurstTransfer(USER_ANTCHANNEL, aucTempBuffer, 10);
- break;
- }
- case 'r':
- case 'R':
- {
- // Reset system
- printf("Resetting module...\n");
- ANT_ResetSystem(); // Soft reset
- ANT_Nap(1000); // Need to delay after a reset
- // Restart the test by setting network key
- printf("Setting network key...\n");
- ANT_SetNetworkKey(USER_NETWORK_NUM, ucNetKey);
- break;
- }
- case 'c':
- case 'C':
- {
- // Request capabilites.
- ANT_RequestMessage(USER_ANTCHANNEL, MESG_CAPABILITIES_ID);
- break;
- }
- case 'v':
- case 'V':
- {
- // Request version
- ANT_RequestMessage(USER_ANTCHANNEL, MESG_VERSION_ID);
- break;
- }
- case 'S':
- case 's':
- {
- // Request channel status
- ANT_RequestMessage(USER_ANTCHANNEL, MESG_CHANNEL_STATUS_ID);
- break;
- }
- case 'I':
- case 'i':
- {
- // Request channel ID
- ANT_RequestMessage(USER_ANTCHANNEL, MESG_CHANNEL_ID_ID);
- break;
- }
- case 'd':
- case 'D':
- {
- bDisplay = !bDisplay;
- break;
- }
- case 'u':
- case 'U':
- {
- // Print out information about the USB device we are connected to
- printf("USB Device Description\n");
- USHORT usDevicePID;
- USHORT usDeviceVID;
- UCHAR aucDeviceDescription[256];
- UCHAR aucDeviceSerial[256];
- // Retrieve info
- if(ANT_GetDeviceUSBVID(&usDeviceVID))
- {
- printf(" VID: 0x%X\n", usDeviceVID);
- }
- if(ANT_GetDeviceUSBPID(&usDevicePID))
- {
- printf(" PID: 0x%X\n", usDevicePID);
- }
- if(ANT_GetDeviceUSBInfo(ucDeviceNumber, aucDeviceDescription, aucDeviceSerial))
- {
- printf(" Product Description: %s\n", aucDeviceDescription);
- printf(" Serial String: %s\n", aucDeviceSerial);
- }
- break;
- }
- default:
- {
- break;
- }
- }
- ANT_Nap(0);
- }
- // Clean up ANT
- printf("Disconnecting module...\n");
- ANT_Close();
- printf("Demo has completed successfully!\n");
- return;
- }
- ////////////////////////////////////////////////////////////////////////////////
- // Test_ChannelCallback
- //
- // Callback function passed to ANT DLL. Called whenever a channel event
- // is recieved.
- //
- // ucChannel_: Channel number of event
- // ucEvent_: Channel event as described in section 9.5.6 of the messaging document
- ////////////////////////////////////////////////////////////////////////////////
- BOOL Test_ChannelCallback(UCHAR ucChannel_, UCHAR ucEvent_)
- {
- BOOL bPrintBuffer = FALSE;
- UCHAR ucDataOffset = MESSAGE_BUFFER_DATA2_INDEX; // For most data messages
- switch(ucEvent_)
- {
- case EVENT_TX:
- {
- // This event indicates that a message has just been
- // sent over the air. We take advantage of this event to set
- // up the data for the next message period.
- static UCHAR ucIncrement = 0; // Increment the first byte of the buffer
- aucTransmitBuffer[0] = ucIncrement++;
- // Broadcast data will be sent over the air on
- // the next message period.
- if(bBroadcasting)
- {
- ANT_SendBroadcastData( USER_ANTCHANNEL,aucTransmitBuffer);
- // Echo what the data will be over the air on the next message period.
- if(bDisplay)
- {
- printf("Tx:(%d): [%02x],[%02x],[%02x],[%02x],[%02x],[%02x],[%02x],[%02x]\n",
- USER_ANTCHANNEL,
- aucTransmitBuffer[MESSAGE_BUFFER_DATA1_INDEX],
- aucTransmitBuffer[MESSAGE_BUFFER_DATA2_INDEX],
- aucTransmitBuffer[MESSAGE_BUFFER_DATA3_INDEX],
- aucTransmitBuffer[MESSAGE_BUFFER_DATA4_INDEX],
- aucTransmitBuffer[MESSAGE_BUFFER_DATA5_INDEX],
- aucTransmitBuffer[MESSAGE_BUFFER_DATA6_INDEX],
- aucTransmitBuffer[MESSAGE_BUFFER_DATA7_INDEX],
- aucTransmitBuffer[MESSAGE_BUFFER_DATA8_INDEX]);
- }
- else
- {
- static int iIndex = 0;
- static char ac[] = {'|','/','-','\\'};
- printf("Tx: %c\r",ac[iIndex++]); fflush(stdout);
- iIndex &= 3;
- }
- }
- break;
- }
- case EVENT_RX_FLAG_ACKNOWLEDGED:
- case EVENT_RX_FLAG_BURST_PACKET:
- case EVENT_RX_FLAG_BROADCAST:
- {
- // This is an event generated by the DLL. It is not strictly
- // returned by the ANT part. To enable, must call ANT_RxExtMesgsEnable first.
- // This event has a flag at the end of the data payload
- // that indicates additional information. Process this here
- // and then fall-through to process the data payload.
- UCHAR ucFlag = aucChannelBuffer[MESSAGE_BUFFER_DATA10_INDEX];
- if(bDisplay && ucFlag & ANT_EXT_MESG_BITFIELD_DEVICE_ID)
- {
- // Channel ID of the device that we just recieved a message from.
- USHORT usDeviceNumber = aucChannelBuffer[MESSAGE_BUFFER_DATA11_INDEX] | (aucChannelBuffer[MESSAGE_BUFFER_DATA12_INDEX] << 8);
- UCHAR ucDeviceType = aucChannelBuffer[MESSAGE_BUFFER_DATA13_INDEX];
- UCHAR ucTransmissionType = aucChannelBuffer[MESSAGE_BUFFER_DATA14_INDEX];
- printf("Chan ID(%d/%d/%d) - ", usDeviceNumber, ucDeviceType, ucTransmissionType);
- }
- // INTENTIONAL FALLTHROUGH
- }
- case EVENT_RX_ACKNOWLEDGED:
- case EVENT_RX_BURST_PACKET:
- case EVENT_RX_BROADCAST:
- {
- // This is an event generated by the DLL. It is not strictly
- // returned by the ANT part.
- // Display recieved message
- bPrintBuffer = TRUE;
- ucDataOffset = MESSAGE_BUFFER_DATA2_INDEX; // For most data messages
- if(bDisplay)
- {
- if(ucEvent_ == EVENT_RX_ACKNOWLEDGED || ucEvent_ == EVENT_RX_FLAG_ACKNOWLEDGED)
- printf("Acked Rx:(%d): ", aucChannelBuffer[MESSAGE_BUFFER_DATA1_INDEX]);
- else if(ucEvent_ == EVENT_RX_BURST_PACKET || ucEvent_ == EVENT_RX_FLAG_BURST_PACKET)
- printf("Burst(0x%02x) Rx:(%d): ", ((aucChannelBuffer[MESSAGE_BUFFER_DATA1_INDEX] & 0xE0) >> 5), aucChannelBuffer[MESSAGE_BUFFER_DATA1_INDEX] & 0x1F );
- else
- printf("Rx:(%d): ", aucChannelBuffer[MESSAGE_BUFFER_DATA1_INDEX]);
- }
- break;
- }
- case EVENT_RX_EXT_ACKNOWLEDGED:
- case EVENT_RX_EXT_BURST_PACKET:
- case EVENT_RX_EXT_BROADCAST:
- {
- // This is an event generated by the DLL. It is not strictly
- // returned by the ANT part. To enable, must call ANT_RxExtMesgsEnable first.
- // The "extended" part of this message is the 4-byte channel
- // id of the device that we recieved this message from. This event
- // is only available on the AT3. The AP2 uses the EVENT_RX_FLAG_BROADCAST
- // as shown above.
- // Channel ID of the device that we just recieved a message from.
- USHORT usDeviceNumber = aucChannelBuffer[MESSAGE_BUFFER_DATA2_INDEX] | (aucChannelBuffer[MESSAGE_BUFFER_DATA3_INDEX] << 8);
- UCHAR ucDeviceType = aucChannelBuffer[MESSAGE_BUFFER_DATA4_INDEX];
- UCHAR ucTransmissionType = aucChannelBuffer[MESSAGE_BUFFER_DATA5_INDEX];
- bPrintBuffer = TRUE;
- ucDataOffset = MESSAGE_BUFFER_DATA6_INDEX; // For most data messages
- if(bDisplay)
- {
- // Display the channel id
- printf("Chan ID(%d/%d/%d) ", usDeviceNumber, ucDeviceType, ucTransmissionType );
- if(ucEvent_ == EVENT_RX_EXT_ACKNOWLEDGED)
- printf("- Acked Rx:(%d): ", aucChannelBuffer[MESSAGE_BUFFER_DATA1_INDEX]);
- else if(ucEvent_ == EVENT_RX_EXT_BURST_PACKET)
- printf("- Burst(0x%02x) Rx:(%d): ", ((aucChannelBuffer[MESSAGE_BUFFER_DATA1_INDEX] & 0xE0) >> 5), aucChannelBuffer[MESSAGE_BUFFER_DATA1_INDEX] & 0x1F );
- else
- printf("- Rx:(%d): ", aucChannelBuffer[MESSAGE_BUFFER_DATA1_INDEX]);
- }
- break;
- }
- case EVENT_RX_SEARCH_TIMEOUT:
- {
- printf("Search Timeout\n");
- break;
- }
- case EVENT_RX_FAIL:
- {
- printf("Rx Fail\n");
- break;
- }
- case EVENT_TRANSFER_RX_FAILED:
- {
- printf("Burst receive has failed\n");
- break;
- }
- case EVENT_TRANSFER_TX_COMPLETED:
- {
- printf("Tranfer Completed.\n");
- break;
- }
- case EVENT_TRANSFER_TX_FAILED:
- {
- printf("Tranfer Failed.\n");
- break;
- }
- case EVENT_CHANNEL_CLOSED:
- {
- // This event should be used to determine that the channel is closed.
- printf("Channel Closed\n");
- printf("Unassigning Channel...\n");
- ANT_UnAssignChannel(USER_ANTCHANNEL);
- break;
- }
- case EVENT_RX_FAIL_GO_TO_SEARCH:
- {
- printf("Go to Search.\n");
- break;
- }
- case EVENT_CHANNEL_COLLISION:
- {
- printf("Channel Collision\n");
- break;
- }
- case EVENT_TRANSFER_TX_START:
- {
- printf("Burst Started\n");
- break;
- }
- default:
- {
- printf("Unhandled channel event 0x%X\n", ucEvent_);
- break;
- }
- }
- // If we recieved a data message, diplay its contents here.
- if(bPrintBuffer)
- {
- if(bDisplay)
- {
- printf("[%02x],[%02x],[%02x],[%02x],[%02x],[%02x],[%02x],[%02x]\n",
- aucChannelBuffer[ucDataOffset + 0],
- aucChannelBuffer[ucDataOffset + 1],
- aucChannelBuffer[ucDataOffset + 2],
- aucChannelBuffer[ucDataOffset + 3],
- aucChannelBuffer[ucDataOffset + 4],
- aucChannelBuffer[ucDataOffset + 5],
- aucChannelBuffer[ucDataOffset + 6],
- aucChannelBuffer[ucDataOffset + 7]);
- }
- else
- {
- static int iIndex = 0;
- static char ac[] = {'|','/','-','\\'};
- printf("Rx: %c\r",ac[iIndex++]); fflush(stdout);
- iIndex &= 3;
- }
- }
- return(TRUE);
- }
- ////////////////////////////////////////////////////////////////////////////////
- // Test_ResponseCallback
- //
- // Callback function passed to ANT DLL. Called whenever a message is recieved from ANT
- // unless that message is a channel event message.
- //
- // ucChannel_: Channel number of relevent to the message
- // ucMessageId_: Message ID of the message recieved from ANT.
- ////////////////////////////////////////////////////////////////////////////////
- BOOL Test_ResponseCallback(UCHAR ucChannel_, UCHAR ucMessageId_)
- {
- BOOL bSuccess = FALSE;
- switch(ucMessageId_)
- {
- case MESG_STARTUP_MESG_ID:
- {
- printf("RESET Complete, reason: ");
- UCHAR ucReason = aucResponseBuffer[MESSAGE_BUFFER_DATA1_INDEX];
- if(ucReason == RESET_POR)
- printf("RESET_POR");
- if(ucReason & RESET_SUSPEND)
- printf("RESET_SUSPEND ");
- if(ucReason & RESET_SYNC)
- printf("RESET_SYNC ");
- if(ucReason & RESET_CMD)
- printf("RESET_CMD ");
- if(ucReason & RESET_WDT)
- printf("RESET_WDT ");
- if(ucReason & RESET_RST)
- printf("RESET_RST ");
- printf("\n");
- break;
- }
- case MESG_CAPABILITIES_ID:
- {
- printf("CAPABILITIES:\n");
- printf(" Max ANT Channels: %d\n",aucResponseBuffer[MESSAGE_BUFFER_DATA1_INDEX]);
- printf(" Max ANT Networks: %d\n",aucResponseBuffer[MESSAGE_BUFFER_DATA2_INDEX]);
- UCHAR ucStandardOptions = aucResponseBuffer[MESSAGE_BUFFER_DATA3_INDEX];
- UCHAR ucAdvanced = aucResponseBuffer[MESSAGE_BUFFER_DATA4_INDEX];
- UCHAR ucAdvanced2 = aucResponseBuffer[MESSAGE_BUFFER_DATA5_INDEX];
- printf("Standard Options:\n");
- if( ucStandardOptions & CAPABILITIES_NO_RX_CHANNELS )
- printf("CAPABILITIES_NO_RX_CHANNELS\n");
- if( ucStandardOptions & CAPABILITIES_NO_TX_CHANNELS )
- printf("CAPABILITIES_NO_TX_CHANNELS\n");
- if( ucStandardOptions & CAPABILITIES_NO_RX_MESSAGES )
- printf("CAPABILITIES_NO_RX_MESSAGES\n");
- if( ucStandardOptions & CAPABILITIES_NO_TX_MESSAGES )
- printf("CAPABILITIES_NO_TX_MESSAGES\n");
- if( ucStandardOptions & CAPABILITIES_NO_ACKD_MESSAGES )
- printf("CAPABILITIES_NO_ACKD_MESSAGES\n");
- if( ucStandardOptions & CAPABILITIES_NO_BURST_TRANSFER )
- printf("CAPABILITIES_NO_BURST_TRANSFER\n");
- printf("Advanced Options:\n");
- if( ucAdvanced & CAPABILITIES_OVERUN_UNDERRUN )
- printf("CAPABILITIES_OVERUN_UNDERRUN\n");
- if( ucAdvanced & CAPABILITIES_NETWORK_ENABLED )
- printf("CAPABILITIES_NETWORK_ENABLED\n");
- if( ucAdvanced & CAPABILITIES_AP1_VERSION_2 )
- printf("CAPABILITIES_AP1_VERSION_2\n");
- if( ucAdvanced & CAPABILITIES_SERIAL_NUMBER_ENABLED )
- printf("CAPABILITIES_SERIAL_NUMBER_ENABLED\n");
- if( ucAdvanced & CAPABILITIES_PER_CHANNEL_TX_POWER_ENABLED )
- printf("CAPABILITIES_PER_CHANNEL_TX_POWER_ENABLED\n");
- if( ucAdvanced & CAPABILITIES_LOW_PRIORITY_SEARCH_ENABLED )
- printf("CAPABILITIES_LOW_PRIORITY_SEARCH_ENABLED\n");
- if( ucAdvanced & CAPABILITIES_SCRIPT_ENABLED )
- printf("CAPABILITIES_SCRIPT_ENABLED\n");
- if( ucAdvanced & CAPABILITIES_SEARCH_LIST_ENABLED )
- printf("CAPABILITIES_SEARCH_LIST_ENABLED\n");
- printf("Advanced 2 Options 1:\n");
- if( ucAdvanced2 & CAPABILITIES_LED_ENABLED )
- printf("CAPABILITIES_LED_ENABLED\n");
- if( ucAdvanced2 & CAPABILITIES_EXT_MESSAGE_ENABLED )
- printf("CAPABILITIES_EXT_MESSAGE_ENABLED\n");
- if( ucAdvanced2 & CAPABILITIES_SCAN_MODE_ENABLED )
- printf("CAPABILITIES_SCAN_MODE_ENABLED\n");
- if( ucAdvanced2 & CAPABILITIES_RESERVED )
- printf("CAPABILITIES_RESERVED\n");
- if( ucAdvanced2 & CAPABILITIES_PROX_SEARCH_ENABLED )
- printf("CAPABILITIES_PROX_SEARCH_ENABLED\n");
- if( ucAdvanced2 & CAPABILITIES_EXT_ASSIGN_ENABLED )
- printf("CAPABILITIES_EXT_ASSIGN_ENABLED\n");
- if( ucAdvanced2 & CAPABILITIES_FS_ANTFS_ENABLED)
- printf("CAPABILITIES_FREE_1\n");
- if( ucAdvanced2 & CAPABILITIES_FIT1_ENABLED )
- printf("CAPABILITIES_FIT1_ENABLED\n");
- break;
- }
- case MESG_CHANNEL_STATUS_ID:
- {
- printf("Got Status\n");
- char astrStatus[][32] = { "STATUS_UNASSIGNED_CHANNEL",
- "STATUS_ASSIGNED_CHANNEL",
- "STATUS_SEARCHING_CHANNEL",
- "STATUS_TRACKING_CHANNEL" };
- UCHAR ucStatusByte = aucResponseBuffer[MESSAGE_BUFFER_DATA2_INDEX] & STATUS_CHANNEL_STATE_MASK; // MUST MASK OFF THE RESERVED BITS
- printf("STATUS: %s\n",astrStatus[ucStatusByte]);
- break;
- }
- case MESG_CHANNEL_ID_ID:
- {
- // Channel ID of the device that we just recieved a message from.
- USHORT usDeviceNumber = aucResponseBuffer[MESSAGE_BUFFER_DATA2_INDEX] | (aucResponseBuffer[MESSAGE_BUFFER_DATA3_INDEX] << 8);
- UCHAR ucDeviceType = aucResponseBuffer[MESSAGE_BUFFER_DATA4_INDEX];
- UCHAR ucTransmissionType = aucResponseBuffer[MESSAGE_BUFFER_DATA5_INDEX];
- printf("CHANNEL ID: (%d/%d/%d)\n", usDeviceNumber, ucDeviceType, ucTransmissionType);
- break;
- }
- case MESG_VERSION_ID:
- {
- printf("VERSION: %s\n", (char*) &aucResponseBuffer[MESSAGE_BUFFER_DATA1_INDEX]);
- break;
- }
- case MESG_RESPONSE_EVENT_ID:
- {
- switch (aucResponseBuffer[MESSAGE_BUFFER_DATA2_INDEX])
- {
- case MESG_NETWORK_KEY_ID:
- {
- if(aucResponseBuffer[MESSAGE_BUFFER_DATA3_INDEX] != RESPONSE_NO_ERROR)
- {
- printf("Error configuring network key: Code 0%d\n", aucResponseBuffer[MESSAGE_BUFFER_DATA3_INDEX]);
- break;
- }
- printf("Network key set\n");
- printf("Assigning channel...\n");
- if(ucChannelType == CHANNEL_TYPE_MASTER)
- {
- bSuccess = ANT_AssignChannel(USER_ANTCHANNEL, PARAMETER_TX_NOT_RX, USER_NETWORK_NUM);
- }
- else if(ucChannelType == CHANNEL_TYPE_SLAVE)
- {
- bSuccess = ANT_AssignChannel(USER_ANTCHANNEL, 0, USER_NETWORK_NUM);
- }
- break;
- }
- case MESG_ASSIGN_CHANNEL_ID:
- {
- if(aucResponseBuffer[MESSAGE_BUFFER_DATA3_INDEX] != RESPONSE_NO_ERROR)
- {
- printf("Error assigning channel: Code 0%d\n", aucResponseBuffer[MESSAGE_BUFFER_DATA3_INDEX]);
- break;
- }
- printf("Channel assigned\n");
- printf("Setting Channel ID...\n");
- bSuccess = ANT_SetChannelId(USER_ANTCHANNEL, USER_DEVICENUM, USER_DEVICETYPE, USER_TRANSTYPE);
- break;
- }
- case MESG_CHANNEL_ID_ID:
- {
- if(aucResponseBuffer[MESSAGE_BUFFER_DATA3_INDEX] != RESPONSE_NO_ERROR)
- {
- printf("Error configuring Channel ID: Code 0%d\n", aucResponseBuffer[MESSAGE_BUFFER_DATA3_INDEX]);
- break;
- }
- printf("Channel ID set\n");
- printf("Setting Radio Frequency...\n");
- bSuccess = ANT_SetChannelRFFreq(USER_ANTCHANNEL, USER_RADIOFREQ);
- break;
- }
- case MESG_CHANNEL_RADIO_FREQ_ID:
- {
- if(aucResponseBuffer[MESSAGE_BUFFER_DATA3_INDEX] != RESPONSE_NO_ERROR)
- {
- printf("Error configuring Radio Frequency: Code 0%d\n", aucResponseBuffer[MESSAGE_BUFFER_DATA3_INDEX]);
- break;
- }
- printf("Radio Frequency set\n");
- printf("Opening channel...\n");
- bBroadcasting = TRUE;
- bSuccess = ANT_OpenChannel(USER_ANTCHANNEL);
- break;
- }
- case MESG_OPEN_CHANNEL_ID:
- {
- if(aucResponseBuffer[MESSAGE_BUFFER_DATA3_INDEX] != RESPONSE_NO_ERROR)
- {
- printf("Error opening channel: Code 0%d\n", aucResponseBuffer[MESSAGE_BUFFER_DATA3_INDEX]);
- bBroadcasting = FALSE;
- break;
- }
- printf("Channel opened\n");
- #if defined (ENABLE_EXTENDED_MESSAGES)
- printf("Enabling extended messages...\n");
- ANT_RxExtMesgsEnable(TRUE);
- #endif
- break;
- }
- case MESG_RX_EXT_MESGS_ENABLE_ID:
- {
- if(aucResponseBuffer[MESSAGE_BUFFER_DATA3_INDEX] == INVALID_MESSAGE)
- {
- printf("Extended messages not supported in this ANT product\n");
- break;
- }
- else if(aucResponseBuffer[MESSAGE_BUFFER_DATA3_INDEX] != RESPONSE_NO_ERROR)
- {
- printf("Error enabling extended messages: Code 0%d\n", aucResponseBuffer[MESSAGE_BUFFER_DATA3_INDEX]);
- break;
- }
- printf("Extended messages enabled\n");
- break;
- }
- case MESG_UNASSIGN_CHANNEL_ID:
- {
- if(aucResponseBuffer[MESSAGE_BUFFER_DATA3_INDEX] != RESPONSE_NO_ERROR)
- {
- printf("Error unassigning channel: Code 0%d\n", aucResponseBuffer[MESSAGE_BUFFER_DATA3_INDEX]);
- break;
- }
- printf("Channel unassigned\n");
- printf("Press enter to exit\n");
- bDone = TRUE;
- break;
- }
- case MESG_CLOSE_CHANNEL_ID:
- {
- if(aucResponseBuffer[MESSAGE_BUFFER_DATA3_INDEX]== CHANNEL_IN_WRONG_STATE)
- {
- // We get here if we tried to close the channel after the search timeout (slave)
- printf("Channel is already closed\n");
- printf("Unassigning channel...\n");
- ANT_UnAssignChannel(USER_ANTCHANNEL);
- break;
- }
- else if(aucResponseBuffer[MESSAGE_BUFFER_DATA3_INDEX] != RESPONSE_NO_ERROR)
- {
- printf("Error closing channel: Code 0%d\n", aucResponseBuffer[MESSAGE_BUFFER_DATA3_INDEX]);
- break;
- }
- // If this message was successful, wait for EVENT_CHANNEL_CLOSED to confirm the channel is closed
- break;
- }
- case MESG_REQUEST_ID:
- {
- if(aucResponseBuffer[MESSAGE_BUFFER_DATA3_INDEX] == INVALID_MESSAGE)
- {
- printf("Requested message not supported in this ANT product\n");
- break;
- }
- }
- default:
- {
- printf("Unhandled response %d to message 0x%X\n", aucResponseBuffer[MESSAGE_BUFFER_DATA3_INDEX], aucResponseBuffer[MESSAGE_BUFFER_DATA2_INDEX]);
- break;
- }
- }
- }
- }
- return(TRUE);
- }
- ////////////////////////////////////////////////////////////////////////////////
- // PrintMenu
- //
- // Start the Test program.
- //
- ////////////////////////////////////////////////////////////////////////////////
- void PrintMenu()
- {
- // Printout options
- printf("\n");
- printf("M - Print this menu\n");
- printf("A - Send Acknowledged message\n");
- printf("B - Send Burst message\n");
- printf("R - Reset\n");
- printf("C - Request Capabilites\n");
- printf("V - Request Version\n");
- printf("I - Request Channel ID\n");
- printf("S - Request Status\n");
- printf("U - Request USB Descriptor\n");
- printf("D - Toggle Display\n");
- printf("Q - Quit\n");
- printf("\n");
- fflush(stdout);
- }
|