Телесистемы
 Разработка, производство и продажа радиоэлектронной аппаратуры
На главную   | Карта сайта | Пишите нам | В избранное
Требуется программист в Зеленограде
- обработка данных с датчиков; ColdFire; 40 тыс.
e-mail:jobsmp@pochta.ru

Телесистемы | Электроника | Конференция «Микроконтроллеры и их применение»

Ответ:

Отправлено kolja 04 сентября 2007 г. 16:28
В ответ на: ADSP-BF532: кто-нибудь может бросить текстуру с примером работы DMA память-память. Другие форумы очень сонные, а здесь многие бывают. отправлено Lucky 04 сентября 2007 г. 15:01

////////////////////////////////////////////////////////////////
#define DMA_1D_MODE (0<<4)
#define DMA_2D_MODE (1<<4)

#define DMA_WDSIZE_8_BIT (0<<2)
#define DMA_WDSIZE_16_BIT (1<<2)
#define DMA_WDSIZE_32_BIT (2<<2)

////////////////////////////////////////////////////////////////
typedef struct __C_DMA_Descriptor
{
unsigned short dma_mode;
unsigned short dma_wdsize;
void *start_addr;
unsigned short x_count;
short x_modify_bytes;
unsigned short y_count;
short y_modify_bytes;
}C_DMA_Descriptor;

//**************************************************************************
section("L1_code") void sys_DMA0_transfer(C_DMA_Descriptor *dst, C_DMA_Descriptor *src)
{
///////////////// SOURCE ///////////////////////////////////////////////////
*pMDMA_S0_START_ADDR = src->start_addr;

*pMDMA_S0_X_MODIFY = src->x_modify_bytes;
*pMDMA_S0_Y_MODIFY = src->y_modify_bytes;

*pMDMA_S0_X_COUNT = src->x_count;
*pMDMA_S0_Y_COUNT = src->y_count;

*pMDMA_S0_CONFIG = (src->dma_mode) | (src->dma_wdsize) | DMAEN;

//////////////// DESTINATION ///////////////////////////////////////////////
*pMDMA_D0_START_ADDR = dst->start_addr;

*pMDMA_D0_X_MODIFY = dst->x_modify_bytes;
*pMDMA_D0_Y_MODIFY = dst->y_modify_bytes;

*pMDMA_D0_X_COUNT = dst->x_count;
*pMDMA_D0_Y_COUNT = dst->y_count;

*pMDMA_D0_CONFIG = (dst->dma_mode) | (dst->dma_wdsize) | DMAEN | WNR;
ssync();

////////////////////////////////////////////////////////////////////////////
while(*pMDMA_D0_IRQ_STATUS & DMA_RUN);//Wait for DMA to Complete
}

//**************************************************************************
section("L1_code") void sys_DMA1_transfer(C_DMA_Descriptor *dst, C_DMA_Descriptor *src)
{
///////////////// SOURCE ///////////////////////////////////////////////////
*pMDMA_S1_START_ADDR = src->start_addr;

*pMDMA_S1_X_MODIFY = src->x_modify_bytes;
*pMDMA_S1_Y_MODIFY = src->y_modify_bytes;

*pMDMA_S1_X_COUNT = src->x_count;
*pMDMA_S1_Y_COUNT = src->y_count;

*pMDMA_S1_CONFIG = (src->dma_mode) | (src->dma_wdsize) | DMAEN;

//////////////// DESTINATION ///////////////////////////////////////////////
*pMDMA_D1_START_ADDR = dst->start_addr;

*pMDMA_D1_X_MODIFY = dst->x_modify_bytes;
*pMDMA_D1_Y_MODIFY = dst->y_modify_bytes;

*pMDMA_D1_X_COUNT = dst->x_count;
*pMDMA_D1_Y_COUNT = dst->y_count;

*pMDMA_D1_CONFIG = (dst->dma_mode) | (dst->dma_wdsize) | DMAEN | WNR;
ssync();

////////////////////////////////////////////////////////////////////////////
while(*pMDMA_D1_IRQ_STATUS & DMA_RUN);//Wait for DMA to Complete
}

//**************************************************************************



Составить ответ | Вернуться на конференцию

Ответы


Отправка ответа
Имя*: 
Пароль: 
E-mail: 
Тема*:

Сообщение:

Ссылка на URL: 
URL изображения: 

если вы незарегистрированный на форуме пользователь, то
для успешного добавления сообщения заполните поле, как указано ниже:
вычтите из двух единицу:

Перейти к списку ответов | Конференция | Раздел "Электроника" | Главная страница | Карта сайта

Rambler's Top100 Рейтинг@Mail.ru
 
Web telesys.ru