aboutsummaryrefslogtreecommitdiff
path: root/devel/msp430-debug-stack/files/patch-DLL430__v3_src_TI_DLL430_UsbCdcIoChannel.cpp
blob: 3bb02c53d7a1d82c5089ef4538453024c693ecaf (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
--- DLL430_v3/src/TI/DLL430/UsbCdcIoChannel.cpp.orig	2025-02-14 17:38:09 UTC
+++ DLL430_v3/src/TI/DLL430/UsbCdcIoChannel.cpp
@@ -42,7 +42,7 @@
 
 #include <boost/asio/read.hpp>
 #include <boost/asio/write.hpp>
-#include <boost/asio/io_service.hpp>
+#include <boost/asio/io_context.hpp>
 
 #if defined(_WIN32) || defined(_WIN64)
 
@@ -181,7 +181,7 @@ void UsbCdcIoChannel::createCdcPortList(const uint16_t
 
 	for (;;)
 	{
-		io_service_t device = IOIteratorNext(iterator);
+		io_context_t device = IOIteratorNext(iterator);
 		if (device == 0)
 		{
 			if (!IOIteratorIsValid(iterator))
@@ -310,6 +310,22 @@ void UsbCdcIoChannel::createCdcPortList(const uint16_t
 	}
 #else
 	stringstream cdcIdStream;
+
+#ifdef __FreeBSD__
+
+	path p( "/dev" );
+	if( exists(p) && is_directory(p) ) {
+
+		cdcIdStream << hex << setfill('0') << "mspfet" << setw(4) << productId;
+
+		const directory_iterator end;
+		for( directory_iterator it(p); it != end; ++it ) {
+
+			string dir = it->path().string();
+			if( dir.find( cdcIdStream.str() ) != string::npos ) {
+	      			{
+
+#else
 	cdcIdStream << hex << setfill('0') << "usb:v" << setw(4) << vendorId << "p" << setw(4) << productId;
 
 	path p("/sys/class/tty/");
@@ -331,6 +347,7 @@ void UsbCdcIoChannel::createCdcPortList(const uint16_t
 				ifNumStream >> interfaceNumber;
 				if (modalias.find(cdcIdStream.str()) == 0 && interfaceNumber == 0)
 				{
+#endif
 					const string filename = it->path().filename().string();
 					const string portPath = string("/dev/") + filename;
 
@@ -376,7 +393,7 @@ bool UsbCdcIoChannel::openPort()
 
 bool UsbCdcIoChannel::openPort()
 {
-	ioService = new boost::asio::io_service;
+	ioService = new boost::asio::io_context;
 	port = new boost::asio::serial_port(*ioService);
 	timer = new boost::asio::deadline_timer(*ioService);
 
@@ -542,7 +559,7 @@ size_t UsbCdcIoChannel::read(HalResponse& resp)
 
 	boost::system::error_code ec;
 
-	while (ioService->run_one(ec))
+	while (ioService->run_one())
 	{
 		if (readEvent)
 		{
@@ -577,13 +594,13 @@ size_t UsbCdcIoChannel::read(HalResponse& resp)
 
 		if (ioService->stopped())
 		{
-			ioService->reset();
+			ioService->restart();
 		}
 	}
 
 	//Let cancelled tasks finish
-	ioService->run(ec);
-	ioService->reset();
+	ioService->run();
+	ioService->restart();
 
 
 	if (actSize == expSize)