AgIsoStack++
A control-function-focused implementation of the major ISOBUS and J1939 protocols
Loading...
Searching...
No Matches
PCANBasic.h
1// PCANBasic.h
2//
3// ~~~~~~~~~~~~
4//
5// PCAN-Basic API
6//
7// ~~~~~~~~~~~~
8//
9// ------------------------------------------------------------------
10// Author : Keneth Wagner
11// Last change: 2022-07-06
12//
13// Language: ANSI-C
14// ------------------------------------------------------------------
15//
16// Copyright (C) 1999-2022 PEAK-System Technik GmbH, Darmstadt
17// more Info at http://www.peak-system.com
18//
19// clang-format off
21#ifndef __PCANBASICH__
22#define __PCANBASICH__
23
25// Value definitions
27
28// Currently defined and supported PCAN channels
29//
30#define PCAN_NONEBUS 0x00U // Undefined/default value for a PCAN bus
31
32#define PCAN_ISABUS1 0x21U // PCAN-ISA interface, channel 1
33#define PCAN_ISABUS2 0x22U // PCAN-ISA interface, channel 2
34#define PCAN_ISABUS3 0x23U // PCAN-ISA interface, channel 3
35#define PCAN_ISABUS4 0x24U // PCAN-ISA interface, channel 4
36#define PCAN_ISABUS5 0x25U // PCAN-ISA interface, channel 5
37#define PCAN_ISABUS6 0x26U // PCAN-ISA interface, channel 6
38#define PCAN_ISABUS7 0x27U // PCAN-ISA interface, channel 7
39#define PCAN_ISABUS8 0x28U // PCAN-ISA interface, channel 8
40
41#define PCAN_DNGBUS1 0x31U // PCAN-Dongle/LPT interface, channel 1
42
43#define PCAN_PCIBUS1 0x41U // PCAN-PCI interface, channel 1
44#define PCAN_PCIBUS2 0x42U // PCAN-PCI interface, channel 2
45#define PCAN_PCIBUS3 0x43U // PCAN-PCI interface, channel 3
46#define PCAN_PCIBUS4 0x44U // PCAN-PCI interface, channel 4
47#define PCAN_PCIBUS5 0x45U // PCAN-PCI interface, channel 5
48#define PCAN_PCIBUS6 0x46U // PCAN-PCI interface, channel 6
49#define PCAN_PCIBUS7 0x47U // PCAN-PCI interface, channel 7
50#define PCAN_PCIBUS8 0x48U // PCAN-PCI interface, channel 8
51#define PCAN_PCIBUS9 0x409U // PCAN-PCI interface, channel 9
52#define PCAN_PCIBUS10 0x40AU // PCAN-PCI interface, channel 10
53#define PCAN_PCIBUS11 0x40BU // PCAN-PCI interface, channel 11
54#define PCAN_PCIBUS12 0x40CU // PCAN-PCI interface, channel 12
55#define PCAN_PCIBUS13 0x40DU // PCAN-PCI interface, channel 13
56#define PCAN_PCIBUS14 0x40EU // PCAN-PCI interface, channel 14
57#define PCAN_PCIBUS15 0x40FU // PCAN-PCI interface, channel 15
58#define PCAN_PCIBUS16 0x410U // PCAN-PCI interface, channel 16
59
60#define PCAN_USBBUS1 0x51U // PCAN-USB interface, channel 1
61#define PCAN_USBBUS2 0x52U // PCAN-USB interface, channel 2
62#define PCAN_USBBUS3 0x53U // PCAN-USB interface, channel 3
63#define PCAN_USBBUS4 0x54U // PCAN-USB interface, channel 4
64#define PCAN_USBBUS5 0x55U // PCAN-USB interface, channel 5
65#define PCAN_USBBUS6 0x56U // PCAN-USB interface, channel 6
66#define PCAN_USBBUS7 0x57U // PCAN-USB interface, channel 7
67#define PCAN_USBBUS8 0x58U // PCAN-USB interface, channel 8
68#define PCAN_USBBUS9 0x509U // PCAN-USB interface, channel 9
69#define PCAN_USBBUS10 0x50AU // PCAN-USB interface, channel 10
70#define PCAN_USBBUS11 0x50BU // PCAN-USB interface, channel 11
71#define PCAN_USBBUS12 0x50CU // PCAN-USB interface, channel 12
72#define PCAN_USBBUS13 0x50DU // PCAN-USB interface, channel 13
73#define PCAN_USBBUS14 0x50EU // PCAN-USB interface, channel 14
74#define PCAN_USBBUS15 0x50FU // PCAN-USB interface, channel 15
75#define PCAN_USBBUS16 0x510U // PCAN-USB interface, channel 16
76
77#define PCAN_PCCBUS1 0x61U // PCAN-PC Card interface, channel 1
78#define PCAN_PCCBUS2 0x62U // PCAN-PC Card interface, channel 2
79
80#define PCAN_LANBUS1 0x801U // PCAN-LAN interface, channel 1
81#define PCAN_LANBUS2 0x802U // PCAN-LAN interface, channel 2
82#define PCAN_LANBUS3 0x803U // PCAN-LAN interface, channel 3
83#define PCAN_LANBUS4 0x804U // PCAN-LAN interface, channel 4
84#define PCAN_LANBUS5 0x805U // PCAN-LAN interface, channel 5
85#define PCAN_LANBUS6 0x806U // PCAN-LAN interface, channel 6
86#define PCAN_LANBUS7 0x807U // PCAN-LAN interface, channel 7
87#define PCAN_LANBUS8 0x808U // PCAN-LAN interface, channel 8
88#define PCAN_LANBUS9 0x809U // PCAN-LAN interface, channel 9
89#define PCAN_LANBUS10 0x80AU // PCAN-LAN interface, channel 10
90#define PCAN_LANBUS11 0x80BU // PCAN-LAN interface, channel 11
91#define PCAN_LANBUS12 0x80CU // PCAN-LAN interface, channel 12
92#define PCAN_LANBUS13 0x80DU // PCAN-LAN interface, channel 13
93#define PCAN_LANBUS14 0x80EU // PCAN-LAN interface, channel 14
94#define PCAN_LANBUS15 0x80FU // PCAN-LAN interface, channel 15
95#define PCAN_LANBUS16 0x810U // PCAN-LAN interface, channel 16
96
97// Represent the PCAN error and status codes
98//
99#define PCAN_ERROR_OK 0x00000U // No error
100#define PCAN_ERROR_XMTFULL 0x00001U // Transmit buffer in CAN controller is full
101#define PCAN_ERROR_OVERRUN 0x00002U // CAN controller was read too late
102#define PCAN_ERROR_BUSLIGHT 0x00004U // Bus error: an error counter reached the 'light' limit
103#define PCAN_ERROR_BUSHEAVY 0x00008U // Bus error: an error counter reached the 'heavy' limit
104#define PCAN_ERROR_BUSWARNING PCAN_ERROR_BUSHEAVY // Bus error: an error counter reached the 'warning' limit
105#define PCAN_ERROR_BUSPASSIVE 0x40000U // Bus error: the CAN controller is error passive
106#define PCAN_ERROR_BUSOFF 0x00010U // Bus error: the CAN controller is in bus-off state
107#define PCAN_ERROR_ANYBUSERR (PCAN_ERROR_BUSWARNING | PCAN_ERROR_BUSLIGHT | PCAN_ERROR_BUSHEAVY | PCAN_ERROR_BUSOFF | PCAN_ERROR_BUSPASSIVE) // Mask for all bus errors
108#define PCAN_ERROR_QRCVEMPTY 0x00020U // Receive queue is empty
109#define PCAN_ERROR_QOVERRUN 0x00040U // Receive queue was read too late
110#define PCAN_ERROR_QXMTFULL 0x00080U // Transmit queue is full
111#define PCAN_ERROR_REGTEST 0x00100U // Test of the CAN controller hardware registers failed (no hardware found)
112#define PCAN_ERROR_NODRIVER 0x00200U // Driver not loaded
113#define PCAN_ERROR_HWINUSE 0x00400U // Hardware already in use by a Net
114#define PCAN_ERROR_NETINUSE 0x00800U // A Client is already connected to the Net
115#define PCAN_ERROR_ILLHW 0x01400U // Hardware handle is invalid
116#define PCAN_ERROR_ILLNET 0x01800U // Net handle is invalid
117#define PCAN_ERROR_ILLCLIENT 0x01C00U // Client handle is invalid
118#define PCAN_ERROR_ILLHANDLE (PCAN_ERROR_ILLHW | PCAN_ERROR_ILLNET | PCAN_ERROR_ILLCLIENT) // Mask for all handle errors
119#define PCAN_ERROR_RESOURCE 0x02000U // Resource (FIFO, Client, timeout) cannot be created
120#define PCAN_ERROR_ILLPARAMTYPE 0x04000U // Invalid parameter
121#define PCAN_ERROR_ILLPARAMVAL 0x08000U // Invalid parameter value
122#define PCAN_ERROR_UNKNOWN 0x10000U // Unknown error
123#define PCAN_ERROR_ILLDATA 0x20000U // Invalid data, function, or action
124#define PCAN_ERROR_ILLMODE 0x80000U // Driver object state is wrong for the attempted operation
125#define PCAN_ERROR_CAUTION 0x2000000U // An operation was successfully carried out, however, irregularities were registered
126#define PCAN_ERROR_INITIALIZE 0x4000000U // Channel is not initialized [Value was changed from 0x40000 to 0x4000000]
127#define PCAN_ERROR_ILLOPERATION 0x8000000U // Invalid operation [Value was changed from 0x80000 to 0x8000000]
128
129// PCAN devices
130//
131#define PCAN_NONE 0x00U // Undefined, unknown or not selected PCAN device value
132#define PCAN_PEAKCAN 0x01U // PCAN Non-PnP devices. NOT USED WITHIN PCAN-Basic API
133#define PCAN_ISA 0x02U // PCAN-ISA, PCAN-PC/104, and PCAN-PC/104-Plus
134#define PCAN_DNG 0x03U // PCAN-Dongle
135#define PCAN_PCI 0x04U // PCAN-PCI, PCAN-cPCI, PCAN-miniPCI, and PCAN-PCI Express
136#define PCAN_USB 0x05U // PCAN-USB and PCAN-USB Pro
137#define PCAN_PCC 0x06U // PCAN-PC Card
138#define PCAN_VIRTUAL 0x07U // PCAN Virtual hardware. NOT USED WITHIN PCAN-Basic API
139#define PCAN_LAN 0x08U // PCAN Gateway devices
140
141// PCAN parameters
142//
143#define PCAN_DEVICE_ID 0x01U // Device identifier parameter
144#define PCAN_5VOLTS_POWER 0x02U // 5-Volt power parameter
145#define PCAN_RECEIVE_EVENT 0x03U // PCAN receive event handler parameter
146#define PCAN_MESSAGE_FILTER 0x04U // PCAN message filter parameter
147#define PCAN_API_VERSION 0x05U // PCAN-Basic API version parameter
148#define PCAN_CHANNEL_VERSION 0x06U // PCAN device channel version parameter
149#define PCAN_BUSOFF_AUTORESET 0x07U // PCAN Reset-On-Busoff parameter
150#define PCAN_LISTEN_ONLY 0x08U // PCAN Listen-Only parameter
151#define PCAN_LOG_LOCATION 0x09U // Directory path for log files
152#define PCAN_LOG_STATUS 0x0AU // Debug-Log activation status
153#define PCAN_LOG_CONFIGURE 0x0BU // Configuration of the debugged information (LOG_FUNCTION_***)
154#define PCAN_LOG_TEXT 0x0CU // Custom insertion of text into the log file
155#define PCAN_CHANNEL_CONDITION 0x0DU // Availability status of a PCAN-Channel
156#define PCAN_HARDWARE_NAME 0x0EU // PCAN hardware name parameter
157#define PCAN_RECEIVE_STATUS 0x0FU // Message reception status of a PCAN-Channel
158#define PCAN_CONTROLLER_NUMBER 0x10U // CAN-Controller number of a PCAN-Channel
159#define PCAN_TRACE_LOCATION 0x11U // Directory path for PCAN trace files
160#define PCAN_TRACE_STATUS 0x12U // CAN tracing activation status
161#define PCAN_TRACE_SIZE 0x13U // Configuration of the maximum file size of a CAN trace
162#define PCAN_TRACE_CONFIGURE 0x14U // Configuration of the trace file storing mode (TRACE_FILE_***)
163#define PCAN_CHANNEL_IDENTIFYING 0x15U // Physical identification of a USB based PCAN-Channel by blinking its associated LED
164#define PCAN_CHANNEL_FEATURES 0x16U // Capabilities of a PCAN device (FEATURE_***)
165#define PCAN_BITRATE_ADAPTING 0x17U // Using of an existing bit rate (PCAN-View connected to a channel)
166#define PCAN_BITRATE_INFO 0x18U // Configured bit rate as Btr0Btr1 value
167#define PCAN_BITRATE_INFO_FD 0x19U // Configured bit rate as TPCANBitrateFD string
168#define PCAN_BUSSPEED_NOMINAL 0x1AU // Configured nominal CAN Bus speed as Bits per seconds
169#define PCAN_BUSSPEED_DATA 0x1BU // Configured CAN data speed as Bits per seconds
170#define PCAN_IP_ADDRESS 0x1CU // Remote address of a LAN channel as string in IPv4 format
171#define PCAN_LAN_SERVICE_STATUS 0x1DU // Status of the Virtual PCAN-Gateway Service
172#define PCAN_ALLOW_STATUS_FRAMES 0x1EU // Status messages reception status within a PCAN-Channel
173#define PCAN_ALLOW_RTR_FRAMES 0x1FU // RTR messages reception status within a PCAN-Channel
174#define PCAN_ALLOW_ERROR_FRAMES 0x20U // Error messages reception status within a PCAN-Channel
175#define PCAN_INTERFRAME_DELAY 0x21U // Delay, in microseconds, between sending frames
176#define PCAN_ACCEPTANCE_FILTER_11BIT 0x22U // Filter over code and mask patterns for 11-Bit messages
177#define PCAN_ACCEPTANCE_FILTER_29BIT 0x23U // Filter over code and mask patterns for 29-Bit messages
178#define PCAN_IO_DIGITAL_CONFIGURATION 0x24U // Output mode of 32 digital I/O pin of a PCAN-USB Chip. 1: Output-Active 0 : Output Inactive
179#define PCAN_IO_DIGITAL_VALUE 0x25U // Value assigned to a 32 digital I/O pins of a PCAN-USB Chip
180#define PCAN_IO_DIGITAL_SET 0x26U // Value assigned to a 32 digital I/O pins of a PCAN-USB Chip - Multiple digital I/O pins to 1 = High
181#define PCAN_IO_DIGITAL_CLEAR 0x27U // Clear multiple digital I/O pins to 0
182#define PCAN_IO_ANALOG_VALUE 0x28U // Get value of a single analog input pin
183#define PCAN_FIRMWARE_VERSION 0x29U // Get the version of the firmware used by the device associated with a PCAN-Channel
184#define PCAN_ATTACHED_CHANNELS_COUNT 0x2AU // Get the amount of PCAN channels attached to a system
185#define PCAN_ATTACHED_CHANNELS 0x2BU // Get information about PCAN channels attached to a system
186#define PCAN_ALLOW_ECHO_FRAMES 0x2CU // Echo messages reception status within a PCAN-Channel
187#define PCAN_DEVICE_PART_NUMBER 0x2DU // Get the part number associated to a device
188
189// DEPRECATED parameters
190//
191#define PCAN_DEVICE_NUMBER PCAN_DEVICE_ID // Deprecated parameter. Use PCAN_DEVICE_ID instead
192
193// PCAN parameter values
194//
195#define PCAN_PARAMETER_OFF 0x00U // The PCAN parameter is not set (inactive)
196#define PCAN_PARAMETER_ON 0x01U // The PCAN parameter is set (active)
197#define PCAN_FILTER_CLOSE 0x00U // The PCAN filter is closed. No messages will be received
198#define PCAN_FILTER_OPEN 0x01U // The PCAN filter is fully opened. All messages will be received
199#define PCAN_FILTER_CUSTOM 0x02U // The PCAN filter is custom configured. Only registered messages will be received
200#define PCAN_CHANNEL_UNAVAILABLE 0x00U // The PCAN-Channel handle is illegal, or its associated hardware is not available
201#define PCAN_CHANNEL_AVAILABLE 0x01U // The PCAN-Channel handle is available to be connected (PnP Hardware: it means furthermore that the hardware is plugged-in)
202#define PCAN_CHANNEL_OCCUPIED 0x02U // The PCAN-Channel handle is valid, and is already being used
203#define PCAN_CHANNEL_PCANVIEW (PCAN_CHANNEL_AVAILABLE | PCAN_CHANNEL_OCCUPIED) // The PCAN-Channel handle is already being used by a PCAN-View application, but is available to connect
204
205#define LOG_FUNCTION_DEFAULT 0x00U // Logs system exceptions / errors
206#define LOG_FUNCTION_ENTRY 0x01U // Logs the entries to the PCAN-Basic API functions
207#define LOG_FUNCTION_PARAMETERS 0x02U // Logs the parameters passed to the PCAN-Basic API functions
208#define LOG_FUNCTION_LEAVE 0x04U // Logs the exits from the PCAN-Basic API functions
209#define LOG_FUNCTION_WRITE 0x08U // Logs the CAN messages passed to the CAN_Write function
210#define LOG_FUNCTION_READ 0x10U // Logs the CAN messages received within the CAN_Read function
211#define LOG_FUNCTION_ALL 0xFFFFU // Logs all possible information within the PCAN-Basic API functions
212
213#define TRACE_FILE_SINGLE 0x00U // A single file is written until it size reaches PAN_TRACE_SIZE
214#define TRACE_FILE_SEGMENTED 0x01U // Traced data is distributed in several files with size PAN_TRACE_SIZE
215#define TRACE_FILE_DATE 0x02U // Includes the date into the name of the trace file
216#define TRACE_FILE_TIME 0x04U // Includes the start time into the name of the trace file
217#define TRACE_FILE_OVERWRITE 0x80U // Causes the overwriting of available traces (same name)
218
219#define FEATURE_FD_CAPABLE 0x01U // Device supports flexible data-rate (CAN-FD)
220#define FEATURE_DELAY_CAPABLE 0x02U // Device supports a delay between sending frames (FPGA based USB devices)
221#define FEATURE_IO_CAPABLE 0x04U // Device supports I/O functionality for electronic circuits (USB-Chip devices)
222
223#define SERVICE_STATUS_STOPPED 0x01U // The service is not running
224#define SERVICE_STATUS_RUNNING 0x04U // The service is running
225
226// Other constants
227//
228#define MAX_LENGTH_HARDWARE_NAME 33 // Maximum length of the name of a device: 32 characters + terminator
229#define MAX_LENGTH_VERSION_STRING 256 // Maximum length of a version string: 255 characters + terminator
230
231// PCAN message types
232//
233#define PCAN_MESSAGE_STANDARD 0x00U // The PCAN message is a CAN Standard Frame (11-bit identifier)
234#define PCAN_MESSAGE_RTR 0x01U // The PCAN message is a CAN Remote-Transfer-Request Frame
235#define PCAN_MESSAGE_EXTENDED 0x02U // The PCAN message is a CAN Extended Frame (29-bit identifier)
236#define PCAN_MESSAGE_FD 0x04U // The PCAN message represents a FD frame in terms of CiA Specs
237#define PCAN_MESSAGE_BRS 0x08U // The PCAN message represents a FD bit rate switch (CAN data at a higher bit rate)
238#define PCAN_MESSAGE_ESI 0x10U // The PCAN message represents a FD error state indicator(CAN FD transmitter was error active)
239#define PCAN_MESSAGE_ECHO 0x20U // The PCAN message represents an echo CAN Frame
240#define PCAN_MESSAGE_ERRFRAME 0x40U // The PCAN message represents an error frame
241#define PCAN_MESSAGE_STATUS 0x80U // The PCAN message represents a PCAN status message
242
243// LookUp Parameters
244//
245#define LOOKUP_DEVICE_TYPE __T("devicetype") // Lookup channel by Device type (see PCAN devices e.g. PCAN_USB)
246#define LOOKUP_DEVICE_ID __T("deviceid") // Lookup channel by device id
247#define LOOKUP_CONTROLLER_NUMBER __T("controllernumber") // Lookup channel by CAN controller 0-based index
248#define LOOKUP_IP_ADDRESS __T("ipaddress") // Lookup channel by IP address (LAN channels only)
249
250// Frame Type / Initialization Mode
251//
252#define PCAN_MODE_STANDARD PCAN_MESSAGE_STANDARD
253#define PCAN_MODE_EXTENDED PCAN_MESSAGE_EXTENDED
254
255// Baud rate codes = BTR0/BTR1 register values for the CAN controller.
256// You can define your own Baud rate with the BTROBTR1 register.
257// Take a look at www.peak-system.com for our free software "BAUDTOOL"
258// to calculate the BTROBTR1 register for every bit rate and sample point.
259//
260#define PCAN_BAUD_1M 0x0014U // 1 MBit/s
261#define PCAN_BAUD_800K 0x0016U // 800 kBit/s
262#define PCAN_BAUD_500K 0x001CU // 500 kBit/s
263#define PCAN_BAUD_250K 0x011CU // 250 kBit/s
264#define PCAN_BAUD_125K 0x031CU // 125 kBit/s
265#define PCAN_BAUD_100K 0x432FU // 100 kBit/s
266#define PCAN_BAUD_95K 0xC34EU // 95,238 kBit/s
267#define PCAN_BAUD_83K 0x852BU // 83,333 kBit/s
268#define PCAN_BAUD_50K 0x472FU // 50 kBit/s
269#define PCAN_BAUD_47K 0x1414U // 47,619 kBit/s
270#define PCAN_BAUD_33K 0x8B2FU // 33,333 kBit/s
271#define PCAN_BAUD_20K 0x532FU // 20 kBit/s
272#define PCAN_BAUD_10K 0x672FU // 10 kBit/s
273#define PCAN_BAUD_5K 0x7F7FU // 5 kBit/s
274
275// Represents the configuration for a CAN bit rate
276// Note:
277// * Each parameter and its value must be separated with a '='.
278// * Each pair of parameter/value must be separated using ','.
279//
280// Example:
281// f_clock=80000000,nom_brp=10,nom_tseg1=5,nom_tseg2=2,nom_sjw=1,data_brp=4,data_tseg1=7,data_tseg2=2,data_sjw=1
282//
283#define PCAN_BR_CLOCK __T("f_clock")
284#define PCAN_BR_CLOCK_MHZ __T("f_clock_mhz")
285#define PCAN_BR_NOM_BRP __T("nom_brp")
286#define PCAN_BR_NOM_TSEG1 __T("nom_tseg1")
287#define PCAN_BR_NOM_TSEG2 __T("nom_tseg2")
288#define PCAN_BR_NOM_SJW __T("nom_sjw")
289#define PCAN_BR_NOM_SAMPLE __T("nom_sam")
290#define PCAN_BR_DATA_BRP __T("data_brp")
291#define PCAN_BR_DATA_TSEG1 __T("data_tseg1")
292#define PCAN_BR_DATA_TSEG2 __T("data_tseg2")
293#define PCAN_BR_DATA_SJW __T("data_sjw")
294#define PCAN_BR_DATA_SAMPLE __T("data_ssp_offset")
295
296// Type of PCAN (Non-PnP) hardware
297//
298#define PCAN_TYPE_ISA 0x01U // PCAN-ISA 82C200
299#define PCAN_TYPE_ISA_SJA 0x09U // PCAN-ISA SJA1000
300#define PCAN_TYPE_ISA_PHYTEC 0x04U // PHYTEC ISA
301#define PCAN_TYPE_DNG 0x02U // PCAN-Dongle 82C200
302#define PCAN_TYPE_DNG_EPP 0x03U // PCAN-Dongle EPP 82C200
303#define PCAN_TYPE_DNG_SJA 0x05U // PCAN-Dongle SJA1000
304#define PCAN_TYPE_DNG_SJA_EPP 0x06U // PCAN-Dongle EPP SJA1000
305
307// Type definitions
309
310#define TPCANHandle WORD // Represents a PCAN hardware channel handle
311#define TPCANStatus DWORD // Represents a PCAN status/error code
312#define TPCANParameter BYTE // Represents a PCAN parameter to be read or set
313#define TPCANDevice BYTE // Represents a PCAN device
314#define TPCANMessageType BYTE // Represents the type of a PCAN message
315#define TPCANType BYTE // Represents the type of PCAN hardware to be initialized
316#define TPCANMode BYTE // Represents a PCAN filter mode
317#define TPCANBaudrate WORD // Represents a PCAN Baud rate register value
318#define TPCANBitrateFD LPSTR // Represents a PCAN-FD bit rate string
319#define TPCANTimestampFD UINT64 // Represents a timestamp of a received PCAN FD message
320
322// Structure definitions
324
325// Represents a PCAN message
326//
327typedef struct tagTPCANMsg
328{
329 DWORD ID; // 11/29-bit message identifier
330 TPCANMessageType MSGTYPE; // Type of the message
331 BYTE LEN; // Data Length Code of the message (0..8)
332 BYTE DATA[8]; // Data of the message (DATA[0]..DATA[7])
333} TPCANMsg;
334
335// Represents a timestamp of a received PCAN message
336// Total Microseconds = micros + 1000 * millis + 0x100000000 * 1000 * millis_overflow
337//
338typedef struct tagTPCANTimestamp
339{
340 DWORD millis; // Base-value: milliseconds: 0.. 2^32-1
341 WORD millis_overflow; // Roll-arounds of millis
342 WORD micros; // Microseconds: 0..999
343} TPCANTimestamp;
344
345// Represents a PCAN message from a FD capable hardware
346//
347typedef struct tagTPCANMsgFD
348{
349 DWORD ID; // 11/29-bit message identifier
350 TPCANMessageType MSGTYPE; // Type of the message
351 BYTE DLC; // Data Length Code of the message (0..15)
352 BYTE DATA[64]; // Data of the message (DATA[0]..DATA[63])
353} TPCANMsgFD;
354
355// Describes an available PCAN channel
356//
357typedef struct tagTPCANChannelInformation
358{
359 TPCANHandle channel_handle; // PCAN channel handle
360 TPCANDevice device_type; // Kind of PCAN device
361 BYTE controller_number; // CAN-Controller number
362 DWORD device_features; // Device capabilities flag (see FEATURE_*)
363 char device_name[MAX_LENGTH_HARDWARE_NAME]; // Device name
364 DWORD device_id; // Device number
365 DWORD channel_condition; // Availability status of a PCAN-Channel
366}TPCANChannelInformation;
367
368#ifdef __cplusplus
369extern "C" {
370#define _DEF_ARG =0
371#else
372#define _DEF_ARG
373#endif
374
376// PCAN-Basic API function declarations
378
379
389TPCANStatus __stdcall CAN_Initialize(
390 TPCANHandle Channel,
391 TPCANBaudrate Btr0Btr1,
392 TPCANType HwType _DEF_ARG,
393 DWORD IOPort _DEF_ARG,
394 WORD Interrupt _DEF_ARG);
395
396
411TPCANStatus __stdcall CAN_InitializeFD(
412 TPCANHandle Channel,
413 TPCANBitrateFD BitrateFD);
414
415
423TPCANStatus __stdcall CAN_Uninitialize(
424 TPCANHandle Channel);
425
426
435TPCANStatus __stdcall CAN_Reset(
436 TPCANHandle Channel);
437
438
444TPCANStatus __stdcall CAN_GetStatus(
445 TPCANHandle Channel);
446
447
457TPCANStatus __stdcall CAN_Read(
458 TPCANHandle Channel,
459 TPCANMsg* MessageBuffer,
460 TPCANTimestamp* TimestampBuffer);
461
462
472TPCANStatus __stdcall CAN_ReadFD(
473 TPCANHandle Channel,
474 TPCANMsgFD* MessageBuffer,
475 TPCANTimestampFD *TimestampBuffer);
476
477
484TPCANStatus __stdcall CAN_Write(
485 TPCANHandle Channel,
486 TPCANMsg* MessageBuffer);
487
488
495TPCANStatus __stdcall CAN_WriteFD(
496 TPCANHandle Channel,
497 TPCANMsgFD* MessageBuffer);
498
499
512TPCANStatus __stdcall CAN_FilterMessages(
513 TPCANHandle Channel,
514 DWORD FromID,
515 DWORD ToID,
516 TPCANMode Mode);
517
518
530TPCANStatus __stdcall CAN_GetValue(
531 TPCANHandle Channel,
532 TPCANParameter Parameter,
533 void* Buffer,
534 DWORD BufferLength);
535
536
548TPCANStatus __stdcall CAN_SetValue(
549 TPCANHandle Channel,
550 TPCANParameter Parameter,
551 void* Buffer,
552 DWORD BufferLength);
553
554
566TPCANStatus __stdcall CAN_GetErrorText(
567 TPCANStatus Error,
568 WORD Language,
569 LPSTR Buffer);
570
579TPCANStatus __stdcall CAN_LookUpChannel(
580 LPSTR Parameters,
581 TPCANHandle* FoundChannel);
582
583
584#ifdef __cplusplus
585}
586#endif
587
588#endif
589
590// clang-format on