From b4b00814a80f8233c7782602a9a8698de0a0ac47 Mon Sep 17 00:00:00 2001 From: Henrik Moe Arnesen Date: Wed, 27 Nov 2024 10:48:04 +0100 Subject: [PATCH] MPAE-18615: Add AC DACREF clarification and update formula formatting --- README.md | 16 ++++++++-------- 1 file changed, 8 insertions(+), 8 deletions(-) diff --git a/README.md b/README.md index 67d5374..768b3e9 100644 --- a/README.md +++ b/README.md @@ -66,14 +66,14 @@ All communication is sent over the data interface for this basic Virtual Serial This example is configured to run on 24 MHz. The minimum oscillator frequency for USB on the AVR DU is 12 MHz.

-The application uses a delay function to blink an LED if the USB connection fails. This delay function is dependent on knowing the main clock speed through the F_CPU define. Here, this has been set up as a preprocessed define macro in the project settings, as seen in the image below. +The application uses a delay function to blink an LED if the USB connection fails. This delay function is dependent on knowing the main clock speed through the F_CPU define. Here, this has been set up as a preprocessed define macro in the project settings.

Alternatively, it could have been added in the main file as `#define F_CPU 24000000UL` above the `#include ` line. ### USB Voltage Detection Setup -To ensure that the USB peripheral only tries to attach to the bus when the Curiosity Nano is connected to the PC, the Analog Comparator will periodically check if the voltage is within the acceptable range for VBUS. +To ensure that the USB peripheral only tries to attach to the bus when the Curiosity Nano is connected to the PC, the Analog Comparator will be checked periodically if the voltage is within the acceptable range for VBUS. #### Voltage Reference Setup In the VREF peripheral, the Voltage Reference is set to 2.048V. @@ -86,11 +86,11 @@ The positive input is set to the USB DETECT pin on the Curiosity Nano which is c To calculate the DACREF, use the formula from the data sheet: -*V_DACREF = (DACREF / 256) * V_REF* +*VDACREF> = (DACREF / 256) * VREF* Due to the voltage divider present on the Curiosity Nano, a threshold of 0.32V is needed for this project. Inputting this value into the Requested Voltage field in MCC can calculate the DACREF value automatically. -Refer to the [AVR64DU32 Curiosity Nano User Guide](https://ww1.microchip.com/downloads/aemDocuments/documents/MCU08/ProductDocuments/UserGuides/AVR64DU32-Curiosity-Nano-UserGuide-DS50003671.pdf) for more information on how the *USB DETECT* is implemented on the Curiosity Nano. +Refer to the [AVR64DU32 Curiosity Nano User Guide](https://ww1.microchip.com/downloads/aemDocuments/documents/MCU08/ProductDocuments/UserGuides/AVR64DU32-Curiosity-Nano-UserGuide-DS50003671.pdf) for more information on how the USB DETECT is implemented on the Curiosity Nano.

@@ -102,22 +102,22 @@ The RTC is configured to run on a 1 kHz clock with no prescaler.

#### RTC Interrupt Settings -The PIT is then set to trigger at every 32 clock cycles of the RTC clock. this gives an update rate of ~31 Hz. +The PIT is then set to trigger at every 32 clock cycles of the RTC clock, which gives an update rate of ~31 Hz.

-The application is set up to need five stable voltage readings before initiating the USB communication. This means that, with no voltage fluctuations and the settings above, the start-up time will be in the 0.16s range. +The application is set up to need five stable voltage readings before initiating the USB communication. Considering the previous settings and an environment with no voltage fluctuations, the start-up time is in the 0.16s range. ### LED Setup The on-board LED of the Curiosity Nano is used to indicate if the USB communications has failed. The LED is connected to the PF1 pin and can be selected as an output in the Pin Grid View below.

-The pin is given a custom name in the Pins menu, as seen below. This makes the code easier to read with function generated using this name. +The pin is given a custom name in the Pins menu, as seen below. This makes the code easier to read with the functions generated using this name.

### Global Interrupts -Since this example uses interrupts for voltage monitoring, global interrupt must be enabled in the Interrupt Manager. +Since this example uses interrupts both for voltage monitoring and for USART communication, toggle the Global Interrupt Enable button Interrupt Manager.