This post is older than 2 years and might not be relevant anymore
More Info: Consider searching for newer posts

Unable to use TWI on nrf52840

Hi 

I am trying to use the TWI on nrf52840 but i am unable to get it to work. its getting stuck somewhere. I dont have a logic analyzer so i am unable to check if the signal are coming or not. I am able to use the I2C with apache mynewt so i dont think its the hardware problem. i have doubled checked the pin assignments for SCL and SDA as well. I have attached the code. Please help me out.

Output on the terminal:

<info> app: TWI scanner started
<info> app: Function return code: NRF_SUCCESS
<info> app: after twi_init

sdk_config.h

/**
 * Copyright (c) 2016 - 2018, Nordic Semiconductor ASA
 *
 * All rights reserved.
 *
 * Redistribution and use in source and binary forms, with or without modification,
 * are permitted provided that the following conditions are met:
 *
 * 1. Redistributions of source code must retain the above copyright notice, this
 *    list of conditions and the following disclaimer.
 *
 * 2. Redistributions in binary form, except as embedded into a Nordic
 *    Semiconductor ASA integrated circuit in a product or a software update for
 *    such product, must reproduce the above copyright notice, this list of
 *    conditions and the following disclaimer in the documentation and/or other
 *    materials provided with the distribution.
 *
 * 3. Neither the name of Nordic Semiconductor ASA nor the names of its
 *    contributors may be used to endorse or promote products derived from this
 *    software without specific prior written permission.
 *
 * 4. This software, with or without modification, must only be used with a
 *    Nordic Semiconductor ASA integrated circuit.
 *
 * 5. Any software provided in binary form under this license must not be reverse
 *    engineered, decompiled, modified and/or disassembled.
 *
 * THIS SOFTWARE IS PROVIDED BY NORDIC SEMICONDUCTOR ASA "AS IS" AND ANY EXPRESS
 * OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
 * OF MERCHANTABILITY, NONINFRINGEMENT, AND FITNESS FOR A PARTICULAR PURPOSE ARE
 * DISCLAIMED. IN NO EVENT SHALL NORDIC SEMICONDUCTOR ASA OR CONTRIBUTORS BE
 * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE
 * GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
 * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 *
 */
/** @file
 * @defgroup tw_scanner main.c
 * @{
 * @ingroup nrf_twi_example
 * @brief TWI Sensor Example main file.
 *
 * This file contains the source code for a sample application using TWI.
 *
 */

#include <stdio.h>
#include "boards.h"
#include "app_util_platform.h"
#include "app_error.h"
#include "nrf_drv_twi.h"



#include "nrf_log.h"
#include "nrf_log_ctrl.h"
#include "nrf_log_default_backends.h"

/* TWI instance ID. */
#define TWI0_ENABLED 1
#define TWI_INSTANCE_ID     0

#define MPU9250_ADDRESS 0x68
#define WHO_AM_I_MPU9250 0x75 // Should return 0x71
#define CORRECT_RETURN 0x71

/* TWI instance. */
static const nrf_drv_twi_t m_twi = NRF_DRV_TWI_INSTANCE(TWI_INSTANCE_ID);



/**
 * @brief TWI initialization.
 */
void twi_init (void)
{
    ret_code_t err_code;

    const nrf_drv_twi_config_t twi_config = {
       .scl                = I2C_0_PIN_SCL,
       .sda                = I2C_0_PIN_SDA,
       .frequency          = I2C_0_FREQ_KHZ,
       .interrupt_priority = APP_IRQ_PRIORITY_HIGH,
       .clear_bus_init     = false
    };

    err_code = nrf_drv_twi_init(&m_twi, &twi_config, NULL, NULL);
    
    char const * p_desc = nrf_strerror_find(err_code);
    if (p_desc == NULL)
    {
        /* No human readable form found */
        NRF_LOG_INFO("Function return code: UNKNOWN (%x)", err_code);
    }
    else
    {
        /* Nice - mnemonic like - human readable form found */
        NRF_LOG_INFO("Function return code: %s", p_desc);
    }
     
    APP_ERROR_CHECK(err_code);
    nrf_drv_twi_enable(&m_twi);

}

/*
 * function to read sensor registers.
*/
ret_code_t read_register(nrf_drv_twi_t twi_instance, uint8_t device_addr, uint8_t register_addr, uint8_t *p_data, uint8_t bytes, bool no_stop)
{
  ret_code_t err_code;

  err_code = nrf_drv_twi_tx(&twi_instance, device_addr, &register_addr, 1, no_stop);
  APP_ERROR_CHECK(err_code);

  if(err_code != NRF_SUCCESS) {
    return err_code;
  }

  err_code = nrf_drv_twi_rx(&twi_instance, device_addr, p_data, bytes);
  return err_code;
}


/**
 * @brief Function for main application entry.
 */
int main(void)
{
    ret_code_t err_code;
    //uint8_t address;
    uint8_t sample_data;
    bool detected_device = false;

    APP_ERROR_CHECK(NRF_LOG_INIT(NULL));
    NRF_LOG_DEFAULT_BACKENDS_INIT();

    NRF_LOG_INFO("TWI scanner started");
    NRF_LOG_FLUSH();
    twi_init();
    NRF_LOG_INFO("after twi_init");
	NRF_LOG_FLUSH();  


	err_code = read_register(m_twi, MPU9250_ADDRESS, WHO_AM_I_MPU9250, &sample_data, sizeof(sample_data), 0);

	char const * p_desc = nrf_strerror_find(err_code);
	if (p_desc == NULL)
	{
		/* No human readable form found */
		NRF_LOG_INFO("Function read_register code: UNKNOWN (%x)", err_code);
	}
	else
	{
		/* Nice - mnemonic like - human readable form found */
		NRF_LOG_INFO("Function read_register code: %s", p_desc);
	}
	NRF_LOG_FLUSH();
	
	if (err_code == NRF_SUCCESS)
	{
		detected_device = true;
		NRF_LOG_INFO("should be 0x71 but is 0x%02X", sample_data);
	}else{
		NRF_LOG_INFO("Failed!\n");
	}
	NRF_LOG_FLUSH();	
	
	
    if (!detected_device)
    {
        NRF_LOG_INFO("No device was found.");
        NRF_LOG_FLUSH();
    }

    while (true)
    {
        /* Empty loop. */
    }
}

/** @} */

Thanks.

Parents Reply Children
Related