Bosch Sensortec Community

    cancel
    Showing results for 
    Search instead for 
    Did you mean: 

    intermittent null_ptr error bmx160

    intermittent null_ptr error bmx160

    richardlowe
    New Poster

    I am trying to debug an error when using the FIFO on the bmx160 (I am using the driver for the bmi160 as Bosch recommends).

    When I read data from the FIFO by calling bmi160_get_fifo_data (https://github.com/BoschSensortec/BMI160_driver/blob/master/bmi160.c#L2157) , the function returns -1 (BMI160_E_NULL_PTR).  

    I have debugged the code by adding print statements to see what’s happening. When attempting to get the fill level of the FIFO,  https://github.com/BoschSensortec/BMI160_driver/blob/master/bmi160.c#L5485, then the result is -1.

    The error is happening only occasionally. Sometimes I can read 10minutes of data without issue, sometimes I can read no more than 30s before I receive an error code.

    I can share code, but I am writing in Rust and not C.

    5 REPLIES 5

    BSTRobin
    Community Moderator
    Community Moderator

    Hello richardlowe,

    You could refer to the example code in the attachment. FIFO poll and FIFO watermark interrupt reading work well without the error you described.

    Hi, thanks for providing that code, however it doesn't build and seems to be missing header files.

    I can provide C code which exhibits the same error as the Rust implementation. Perhaps you could take a look at my C code to see if something is wrong?

    Thanks,

    Richard

    BSTRobin
    Community Moderator
    Community Moderator

    Hello richardlowe,

    I didn't put the C code and header file of sensor API in the attachment. They are on GitHub.
    BMI160 sensor API: https://github.com/BoschSensortec/BMI160_driver
    BMM150 sensor API: https://github.com/BoschSensortec/BMM150-Sensor-API

    Hi,

    The api was provided along with the example you gave. It even includes the modification to change the chip ID from 0xD1 to 0xD8.

    What is not provided is  the following two headers in main.c:

    #include "main.h"
    #include "cmsis_os.h"

    Should I not be using main.c (which has an ST copyright in it)? There is no other entrypoint provided in the code you sent.

     

    If you could look at the code I provided, which only has a dependency on the BMI160 api, I would be grateful.

    Icon--AD-black-48x48Icon--address-consumer-data-black-48x48Icon--appointment-black-48x48Icon--back-left-black-48x48Icon--calendar-black-48x48Icon--center-alignedIcon--Checkbox-checkIcon--clock-black-48x48Icon--close-black-48x48Icon--compare-black-48x48Icon--confirmation-black-48x48Icon--dealer-details-black-48x48Icon--delete-black-48x48Icon--delivery-black-48x48Icon--down-black-48x48Icon--download-black-48x48Ic-OverlayAlertIcon--externallink-black-48x48Icon-Filledforward-right_adjustedIcon--grid-view-black-48x48IC_gd_Check-Circle170821_Icons_Community170823_Bosch_Icons170823_Bosch_Icons170821_Icons_CommunityIC-logout170821_Icons_Community170825_Bosch_Icons170821_Icons_CommunityIC-shopping-cart2170821_Icons_CommunityIC-upIC_UserIcon--imageIcon--info-i-black-48x48Icon--left-alignedIcon--Less-minimize-black-48x48Icon-FilledIcon--List-Check-grennIcon--List-Check-blackIcon--List-Cross-blackIcon--list-view-mobile-black-48x48Icon--list-view-black-48x48Icon--More-Maximize-black-48x48Icon--my-product-black-48x48Icon--newsletter-black-48x48Icon--payment-black-48x48Icon--print-black-48x48Icon--promotion-black-48x48Icon--registration-black-48x48Icon--Reset-black-48x48Icon--right-alignedshare-circle1Icon--share-black-48x48Icon--shopping-bag-black-48x48Icon-shopping-cartIcon--start-play-black-48x48Icon--store-locator-black-48x48Ic-OverlayAlertIcon--summary-black-48x48tumblrIcon-FilledvineIc-OverlayAlertwhishlist