Hallo Forum,
ich möchte auf einem SAMC20J18A alle 0,4µs ein Byte aus einem Array im
RAM per DMA in das untere Byte des PORTA schieben.
Dazu habe ich mir die Bespiele auf der Atmel Seite und das Datenblatt
der SAMC Familie angesehen.
Ich bin über die Art der Angabe der Quell und Ziel -Addressen irritiert.
Im Datenblatt steht, dass die letzte Beat-Addresse angegeben werden
soll.
Darüber bin ich ansich schon verwundert. Arbeitet der DMA rückwärts?
Warum gebe ich Inkrements an, wenn er dann in den Addressen die LETZTE
Adresse haben will? "Inkrement" und "Letzte" passt für mich nicht
zusammen.
Wenn ich mir dann die Beispiele auf der Atmel Seite anschaue, wird dort
nicht die "letzte Addresse" sondern grundsätzlich die "letzte Addresse +
1" an den DMA übergeben.
Das Beispiel meint:
1 | descriptor.destination_address = (uint32_t)(array + sizeof(array));
|
Was für mich nicht die letzte Addresse ist, sondern die "erste Addresse
hinter dem array" wäre.
Gemäß Datenblatt hätte ich geschrieben/erwartet:
1 | descriptor.destination_address = (uint32_t)(array + sizeof(array) - 1 * BEATSIZE);
|
Hat das jemand durchschaut und kann mir sagen, warum die Addressangabe
so ungewöhnlich ist und ob ich einen Denkfehler mache?