From cadd121401bba101f13ad74f423de23a13e703e5 Mon Sep 17 00:00:00 2001 From: Oleksiy Protas Date: Sun, 10 Dec 2023 22:44:41 +0200 Subject: [PATCH] Bounds correctness for AnalogIn_IIO --- libraries/AP_HAL_Linux/AnalogIn_IIO.cpp | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-) diff --git a/libraries/AP_HAL_Linux/AnalogIn_IIO.cpp b/libraries/AP_HAL_Linux/AnalogIn_IIO.cpp index fff9815f43..97f335defa 100644 --- a/libraries/AP_HAL_Linux/AnalogIn_IIO.cpp +++ b/libraries/AP_HAL_Linux/AnalogIn_IIO.cpp @@ -29,6 +29,8 @@ AnalogSource_IIO::AnalogSource_IIO(int16_t pin, float initial_value, float volta void AnalogSource_IIO::init_pins(void) { + static_assert(ARRAY_SIZE(AnalogSource_IIO::analog_sources) == ARRAY_SIZE(fd_analog_sources), "AnalogIn_IIO channels count mismatch"); + char buf[100]; for (unsigned int i = 0; i < ARRAY_SIZE(AnalogSource_IIO::analog_sources); i++) { // Construct the path by appending strings @@ -44,7 +46,11 @@ void AnalogSource_IIO::init_pins(void) */ void AnalogSource_IIO::select_pin(void) { - _pin_fd = fd_analog_sources[_pin]; + if (0 <= _pin && (size_t)_pin < ARRAY_SIZE(fd_analog_sources)) { + _pin_fd = fd_analog_sources[_pin]; + } else { + _pin_fd = -1; + } } float AnalogSource_IIO::read_average()