2.64 Memory to Memory (MEM2MEM)

The Memory to Memory (MEM2MEM) module allows the Peripheral DMA Controller (PDC) to perform memory to memory transfer without CPU intervention. The transfer size can be configured in byte, half-word or word. Two PDC channels are required to perform the transfer; one channel defines the source of the transfer and the other defines the destination.

Using The Library

This library used PDC to transfer data from memory to memory without CPU intervention.

	 // Transfer 10 bytes of data from one buffer to another using MEM2MEM
	 MY_APP_OBJ myAppObj;
	 uint8_t buf[10] = {0,1,2,3,4,5,6,7,8,9};
	 uint8_t buf2[10] = {};
	 void *srcAddr = (uint8_t *) buf;
	 void *destAddr = (uin8_t*) buf2;
	 size_t size = 10;

	 // User registers an event handler with PLIB. This is done once.
	 MEM2MEM_ChannelCallbackRegister(APP_MEM2MEMTransferEventHandler,
	 (uintptr_t)&myAppObj);

	 if(MEM2MEM_ChannelTransfer(srcAddr, destAddr, size,MEM2MEM_TRANSFER_WIDTH_BYTE) == true)
	 {
	 // do something
	 }
	 else
	 {
	 // try again?
	 }
 

Library Interface

Memory to Memory peripheral library provides the following interfaces:

Functions

NameDescription
MEM2MEM_ChannelCallbackRegisterThis function allows a MEM2MEM PLIB client to set a callback
MEM2MEM_ChannelTransferRegisters a DMA transfer using MEM2MEM

Data types and constants

NameTypeDescription
MEM2MEM_TRANSFER_WIDTHEnumIdentifies the transfer width to be used
MEM2MEM_TRANSFER_EVENTEnumEnumeration of possible MEM2MEM transfer events
MEM2MEM_CALLBACKTypedefPointer to a MEM2MEM Transfer Event handler function
Note: Not all APIs maybe implemented. See the specific device family section for available APIs.