

# iND86201 Application Notes



8/30/17

iND86201 Application Note



# 1.0 TABLE OF CONTENTS

| 1.0 | TABLE OF CONTENTS                             | 3    |
|-----|-----------------------------------------------|------|
| 2.0 | LIST OF FIGURES                               | 4    |
| 3.0 | KNOWN ISSUES AND WORKAROUND                   | 5    |
| 3.  | 1 PIN Wake-up Fail Once USB Connected to A PC | 5    |
| 3.  | 2GPIO Read/Write failure                      | 5    |
| 3.  | 3 Wake-up issue                               | 6    |
| 3.  | 4ADC current drain4ADC current drain          | 7    |
| 3.  | 5Sequence for Band Gap Startup                | 8    |
| 4.0 | REFERENCES                                    | 9    |
| 5.0 | REVISION HISTORY                              | 9    |
| 6.0 | CONTACTS                                      | . 10 |



# 2.0 LIST OF FIGURES

No table of figures entries found.



## 3.0 Known Issues and Workaround

## 3.1 PIN WAKE-UP FAIL ONCE USB CONNECTED TO A PC

#### Function:

By setting the PIN, Ernie can wake up from deep sleep when status of the IO is changed.

#### Issue:

PIN wake-up does not work if Ernie's USB is connected to a PC.

#### **Issue Workaround:**

"USBF" flag in PMURST register has to be cleared before system goes into deep sleep.

## 3.2 GPIO READ/WRITE FAILURE

#### Function:

**GPIO Read/Write** 

#### Issue:

The read operation on GPIOC and GPIOD might return invalid results, it will also affect the read-modify-write operation where invalid result results get programmed into the port register.

#### Issue Workaround:

Additional read operation on GPIOB is required to allow consistently correct result to be propagated to the port register.

For a read operation:

```
uint8_t GPIOD_PortRead(uint8_t mask)
{
    uint8_t data;
    /* Additional read operation on GPIOB is placed before the read operation on GPIOD. */
    data = GPIOB_SFRS->PORT;
    return GPIOD_SFRS->PORT & mask;
}
```

#### For a write operation:

void GPIOD\_PortSet(uint8\_t val, uint8\_t mask)



```
uint8_t readen;
uint8_t data;

readen = GPIOD_SFRS->READEN;
GPIOD_SFRS->READEN = 0xFF;
/* Additional read operation on GPIOB is placed before the read operation on GPIOD. */
data = GPIOB_SFRS->PORT;
data = GPIOD_SFRS->PORT;
GPIOD_SFRS->PORT = (val & mask) | (data & ~mask);
GPIOD_SFRS->READEN = readen;
}
```

## 3.3 WAKE-UP ISSUE

#### Function:

Wake-Up

#### Issue:

In very rare instances, Ernie enters deep sleep mode forever during the intensive sleep and wakeup test triggered by GPIO interrupts. The root cause is that if a GPIO interrupt is fired when Ernie is in the transition to deep sleep mode, the system will enter an undefined mode where no wakeup event can be fired till the system going through a full power cycle.

Typically, these GPIOs are designed as default pull-up, a pull-down to GND will generate a wakeup event.

#### Issue Workaround:

Block all GPIO events from being generated during the transition from active mode to deep sleep mode.

From hardware side, capacitors of 100nF are required to be placed between GPIO pins and GND. This configuration will introduce a delay for any GPIO hardware to generate edge transitions.

From software side, before entering deep sleep mode, software sets those GPIO pins as output and clear them to 0 to discharge these signals completely. Then set them back to input interrupt mode. Since these pins are being slowly pulled-up due to the high pull-up resistors and the external capacitors added (from previous paragraph) thus a certain minimum delay is inserted here. Before the signals are to be pulled high enough to cross the threshold, the end user will not be able to fire any pull-down interrupts.



Here is the example code to enter deep sleep mode, in this example, GPIOB.0 and GPIOB.1 are design as interrupt sources for system wakeup.

