wake on PDM microphone

I see there is a way to set an audio event exceeding a set threshold.
https://infocenter.nordicsemi.com/index.jsp?topic=%2Fug_thingy53%2FUG%2Fthingy53%2Fhw_description%2Fmicrophone_buzzer.html

I found the nfc system_off sample and added button press to wake using:
nrf_gpio_cfg_sense_set(NRF_DT_GPIOS_TO_PSEL(DT_ALIAS(sw0), gpios), NRF_GPIO_PIN_SENSE_HIGH);
to wake the board when a button is pressed.  (this works for me, but doesn't call the button callback upon wake, so you have to press once to wake and another for button press)

I'd like for the device to wake on sound, light, and motion.  Based on the document referenced above it seems theres a way to wake on sound, haven't yet figured it out.

Is there a sample for waking the device for sound.  I'm still learning and any direction would be greatly appreciated.

Parents Reply
  • Tried setting mcuboot-button0; it looked like it was working for a while but still found myself with a locked up device.

       aliases {
            mcuboot-button0 = &button0;
        };
    I haven't found any information on how to get my project working while disabling the mcuboot.  I can't use the RTC module when this occurs and switching the device is no fun.

    I hope you have success in finding a solution.
Children
  • My apology for the long absence. 

    I just want to let you know that I am still working on this case. 

    I have thought that the issue is with the Serial Recovery feature, where MCUboot would enter recovery mode and await a new application image. CONFIG_BOOT_SERIAL_ENTRANCE_GPIO enabled this feature, and it is on by default.

    However, further testing show that it might not be the case. The device remains stuck even after I disabled Serial Recovery completely, not just the button entrance method.
    (I also ran into the observation that button0 somehow cannot be used instead)

    At the moment, I have found that if we disable the GPIO driver completely by setting CONFIG_GPIO=n for MCUboot, then the device works as expect.

    However, I don't know if this state is acceptable for you. I know you plan to use MCUboot, but do you plan to use the Serial Recovery feature?

    Considering that you want the device to work with the scenario where an end-user would repeatedly press the button, you will not be able to use the button to enter the Serial Recovery mode, regardless of configs.

    Please let me know what you think. I have a few more things I will try tomorrow, but I don't have high hope it will bring any difference.

    Once again, I am very sorry for the long wait.

  • No apologies needed.  I appreciate that you continued your efforts!

    added child_image\mcuboot.conf with 
    CONFIG_GPIO=n
    I found it wasn't enough and I had to put
    CONFIG_MCUBOOT_SERIAL=n
    in as well.

    This fix also worked in the project not just the sample.  Cheers and thank u.

    Correct, a button press entry into DFU mode would not work.  Updates were not top of my priority list, but the concept I was thinking would be a bluetooth command to write a flash value indicating entry into the serial recovery feature and sys_reboot()?  With it being compiled out, this is not an option currently.

    It's unfortunate that mcuboot causes such a lock and the way in which it locks can corrupt attached i2c device memory.

  • tldr said:
    I found it wasn't enough and I had to put
    CONFIG_MCUBOOT_SERIAL=n
    in as well.

    OK. That's a little surprising. I guess with GPIO not enabled, Serial Recovery default to a different entrance method, some waiting form, and keep the execution stuck in MCUboot still.

    tldr said:
    Correct, a button press entry into DFU mode would not work.  Updates were not top of my priority list

    I think you can use BLE as the primary DFU transport. Serial Recovery is quite nice to have, but not a must.

    tldr said:
    the concept I was thinking would be a bluetooth command to write a flash value indicating entry into the serial recovery feature and sys_reboot()? 

    I don't think there is native support for it, but it's a direction. Not sure how comfortable you are with modifying MCUboot though.

    Here is the definition of the natively supported entrance methods: https://github.com/nrfconnect/sdk-mcuboot/blob/v2.0.99-ncs1/boot/zephyr/Kconfig.serial_recovery#L133-L187

  •  Jump to bootloader (mcuboot) from application without button

    config BOOT_SERIAL_BOOT_MODE
    bool "Check boot mode via retention subsystem"
    depends on RETENTION_BOOT_MODE

    Looks like this retention method might work?

    In terms of waking on sound, it looks like theres a way to do it or that its supposed to.  I'm still looking at the drivers from edge impluse but I wonder if I even need that for threshold and sense wake.

    I don't know if wake from light is possible?  I don't think theres a pin you can sense wake?

  • tldr said:

    config BOOT_SERIAL_BOOT_MODE
    bool "Check boot mode via retention subsystem"
    depends on RETENTION_BOOT_MODE

    Looks like this retention method might work?

    It might work, but you might want to imagine what you want to do with the Serial Recovery feature.

    If the application can run to write to GPREGRET, then it should also be able to receive DFU package.

    The benefit of using Serial Recovery then is to reduce application size.

    Though I imagine you could also add some login during the initialization phase to check if the device has been functioning properly, and if not (like crashing 5 times in a row?), try to go into bootloader mode. This is just a quick idea though, you will want to think about what makes sense for your product.

    tldr said:
    In terms of waking on sound, it looks like theres a way to do it or that its supposed to.  I'm still looking at the drivers from edge impluse but I wonder if I even need that for threshold and sense wake.

    I am unfamiliar with the driver in the Edge Impulse sample application. Are you referring to this? nRF Machine Learning (nordicsemi.com).

    I haven't found mentions of the microphone in that though.

    tldr said:
    I don't know if wake from light is possible?  I don't think theres a pin you can sense wake?

    Do you mean by the BH1749NUC color sensor on the Thingy:53? It doesn't seem so. Its datasheet shows that the only interface it has is I2C.

Related