Forum: Mikrocontroller und Digitale Elektronik SAM C20 DMA Irritation


von F. K. (superpcfan)


Lesenswert?

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?

Bitte melde dich an um einen Beitrag zu schreiben. Anmeldung ist kostenlos und dauert nur eine Minute.
Bestehender Account
Schon ein Account bei Google/GoogleMail? Keine Anmeldung erforderlich!
Mit Google-Account einloggen
Noch kein Account? Hier anmelden.