Понял. Я подобным образом работаю с DS18b20. Вот рабочий кусок кода(лишнее можно выбросить, я подстраховался):
Код
USART_Cmd(USART_DS18B20, DISABLE);
//USART_DS18B20
USART_InitTypeDef USART_InitStructure;
USART_InitStructure.USART_BaudRate = 115200;
USART_InitStructure.USART_WordLength = USART_WordLength_8b;
USART_InitStructure.USART_StopBits = USART_StopBits_1;
USART_InitStructure.USART_Parity = USART_Parity_No;
USART_InitStructure.USART_HardwareFlowControl = USART_HardwareFlowControl_None;
USART_InitStructure.USART_Mode = USART_Mode_Rx | USART_Mode_Tx;
USART_Init(USART_DS18B20, &USART_InitStructure);
// конфигурирую DMA
DMA_InitTypeDef DMA_InitStructure;
DMA_DeInit(USART_DS18B20_Rx_DMA_Ch);
DMA_InitStructure.DMA_PeripheralBaseAddr = (uint32_t)&USART_DS18B20_DR_Base;
DMA_InitStructure.DMA_MemoryBaseAddr = (uint32_t)rx_data_buf;
DMA_InitStructure.DMA_DIR = DMA_DIR_PeripheralSRC;
DMA_InitStructure.DMA_BufferSize = 1000;
DMA_InitStructure.DMA_PeripheralInc = DMA_PeripheralInc_Disable;
DMA_InitStructure.DMA_MemoryInc = DMA_MemoryInc_Enable;
DMA_InitStructure.DMA_PeripheralDataSize = DMA_PeripheralDataSize_Byte;
DMA_InitStructure.DMA_MemoryDataSize = DMA_MemoryDataSize_Byte;
DMA_InitStructure.DMA_Mode = DMA_Mode_Normal;
DMA_InitStructure.DMA_Priority = DMA_Priority_VeryHigh;
DMA_InitStructure.DMA_M2M = DMA_M2M_Disable;
DMA_Init(USART_DS18B20_Rx_DMA_Ch, &DMA_InitStructure);
DMA_DeInit(USART_DS18B20_Tx_DMA_Ch);
DMA_InitStructure.DMA_PeripheralBaseAddr = (uint32_t)&USART_DS18B20_DR_Base;
DMA_InitStructure.DMA_MemoryBaseAddr = (uint32_t)tx_data_buf;
DMA_InitStructure.DMA_DIR = DMA_DIR_PeripheralDST;
DMA_InitStructure.DMA_BufferSize = cnt;
DMA_InitStructure.DMA_PeripheralInc = DMA_PeripheralInc_Disable;
DMA_InitStructure.DMA_MemoryInc = DMA_MemoryInc_Enable;
DMA_InitStructure.DMA_PeripheralDataSize = DMA_PeripheralDataSize_Byte;
DMA_InitStructure.DMA_MemoryDataSize = DMA_MemoryDataSize_Byte;
DMA_InitStructure.DMA_Mode = DMA_Mode_Normal;
DMA_InitStructure.DMA_Priority = DMA_Priority_VeryHigh;
DMA_InitStructure.DMA_M2M = DMA_M2M_Disable;
DMA_Init(USART_DS18B20_Tx_DMA_Ch, &DMA_InitStructure);
USART_ClearFlag(USART_DBG,USART_IT_TC);
USART_Cmd(USART_DS18B20, ENABLE);
USART_DMACmd(USART_DS18B20, USART_DMAReq_Tx | USART_DMAReq_Rx, ENABLE);
DMA_ITConfig(USART_DS18B20_Tx_DMA_Ch, DMA_IT_TC | DMA_IT_TE, ENABLE);
DMA_ITConfig(USART_DS18B20_Rx_DMA_Ch, DMA_IT_HT | DMA_IT_TC | DMA_IT_TE, DISABLE);
// запускаю передачу
DMA_Cmd(USART_DS18B20_Rx_DMA_Ch, ENABLE);
DMA_Cmd(USART_DS18B20_Tx_DMA_Ch, ENABLE);
// засыпаю до завершения передачи
USART_Cmd(USART_DS18B20, DISABLE);
DMA_Cmd(USART_DS18B20_Rx_DMA_Ch, DISABLE);
DMA_Cmd(USART_DS18B20_Tx_DMA_Ch, DISABLE);
DMA_ClearITPendingBit(DMA1_IT_GL2);
DMA_ClearITPendingBit(DMA1_IT_GL3);