Refs #316. Integrated XCP on CAN transport layer into the LibOpenBLT API.

git-svn-id: https://svn.code.sf.net/p/openblt/code/trunk@314 5dc33758-31d5-4daf-9ae8-b24bf3d40d73
This commit is contained in:
Frank Voorburg 2017-07-26 11:08:53 +00:00
parent 44f30fc5a0
commit d1a746f454
5 changed files with 26 additions and 3 deletions

View File

@ -39,6 +39,7 @@
#include "session.h" /* Communication session module */ #include "session.h" /* Communication session module */
#include "xcploader.h" /* XCP loader module */ #include "xcploader.h" /* XCP loader module */
#include "xcptpuart.h" /* XCP UART transport layer */ #include "xcptpuart.h" /* XCP UART transport layer */
#include "xcptpcan.h" /* XCP CAN transport layer */
/**************************************************************************************** /****************************************************************************************
@ -165,6 +166,28 @@ LIBOPENBLT_EXPORT void BltSessionInit(uint32_t sessionType,
xcpLoaderSettings.transport = XcpTpUartGetTransport(); xcpLoaderSettings.transport = XcpTpUartGetTransport();
} }
} }
else if (transportType == BLT_TRANSPORT_XCP_V10_CAN)
{
/* Cast transport settings to the correct type. */
tBltTransportSettingsXcpV10Can * bltTransportSettingsXcpV10CanPtr;
bltTransportSettingsXcpV10CanPtr =
(tBltTransportSettingsXcpV10Can * )transportSettings;
/* Convert transport settings to the format supported by the XCP CAN transport
* layer. It was made static to make sure it doesn't get out of scope when
* used in xcpLoaderSettings.
*/
static tXcpTpCanSettings xcpTpCanSettings;
xcpTpCanSettings.device = bltTransportSettingsXcpV10CanPtr->deviceName;
xcpTpCanSettings.channel = bltTransportSettingsXcpV10CanPtr->deviceChannel;
xcpTpCanSettings.baudrate = bltTransportSettingsXcpV10CanPtr->baudrate;
xcpTpCanSettings.transmitId = bltTransportSettingsXcpV10CanPtr->transmitId;
xcpTpCanSettings.receiveId = bltTransportSettingsXcpV10CanPtr->receiveId;
xcpTpCanSettings.useExtended = (bltTransportSettingsXcpV10CanPtr->useExtended != 0);
/* Store transport layer settings in the XCP loader settings. */
xcpLoaderSettings.transportSettings = &xcpTpCanSettings;
/* Link the transport layer to the XCP loader settings. */
xcpLoaderSettings.transport = XcpTpCanGetTransport();
}
/* Perform actual session initialization. */ /* Perform actual session initialization. */
SessionInit(XcpLoaderGetProtocol(), &xcpLoaderSettings); SessionInit(XcpLoaderGetProtocol(), &xcpLoaderSettings);
} }

View File

@ -146,7 +146,7 @@ typedef struct t_blt_transport_settings_xcp_v10_rs232
*/ */
typedef struct t_blt_transport_settings_xcp_v10_can typedef struct t_blt_transport_settings_xcp_v10_can
{ {
char const * deviceName; /**< Device name such as can0. */ char const * deviceName; /**< Device name such as can0, peak_pcanusb etc. */
uint32_t deviceChannel; /**< Channel on the device to use. */ uint32_t deviceChannel; /**< Channel on the device to use. */
uint32_t baudrate; /**< Communication speed in bits/sec. */ uint32_t baudrate; /**< Communication speed in bits/sec. */
uint32_t transmitId; /**< Transmit CAN identifier. */ uint32_t transmitId; /**< Transmit CAN identifier. */

View File

@ -93,7 +93,7 @@ type
// Structure layout of the XCP version 1.0 CAN transport layer settings. // Structure layout of the XCP version 1.0 CAN transport layer settings.
tBltTransportSettingsXcpV10Can = record tBltTransportSettingsXcpV10Can = record
deviceName: PAnsiChar; // Device name such as can0, pcanusb, etc. deviceName: PAnsiChar; // Device name such as can0, peak_pcanusb, etc.
deviceChannel: LongWord; // Channel on the device to use. deviceChannel: LongWord; // Channel on the device to use.
baudrate: LongWord; // Communication speed in bits/sec. baudrate: LongWord; // Communication speed in bits/sec.
transmitId: LongWord; // Transmit CAN identifier. transmitId: LongWord; // Transmit CAN identifier.

View File

@ -45,7 +45,7 @@ extern "C" {
*/ */
typedef struct t_xcp_tp_can_settings typedef struct t_xcp_tp_can_settings
{ {
char const * device; /**< Device name such as can0, pcanusb, etc. */ char const * device; /**< Device name such as can0, peak_pcanusb, etc. */
uint32_t channel; /**< Channel on the device to use. */ uint32_t channel; /**< Channel on the device to use. */
uint32_t baudrate; /**< Communication speed in bits/sec. */ uint32_t baudrate; /**< Communication speed in bits/sec. */
uint32_t transmitId; /**< Transmit CAN identifier. */ uint32_t transmitId; /**< Transmit CAN identifier. */

Binary file not shown.