```
static void enter_sleep_mode(void)
{
    /* Block GPIO falling edge interrupts during the transition to deep sleep mode.
    It is achieved by adding a 100nF capacitor on each GPIO with interrupt enabled */
    GPIOB_EnablePortOutput(1, 0x03);
    GPIOB_PortSet(0, 0x03);
    GPIOB_EnablePortOutput(0, 0x03);
    /* Request to enter deep sleep mode */
    PMU_devSleepLowPwrReboot(PMU_WAKEUP_TIME_MAX);
    while(1);
}
```

## 3.4 ADC CURRENT DRAIN

Function: ADC

Issue: Current Drain

#### **Issue Workaround:**

In order to put ADC in minimum current drain in deep sleep mode, ADC channel selection needs to be 0x3F so that non-channel is selected. In our example code:

```
int32_t ADC_devExit(ADC_Device_t *dev)
{
   if (!dev)
     return -EFAULT;
   /* Set ADC channel to NONE */
   dev->SelectChannel(E_ADC_CHANNEL_NONE);
   ADC_SFRS->TRIM2.ADCENABLE = 0;
   return 0;
}
```



## 3.5 SEQUENCE FOR BAND GAP STARTUP

Function: Bandgap startup

#### Issue:

Normally a band gap can be enabled by setting all the enable bits in the register for analog power control (0x50000058) at the same time. In rare instances in Ernie, startup might be delayed or failed. The worse cases are observed at lower battery level and lower temperature.

#### Issue Workaround:

In order to guarantee a solid startup of bandgap, the following sequence shall be followed:

- 1. Enable BG, wait 1 ms
- 2. Enable BG and enable BG\_BUF, wait 1 ms
- 3. Enable BG and enable BG\_BUF and enable V2I, wait 1 ms



# 4.0 REFERENCES

[1] iND86201 data sheet

# **5.0 REVISION HISTORY**

| Rev# | Date      | Action          |  |
|------|-----------|-----------------|--|
| 0.1  | 8/16/2017 | Initial version |  |
|      |           |                 |  |
|      |           |                 |  |
|      |           |                 |  |



## 6.0 CONTACTS

#### **United States**

32 Journey Aliso Viejo, California 92656, USA Tel: +1 949-608-0854 sales@indiesemi.com

#### China

232 Room, Donghai Wanhao Plaza, South Hi-tech 11th Road, Hi-tech Industry Park, Nanshan District, Shenzhen, China. Tel: +86 755-86116939

#### **Scotland**

5<sup>th</sup> Floor, The Auction House 63a George Street Edinburgh EH2 2JG, Scotland Tel: +44 131 718 6378

http://www.indiesemi.com/



# **Important Notice**

indie semiconductor reserves the right to make changes, corrections, enhancements, modifications, and improvements to indie semiconductor products and/or to this document at any time without notice. Purchasers should obtain the latest relevant information on indie semiconductor products before placing orders. indie semiconductor products are sold pursuant to indie semiconductor's terms and conditions of sale in place at the time of order acknowledgement. Purchasers are solely responsible for the choice, selection, and use of indie semiconductor products and services described herein. indie semiconductor assumes no liability for the choice, selection, application assistance or the design of Purchasers' products.

No license, express or implied, to any intellectual property right is granted by indie semiconductor by this document.

The materials, products and information are provided "as is" without warranty of any kind, whether express, implied, statutory, or otherwise, including fitness for a particular purpose or use, merchantability, performance, quality or non-infringement of any intellectual property right. Indie semiconductor does not warrant the accuracy or completeness of the information, text, graphics or other items contained herein. indie semiconductor shall not be liable for any damages, including but not limited to any special, indirect, incidental, statutory, or consequential damages, including without limitation, lost of revenues or lost profits that may result from the use of the materials or information, whether or not the recipient of material has been advised of the possibility of such damage.

Unless expressly approved in writing by two authorized indie semiconductor representatives, indie semiconductor products are not designed, intended, warranted, or authorized for use as components in military, space, or aircraft, in systems intended to support or sustain life, or for any other application in which the failure or malfunction of the indie semiconductor product may result in personal injury, death, or severe property or environmental damage.

Information in this document supersedes and replaces information previously supplied in any prior versions of this document.

© 2017, indie semiconductor, all rights reserved