firmata.c: fix possible crash if devs is wrong
Signed-off-by: Brendan Le Foll <brendan.le.foll@intel.com>
This commit is contained in:
@@ -245,9 +245,9 @@ firmata_endParse(t_firmata* firmata)
|
|||||||
printf("i2c reply is %d\n", firmata->i2cmsg[addr][reg]);
|
printf("i2c reply is %d\n", firmata->i2cmsg[addr][reg]);
|
||||||
#endif
|
#endif
|
||||||
} else {
|
} else {
|
||||||
|
if (firmata->devs != NULL) {
|
||||||
struct _firmata* devs = firmata->devs[0];
|
struct _firmata* devs = firmata->devs[0];
|
||||||
int i = 0;
|
int i = 0;
|
||||||
if (devs != NULL) {
|
|
||||||
for (i; i < firmata->dev_count; i++, devs++) {
|
for (i; i < firmata->dev_count; i++, devs++) {
|
||||||
if (devs != NULL) {
|
if (devs != NULL) {
|
||||||
if (firmata->parse_buff[1] == devs->feature) {
|
if (firmata->parse_buff[1] == devs->feature) {
|
||||||
|
|||||||
@@ -464,6 +464,10 @@ mraa_firmata_plat_init(const char* uart_dev)
|
|||||||
}
|
}
|
||||||
|
|
||||||
firmata_dev = firmata_new(uart_dev);
|
firmata_dev = firmata_new(uart_dev);
|
||||||
|
if (firmata_dev == NULL) {
|
||||||
|
free(b);
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
// if this isn't working then we have an issue with our uart
|
// if this isn't working then we have an issue with our uart
|
||||||
while (!firmata_dev->isReady) {
|
while (!firmata_dev->isReady) {
|
||||||
|
|||||||
Reference in New Issue
Block a user