RL78 F13 - Needed sample code to understand DTC functionality with ADC Scan One shot mode

Dear Renesas community,

I'm looking for sample code to understand DTC with ADC scan one shot mode.

Needed scenario like 4 ADC channels conversion data want to transfer from ADCR to 4 different variables at each INTAD interrupt.

and 4 variables like arr[index], index value will be incremented at each INTAD interrupt. and index will be reseted after 4th channel ADC conversion

Could you please provide the sample code for the same?

Thanks & Regards,

Meet

Parents
  • Hello,

    Yes, I can provide this for you. 

    So when the INTAD occurs, you want to store the 4 results of the 4 ADC channels in a buffer using DTC, correct ?

  • Yes, every trigger of ADC SOC will generates 4 INTAD interrupts one by one after EOC(end of ADC conversation). 

    Steps: 

    1. So when 1st interrupt comes, transfer the result from ADC result register(source address is fixed for DTC) to arr[0] register. 

    2. Then when 2nd INTAD interrupt comes after 2nd channel ADC EOC, same ADC result register data should be copied to arr[1].

    3. Likewise for 3rd and 4th interrupt, DTC should transfer the ADC result register data into arr[2] and arr[3]. 

    4. Then array counter will reset and next trigger of ADC SOC, will start again and repeat steps from point no 1.

    Note :  I have considered 16 bit data transfer for 10bit ADC. 

    Kindly consider above scenario for sample code. 

    In addition, I have few queries as mentioned below - 

    1. for DTC destination address, how and where I can configure if the destination array is present in another file. e.g. uint16_t arr[4];

    2. How array index counters will be incremented while transferring next ADC result register data via DTC? 

    3. How DTC understand counter reset and destination address will start to store again from arr[0] ? 

    Thanks & Regards, 

    Meet

  • Hello,

    Please find the attached demo project.

    ADC_DTC_F13.zip

    ANI0-ANI3 channels are scanned and stored at 0xFF400 address in RAM using DTC.

    The destination address is usually specified in Code Generator. You can declare your array to be stored in a specific address using #pragma (as done in the example) and use this address as a destination address.

    Please go through the DTC settings on Code Generator.

    Let me know if you have any questions.

    Regards

  • Hi,

    Thank you for providing the Sample code.

    I have few questions regarding the same.

    1. How can we select the destination address?

    2. R_DTCD0_Start() can be called in ADC ISR as well ? 

    3. Need more details about repeat mode concept, How the address is incremented? and array data type should be uint16_t only or we can take any other data type for destination array ?

    Thanks & Regards,

  • 1) Well, if you decide to have a buffer in RAM to store the results, you need to know the memory range of RAM and select an address.

    But some regions of RAM are used for other purposes too, so you need to make sure the buffer does not overlap with them. (for example trace area for debugger, self-RAM area for flash libraries etc).

    Please take a look on page 107-108.

    2) Yes, but the interrupt that called the ISR will not trigger the DTC. The next interrupt will.

    3) The address is incremented automatically if it selected on Code Generator. The type of data can be different but if you have a 10-bit result, what else can it be ?

    For Repeat mode please look into section 19.3.3

    https://www.renesas.com/us/en/document/mah/rl78f13-f14-users-manual-hardware-rev220?r=1054256

    Regards

  • Regarding answer no.2 

    If next interrupt will trigger/call DTC data transfer, then we will lose the ADC data of first channel from ADCR register right?

    If yes, then may i know why DTC will not be triggered in the ISR where DTC is called?

    If no, can you please explain how we will not lose the data of 1st channel ADC converted data?

Reply
  • Regarding answer no.2 

    If next interrupt will trigger/call DTC data transfer, then we will lose the ADC data of first channel from ADCR register right?

    If yes, then may i know why DTC will not be triggered in the ISR where DTC is called?

    If no, can you please explain how we will not lose the data of 1st channel ADC converted data?

Children