Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
Q
qgroundcontrol
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Valentin Platzgummer
qgroundcontrol
Commits
8c58db2f
Commit
8c58db2f
authored
Oct 23, 2014
by
Lorenz Meier
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #907 from DonLakeFlyer/FlashFix
More stability changes
parents
e1616d01
c12df96f
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
34 additions
and
27 deletions
+34
-27
PX4Bootloader.cc
src/ui/px4_configuration/PX4Bootloader.cc
+28
-21
PX4FirmwareUpgradeThread.cc
src/ui/px4_configuration/PX4FirmwareUpgradeThread.cc
+6
-6
No files found.
src/ui/px4_configuration/PX4Bootloader.cc
View file @
8c58db2f
...
...
@@ -119,6 +119,12 @@ Again:
bool
PX4Bootloader
::
write
(
QSerialPort
*
port
,
const
uint8_t
*
data
,
qint64
maxSize
)
{
// Make sure we don't overflow output buffer
while
(
port
->
bytesToWrite
()
>
50
)
{
int
bump
=
0
;
bump
++
;
}
qint64
bytesWritten
=
port
->
write
((
const
char
*
)
data
,
maxSize
);
if
(
bytesWritten
==
-
1
)
{
_errorString
=
tr
(
"Write failed: %1"
).
arg
(
port
->
errorString
());
...
...
@@ -147,34 +153,35 @@ bool PX4Bootloader::write(QSerialPort* port, const uint8_t byte)
bool
PX4Bootloader
::
read
(
QSerialPort
*
port
,
uint8_t
*
data
,
qint64
maxSize
,
bool
warnOnError
,
int
readTimeout
)
{
qint64
bytesRead
;
if
(
port
->
bytesAvailable
()
<
maxSize
)
{
if
(
!
port
->
waitForReadyRead
(
readTimeout
))
{
_errorString
=
tr
(
"Timeout waiting for read bytes available: %1"
).
arg
(
port
->
errorString
());
qint64
bytesToRead
=
0
;
while
(
bytesToRead
<
maxSize
)
{
if
(
port
->
bytesAvailable
()
==
0
)
{
if
(
!
port
->
waitForReadyRead
(
readTimeout
))
{
_errorString
=
tr
(
"Timeout waiting for byte to be available"
);
if
(
warnOnError
)
{
qWarning
()
<<
_errorString
;
}
return
false
;
}
Q_ASSERT
(
port
->
bytesAvailable
()
!=
0
);
}
qint64
bytesRead
;
bytesRead
=
port
->
read
((
char
*
)
&
data
[
bytesToRead
],
maxSize
);
if
(
bytesRead
==
-
1
)
{
_errorString
=
tr
(
"Read failed: Could not read 1 byte, error: %1"
).
arg
(
port
->
errorString
());
if
(
warnOnError
)
{
qWarning
()
<<
_errorString
;
}
return
false
;
}
else
{
Q_ASSERT
(
bytesRead
!=
0
);
bytesToRead
+=
bytesRead
;
}
}
bytesRead
=
port
->
read
((
char
*
)
data
,
maxSize
);
if
(
bytesRead
==
-
1
)
{
_errorString
=
tr
(
"Read failed: Could not read %1 resonse, error: 12"
).
arg
(
port
->
errorString
());
if
(
warnOnError
)
{
qWarning
()
<<
_errorString
;
}
return
false
;
}
if
(
bytesRead
!=
maxSize
)
{
_errorString
=
tr
(
"In correct number of bytes returned for read: actual(%1) expected(%2)"
).
arg
(
bytesRead
).
arg
(
maxSize
);
if
(
warnOnError
)
{
qWarning
()
<<
_errorString
;
}
return
false
;
}
return
true
;
}
...
...
src/ui/px4_configuration/PX4FirmwareUpgradeThread.cc
View file @
8c58db2f
...
...
@@ -144,7 +144,7 @@ void PX4FirmwareUpgradeThreadWorker::_findBootloaderOnce(void)
}
else
{
_closeFind
();
_bootloaderPort
->
close
();
delete
_bootloaderPort
;
_bootloaderPort
->
deleteLater
()
;
_bootloaderPort
=
NULL
;
qDebug
()
<<
"Bootloader error:"
<<
_bootloader
->
errorString
();
emit
error
(
commandBootloader
,
_bootloader
->
errorString
());
...
...
@@ -153,7 +153,7 @@ void PX4FirmwareUpgradeThreadWorker::_findBootloaderOnce(void)
}
else
{
_closeFind
();
_bootloaderPort
->
close
();
delete
_bootloaderPort
;
_bootloaderPort
->
deleteLater
()
;
_bootloaderPort
=
NULL
;
qDebug
()
<<
"Bootloader sync failed"
;
emit
bootloaderSyncFailed
();
...
...
@@ -189,7 +189,7 @@ void PX4FirmwareUpgradeThreadWorker::timeout(void)
void
PX4FirmwareUpgradeThreadWorker
::
sendBootloaderReboot
(
void
)
{
_bootloader
->
sendBootloaderReboot
(
_bootloaderPort
);
delete
_bootloaderPort
;
_bootloaderPort
->
deleteLater
()
;
_bootloaderPort
=
NULL
;
}
...
...
@@ -197,7 +197,7 @@ void PX4FirmwareUpgradeThreadWorker::program(const QString firmwareFilename)
{
qDebug
()
<<
"Program"
;
if
(
!
_bootloader
->
program
(
_bootloaderPort
,
firmwareFilename
))
{
delete
_bootloaderPort
;
_bootloaderPort
->
deleteLater
()
;
_bootloaderPort
=
NULL
;
qDebug
()
<<
"Program failed:"
<<
_bootloader
->
errorString
();
emit
error
(
commandProgram
,
_bootloader
->
errorString
());
...
...
@@ -217,7 +217,7 @@ void PX4FirmwareUpgradeThreadWorker::verify(const QString firmwareFilename)
qDebug
()
<<
"Verify complete"
;
emit
complete
(
commandVerify
);
}
delete
_bootloaderPort
;
_bootloaderPort
->
deleteLater
()
;
_bootloaderPort
=
NULL
;
}
...
...
@@ -225,7 +225,7 @@ void PX4FirmwareUpgradeThreadWorker::erase(void)
{
qDebug
()
<<
"Erase"
;
if
(
!
_bootloader
->
erase
(
_bootloaderPort
))
{
delete
_bootloaderPort
;
_bootloaderPort
->
deleteLater
()
;
_bootloaderPort
=
NULL
;
qDebug
()
<<
"Erase failed:"
<<
_bootloader
->
errorString
();
emit
error
(
commandErase
,
_bootloader
->
errorString
());
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment