scanner.h
Go to the documentation of this file.
1 
2 // Copyright (c) 2003-2021 Xsens Technologies B.V. or subsidiaries worldwide.
3 // All rights reserved.
4 //
5 // Redistribution and use in source and binary forms, with or without modification,
6 // are permitted provided that the following conditions are met:
7 //
8 // 1. Redistributions of source code must retain the above copyright notice,
9 // this list of conditions, and the following disclaimer.
10 //
11 // 2. Redistributions in binary form must reproduce the above copyright notice,
12 // this list of conditions, and the following disclaimer in the documentation
13 // and/or other materials provided with the distribution.
14 //
15 // 3. Neither the names of the copyright holders nor the names of their contributors
16 // may be used to endorse or promote products derived from this software without
17 // specific prior written permission.
18 //
19 // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY
20 // EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
21 // MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL
22 // THE COPYRIGHT HOLDERS OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
23 // SPECIAL, EXEMPLARY OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT
24 // OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
25 // HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY OR
26 // TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
27 // SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.THE LAWS OF THE NETHERLANDS
28 // SHALL BE EXCLUSIVELY APPLICABLE AND ANY DISPUTES SHALL BE FINALLY SETTLED UNDER THE RULES
29 // OF ARBITRATION OF THE INTERNATIONAL CHAMBER OF COMMERCE IN THE HAGUE BY ONE OR MORE
30 // ARBITRATORS APPOINTED IN ACCORDANCE WITH SAID RULES.
31 //
32 
33 
34 // Copyright (c) 2003-2021 Xsens Technologies B.V. or subsidiaries worldwide.
35 // All rights reserved.
36 //
37 // Redistribution and use in source and binary forms, with or without modification,
38 // are permitted provided that the following conditions are met:
39 //
40 // 1. Redistributions of source code must retain the above copyright notice,
41 // this list of conditions, and the following disclaimer.
42 //
43 // 2. Redistributions in binary form must reproduce the above copyright notice,
44 // this list of conditions, and the following disclaimer in the documentation
45 // and/or other materials provided with the distribution.
46 //
47 // 3. Neither the names of the copyright holders nor the names of their contributors
48 // may be used to endorse or promote products derived from this software without
49 // specific prior written permission.
50 //
51 // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY
52 // EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
53 // MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL
54 // THE COPYRIGHT HOLDERS OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
55 // SPECIAL, EXEMPLARY OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT
56 // OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
57 // HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY OR
58 // TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
59 // SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.THE LAWS OF THE NETHERLANDS
60 // SHALL BE EXCLUSIVELY APPLICABLE AND ANY DISPUTES SHALL BE FINALLY SETTLED UNDER THE RULES
61 // OF ARBITRATION OF THE INTERNATIONAL CHAMBER OF COMMERCE IN THE HAGUE BY ONE OR MORE
62 // ARBITRATORS APPOINTED IN ACCORDANCE WITH SAID RULES.
63 //
64 
65 #ifndef SCANNER_H
66 #define SCANNER_H
67 
68 #include <xstypes/xsresultvalue.h>
69 #include <xstypes/xsportinfo.h>
71 #include <xstypes/xsbaudrate.h>
72 #include "xsusbhubinfo.h"
73 #include "xsscanner.h"
74 
75 #include <atomic>
76 
77 struct XsIntArray;
78 
79 #ifdef _WIN32
80  #include <setupapi.h>
81 #endif
82 
83 class Scanner
84 {
85 public:
86  virtual ~Scanner();
87 
88  class Accessor
89  {
90  public:
91  Scanner& scanner() const;
92  };
93 
94  XsResultValue fetchBasicInfo(XsPortInfo& portInfo, uint32_t singleScanTimeout, bool detectRs485);
95  bool xsScanPort(XsPortInfo& portInfo, XsBaudRate baud, uint32_t singleScanTimeout, bool detectRs485);
96  virtual bool xsScanPorts(XsPortInfoArray& ports, XsBaudRate baudrate, uint32_t singleScanTimeout, bool ignoreNonXsensDevices, bool detectRs485);
97  bool xsFilterResponsiveDevices(XsPortInfoArray& ports, XsBaudRate baudrate, uint32_t singleScanTimeout, bool detectRs485);
98 
99 #ifdef _WIN32
100  static std::string getDevicePath(HDEVINFO hDevInfo, SP_DEVINFO_DATA* DeviceInfoData);
101  int xsScanGetHubNumber(HDEVINFO hDevInfo, SP_DEVINFO_DATA* deviceInfoData);
102  XsPortInfo xsScanPortByHubId(const char* id);
103  bool xsScanXsensUsbHubs(XsIntArray& hubs, XsPortInfoArray& ports);
104 #endif
105  static bool isXsensUsbDevice(uint16_t vid, uint16_t pid);
106  bool xsEnumerateSerialPorts(XsPortInfoArray& ports, bool ignoreNonXsensDevices);
107  virtual bool xsEnumerateNetworkDevices(XsPortInfoArray& ports);
108  virtual bool xsEnumerateBluetoothDevices(XsPortInfoArray& ports);
109 
110  XsUsbHubInfo xsScanUsbHub(const XsPortInfo& portInfo);
111 
113 };
114 
115 namespace XsScannerNamespace
116 {
117 extern volatile std::atomic_bool abortPortScan;
118 extern Scanner* gScanner;
120 }
121 
122 #if 1
123 #define LOGXSSCAN(msg)\
124  do {\
125  JLDEBUGG(msg); \
126  if (XsScannerNamespace::gScanLogCallback) \
127  { \
128  std::ostringstream os; \
129  os << msg; \
130  const XsString cbVal(os.str()); \
131  XsScannerNamespace::gScanLogCallback(&cbVal); \
132  } \
133  } while(0)
134 #else
135 #define LOGXSSCAN(msg) ((void)0)
136 #endif
137 
138 #endif
Scanner::fetchBasicInfo
XsResultValue fetchBasicInfo(XsPortInfo &portInfo, uint32_t singleScanTimeout, bool detectRs485)
Fetch basic device information.
Definition: scanner.cpp:144
XsScannerNamespace::gScanLogCallback
XsScanLogCallbackFunc gScanLogCallback
Definition: scanner.cpp:100
XsScannerNamespace::abortPortScan
volatile std::atomic_bool abortPortScan
Definition: scanner.cpp:98
Scanner::xsScanPort
bool xsScanPort(XsPortInfo &portInfo, XsBaudRate baud, uint32_t singleScanTimeout, bool detectRs485)
Scan a single COM port for connected Xsens devices.
Definition: scanner.cpp:224
XsScannerNamespace
Definition: scanner.cpp:96
XsScannerNamespace::gScanner
Scanner * gScanner
Definition: scanner.cpp:99
xsusbhubinfo.h
Scanner::~Scanner
virtual ~Scanner()
Destructor.
Definition: scanner.cpp:122
Scanner
Provides static functionality for scanning for Xsens devices.
Definition: scanner.h:83
XsIntArray
A list of XsInt values.
xsportinfo.h
XsScanLogCallbackFunc
void(* XsScanLogCallbackFunc)(struct XsString const *)
Defines the callback type that can be supplied to XsScanner_setScanLogCallback.
Definition: xsscanner.h:91
XsResultValue
XsResultValue
Xsens result values.
Definition: xsresultvalue.h:82
Scanner::isXsensUsbDevice
static bool isXsensUsbDevice(uint16_t vid, uint16_t pid)
Definition: scanner.cpp:383
Scanner::xsFilterResponsiveDevices
bool xsFilterResponsiveDevices(XsPortInfoArray &ports, XsBaudRate baudrate, uint32_t singleScanTimeout, bool detectRs485)
Filter responsive devices.
Definition: scanner.cpp:339
XsBaudRate
enum XsBaudRate XsBaudRate
Communication speed.
Definition: xsbaud.h:81
uint32_t
unsigned int uint32_t
Definition: pstdint.h:485
XsPortInfo
Contains a descriptor for opening a communication port to an Xsens device.
Definition: xsportinfo.h:128
Scanner::xsEnumerateSerialPorts
bool xsEnumerateSerialPorts(XsPortInfoArray &ports, bool ignoreNonXsensDevices)
Enumerate the serial ports.
Definition: scanner.cpp:406
Scanner::xsEnumerateBluetoothDevices
virtual bool xsEnumerateBluetoothDevices(XsPortInfoArray &ports)
Enumerates a bluetooth device.
Definition: scanner.cpp:599
xsbaudrate.h
Scanner::xsScanPorts
virtual bool xsScanPorts(XsPortInfoArray &ports, XsBaudRate baudrate, uint32_t singleScanTimeout, bool ignoreNonXsensDevices, bool detectRs485)
Scan serial ports for connected Xsens devices.
Definition: scanner.cpp:315
Scanner::xsScanUsbHub
XsUsbHubInfo xsScanUsbHub(const XsPortInfo &portInfo)
Get information about the hub configuration.
Definition: scanner.cpp:879
XsUsbHubInfo
A structure that wraps USB hub information.
Definition: xsusbhubinfo.h:99
XsPortInfoArray
A list of XsPortInfo values.
Scanner::setScanLogCallback
static void setScanLogCallback(XsScanLogCallbackFunc cb)
Set a callback function for scan log progress and problem reporting.
Definition: scanner.cpp:131
Scanner::xsEnumerateNetworkDevices
virtual bool xsEnumerateNetworkDevices(XsPortInfoArray &ports)
Enumerates a network device.
Definition: scanner.cpp:589
Scanner::Accessor::scanner
Scanner & scanner() const
Definition: scanner.cpp:110
xsscanner.h
xsresultvalue.h
Scanner::Accessor
An accessor class for scanner.
Definition: scanner.h:88
xsportinfoarray.h


xsens_mti_driver
Author(s):
autogenerated on Sun Sep 3 2023 02:43:20