From b1bf22b53c9fa6a01793259c91d1993a798e2180 Mon Sep 17 00:00:00 2001 From: courk Date: Sun, 1 Mar 2020 16:37:42 +0100 Subject: [PATCH] GPIO_BBB: fix partially working GPIO init use cleaner way to enable all GPIO banks, including GPIO1. --- libraries/AP_HAL_Linux/GPIO_BBB.cpp | 30 +++++++++++++++-------------- libraries/AP_HAL_Linux/GPIO_BBB.h | 7 ++++++- 2 files changed, 22 insertions(+), 15 deletions(-) diff --git a/libraries/AP_HAL_Linux/GPIO_BBB.cpp b/libraries/AP_HAL_Linux/GPIO_BBB.cpp index da4b64261f..69c2c222ee 100644 --- a/libraries/AP_HAL_Linux/GPIO_BBB.cpp +++ b/libraries/AP_HAL_Linux/GPIO_BBB.cpp @@ -29,20 +29,6 @@ void GPIO_BBB::init() { #if LINUX_GPIO_NUM_BANKS == 4 int mem_fd; - // Enable all GPIO banks - // Without this, access to deactivated banks (i.e. those with no clock source set up) will (logically) fail with SIGBUS - // Idea taken from https://groups.google.com/forum/#!msg/beagleboard/OYFp4EXawiI/Mq6s3sg14HoJ - - uint8_t bank_enable[3] = { 5, 65, 105 }; - int export_fd = open("/sys/class/gpio/export", O_WRONLY | O_CLOEXEC); - if (export_fd == -1) { - AP_HAL::panic("unable to open /sys/class/gpio/export"); - } - for (uint8_t i=0; i<3; i++) { - dprintf(export_fd, "%u\n", (unsigned)bank_enable[i]); - } - close(export_fd); - /* open /dev/mem */ if ((mem_fd = open("/dev/mem", O_RDWR|O_SYNC|O_CLOEXEC)) < 0) { @@ -50,6 +36,22 @@ void GPIO_BBB::init() exit (-1); } + /* + Enable all GPIO clocks + Without this, access to deactivated banks (i.e. those with no clock source set up) will (logically) fail with SIGBUS + */ + volatile unsigned *cm_per = (volatile unsigned *)mmap(0, CM_PER_BASE_SIZE, PROT_READ|PROT_WRITE, + MAP_SHARED, mem_fd, CM_PER_BASE); + if ((char *)cm_per == MAP_FAILED) { + AP_HAL::panic("unable to map CM_PER registers"); + } + off_t cm_offsets[LINUX_GPIO_NUM_BANKS-1] = { CM_PER_GPIO1_CLKCTRL, CM_PER_GPIO2_CLKCTRL, CM_PER_GPIO3_CLKCTRL }; + for (uint8_t i=0; i