From f7e90669f4bbb89a099a2b2a155d6df0becdc840 Mon Sep 17 00:00:00 2001 From: Danielle Madeley Date: Sat, 2 Feb 2019 18:38:16 +1100 Subject: [PATCH 1/4] Use MSVC syntax --- src/WinPortFactory.h | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/WinPortFactory.h b/src/WinPortFactory.h index b9cf2a88..6ffb2f5a 100644 --- a/src/WinPortFactory.h +++ b/src/WinPortFactory.h @@ -50,7 +50,7 @@ class WinPortFactory : public PortFactoryBase SerialPort::Ptr create(const std::string& name, bool isUsb); private: - typedef DWORD WINAPI (*CM_Open_DevNode_Key)(DWORD, DWORD, DWORD, DWORD, ::PHKEY, DWORD); + typedef DWORD (WINAPI *CM_Open_DevNode_Key)(DWORD, DWORD, DWORD, DWORD, ::PHKEY, DWORD); HDEVINFO _devInfo; HINSTANCE _cfgMgr; From f98df6e3307d672c60a719a76d9d2631ddd14f62 Mon Sep 17 00:00:00 2001 From: Danielle Madeley Date: Sat, 2 Feb 2019 18:45:12 +1100 Subject: [PATCH 2/4] Remove variable length arrays (Not supported in MSVC) --- src/Flasher.cpp | 30 +++++++++++++++--------------- src/WinPortFactory.cpp | 8 +++++--- 2 files changed, 20 insertions(+), 18 deletions(-) diff --git a/src/Flasher.cpp b/src/Flasher.cpp index 7591cf9f..5272a6f3 100644 --- a/src/Flasher.cpp +++ b/src/Flasher.cpp @@ -112,19 +112,19 @@ Flasher::write(const char* filename, uint32_t foffset) { uint32_t offset = 0; uint32_t bufferSize = _samba.writeBufferSize(); - uint8_t buffer[bufferSize]; + std::vector buffer(bufferSize); - while ((fbytes = fread(buffer, 1, bufferSize, infile)) > 0) + while ((fbytes = fread(buffer.data(), 1, bufferSize, infile)) > 0) { _observer.onProgress(offset / pageSize, numPages); if (fbytes < bufferSize) { - memset(buffer + fbytes, 0, bufferSize - fbytes); + memset(buffer.data() + fbytes, 0, bufferSize - fbytes); fbytes = (fbytes + pageSize - 1) / pageSize * pageSize; } - _flash->loadBuffer(buffer, fbytes); + _flash->loadBuffer(buffer.data(), fbytes); _flash->writeBuffer(foffset + offset, fbytes); offset += fbytes; } @@ -132,14 +132,14 @@ Flasher::write(const char* filename, uint32_t foffset) } else { - uint8_t buffer[pageSize]; + std::vector buffer(pageSize); uint32_t pageOffset = foffset / pageSize; - while ((fbytes = fread(buffer, 1, pageSize, infile)) > 0) + while ((fbytes = fread(buffer.data(), 1, pageSize, infile)) > 0) { _observer.onProgress(pageNum, numPages); - _flash->loadBuffer(buffer, fbytes); + _flash->loadBuffer(buffer.data(), fbytes); _flash->writePage(pageOffset + pageNum); pageNum++; @@ -164,8 +164,8 @@ Flasher::verify(const char* filename, uint32_t& pageErrors, uint32_t& totalError { FILE* infile; uint32_t pageSize = _flash->pageSize(); - uint8_t bufferA[pageSize]; - uint8_t bufferB[pageSize]; + std::vector bufferA(pageSize); + std::vector bufferB(pageSize); uint32_t pageNum = 0; uint32_t numPages; uint32_t pageOffset; @@ -200,7 +200,7 @@ Flasher::verify(const char* filename, uint32_t& pageErrors, uint32_t& totalError _observer.onStatus("Verify %ld bytes of flash\n", fsize); - while ((fbytes = fread(bufferA, 1, pageSize, infile)) > 0) + while ((fbytes = fread(bufferA.data(), 1, pageSize, infile)) > 0) { byteErrors = 0; @@ -215,7 +215,7 @@ Flasher::verify(const char* filename, uint32_t& pageErrors, uint32_t& totalError if (flashCrc != calcCrc) { - _flash->readPage(pageOffset + pageNum, bufferB); + _flash->readPage(pageOffset + pageNum, bufferB.data()); for (uint32_t i = 0; i < fbytes; i++) { @@ -226,7 +226,7 @@ Flasher::verify(const char* filename, uint32_t& pageErrors, uint32_t& totalError } else { - _flash->readPage(pageOffset + pageNum, bufferB); + _flash->readPage(pageOffset + pageNum, bufferB.data()); for (uint32_t i = 0; i < fbytes; i++) { @@ -267,7 +267,7 @@ Flasher::read(const char* filename, uint32_t fsize, uint32_t foffset) { FILE* outfile; uint32_t pageSize = _flash->pageSize(); - uint8_t buffer[pageSize]; + std::vector buffer(pageSize); uint32_t pageNum = 0; uint32_t pageOffset; uint32_t numPages; @@ -297,11 +297,11 @@ Flasher::read(const char* filename, uint32_t fsize, uint32_t foffset) { _observer.onProgress(pageNum, numPages); - _flash->readPage(pageOffset + pageNum, buffer); + _flash->readPage(pageOffset + pageNum, buffer.data()); if (pageNum == numPages - 1 && fsize % pageSize > 0) pageSize = fsize % pageSize; - fbytes = fwrite(buffer, 1, pageSize, outfile); + fbytes = fwrite(buffer.data(), 1, pageSize, outfile); if (fbytes != pageSize) throw FileShortError(); } diff --git a/src/WinPortFactory.cpp b/src/WinPortFactory.cpp index 6913747d..9bd2dd21 100644 --- a/src/WinPortFactory.cpp +++ b/src/WinPortFactory.cpp @@ -26,6 +26,8 @@ // (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS // SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. /////////////////////////////////////////////////////////////////////////////// +#include + #include "WinPortFactory.h" #include "WinSerialPort.h" @@ -102,14 +104,14 @@ WinPortFactory::begin() if (size < 1) return error(); - GUID guids[size]; + std::vector guids(size); - if (!SetupDiClassGuidsFromNameA("Ports", guids, size * sizeof(GUID), &size)) + if (!SetupDiClassGuidsFromNameA("Ports", guids.data(), size * sizeof(GUID), &size)) { return error(); } - _devInfo = SetupDiGetClassDevs(guids, NULL, NULL, DIGCF_PRESENT); + _devInfo = SetupDiGetClassDevs(guids.data(), NULL, NULL, DIGCF_PRESENT); if(_devInfo == INVALID_HANDLE_VALUE) return error(); From fe346cbd3b42556e5950ea4ec3660747d9e9f8e1 Mon Sep 17 00:00:00 2001 From: Danielle Madeley Date: Sat, 2 Feb 2019 19:35:44 +1100 Subject: [PATCH 3/4] Accept WIN32 per MSVC --- src/BossaProgress.cpp | 2 +- src/Driver.h | 2 +- src/PortFactory.h | 2 +- 3 files changed, 3 insertions(+), 3 deletions(-) diff --git a/src/BossaProgress.cpp b/src/BossaProgress.cpp index 5873106f..2c9868fb 100644 --- a/src/BossaProgress.cpp +++ b/src/BossaProgress.cpp @@ -44,7 +44,7 @@ void BossaProgress::SetValue(int pos) { _statusGauge->SetValue(pos); -#if __WIN32 +#if defined(__WIN32__) || defined(WIN32) // Work around slow update on Windows _statusGauge->SetValue(pos - 1); _statusGauge->SetValue(pos); diff --git a/src/Driver.h b/src/Driver.h index 04ec9b68..2d9e8e4c 100644 --- a/src/Driver.h +++ b/src/Driver.h @@ -42,7 +42,7 @@ class DriverBase virtual bool update() = 0; }; -#ifdef __WIN32__ +#if defined(__WIN32__) || defined(WIN32) #include "WinDriver.h" typedef WinDriver Driver; #else diff --git a/src/PortFactory.h b/src/PortFactory.h index 3b3b631e..2695b32e 100644 --- a/src/PortFactory.h +++ b/src/PortFactory.h @@ -48,7 +48,7 @@ class PortFactoryBase virtual SerialPort::Ptr create(const std::string& name, bool isUsb) = 0; }; -#if defined(__WIN32__) +#if defined(__WIN32__) || defined(WIN32) #include "WinPortFactory.h" typedef WinPortFactory PortFactory; #elif defined(__linux__) From 466fcb38af85924ea5c41e09053717fe313b4fa5 Mon Sep 17 00:00:00 2001 From: Danielle Madeley Date: Sat, 2 Feb 2019 19:44:01 +1100 Subject: [PATCH 4/4] Polyfill usleep on Windows Should this just be used everywhere? --- src/EefcFlash.cpp | 6 +++++- src/EfcFlash.cpp | 6 +++++- src/PosixSerialPort.cpp | 6 +++++- src/Samba.cpp | 6 +++++- src/usleep.h | 8 ++++++++ 5 files changed, 28 insertions(+), 4 deletions(-) create mode 100644 src/usleep.h diff --git a/src/EefcFlash.cpp b/src/EefcFlash.cpp index 4f614017..15fea560 100644 --- a/src/EefcFlash.cpp +++ b/src/EefcFlash.cpp @@ -29,8 +29,12 @@ #include "EefcFlash.h" #include -#include #include +#if defined(__WIN32__) || defined(WIN32) +#include "usleep.h" +#else +#include +#endif #define EEFC_KEY 0x5a diff --git a/src/EfcFlash.cpp b/src/EfcFlash.cpp index 9b212385..ab0f7337 100644 --- a/src/EfcFlash.cpp +++ b/src/EfcFlash.cpp @@ -29,8 +29,12 @@ #include "EfcFlash.h" #include -#include #include +#if defined(__WIN32__) || defined(WIN32) +#include "usleep.h" +#else +#include +#endif #define EFC_KEY 0x5a diff --git a/src/PosixSerialPort.cpp b/src/PosixSerialPort.cpp index 45eaca9c..53d3b8d0 100644 --- a/src/PosixSerialPort.cpp +++ b/src/PosixSerialPort.cpp @@ -30,12 +30,16 @@ #include #include -#include #include #include #include #include #include +#if defined(__WIN32__) || defined(WIN32) +#include "usleep.h" +#else +#include +#endif #include diff --git a/src/Samba.cpp b/src/Samba.cpp index 490e3936..b489374f 100644 --- a/src/Samba.cpp +++ b/src/Samba.cpp @@ -33,8 +33,12 @@ #include #include #include -#include #include +#if defined(__WIN32__) || defined(WIN32) +#include "usleep.h" +#else +#include +#endif using namespace std; diff --git a/src/usleep.h b/src/usleep.h new file mode 100644 index 00000000..2fe91800 --- /dev/null +++ b/src/usleep.h @@ -0,0 +1,8 @@ +#include +#include + +// Replacement for sleep +void inline +usleep(int length) { + std::this_thread::sleep_for(std::chrono::milliseconds(length)); +}