Реклама на сайте English version  DatasheetsDatasheets

KAZUS.RU - Электронный портал. Принципиальные схемы, Datasheets, Форум по электронике

Новости электроники Новости Литература, электронные книги Литература Документация, даташиты Документация Поиск даташитов (datasheets)Поиск PDF
  От производителей
Новости поставщиков
В мире электроники

  Сборник статей
Электронные книги
FAQ по электронике

  Datasheets
Поиск SMD
Он-лайн справочник

Принципиальные схемы Схемы Каталоги программ, сайтов Каталоги Общение, форум Общение Ваш аккаунтАккаунт
  Каталог схем
Избранные схемы
FAQ по электронике
  Программы
Каталог сайтов
Производители электроники
  Форумы по электронике
Удаленная работа
Помощь проекту


 
Опции темы
Непрочитано 13.03.2019, 21:20  
Donker
Временная регистрация
 
Регистрация: 12.09.2018
Сообщений: 92
Сказал спасибо: 6
Сказали Спасибо 0 раз(а) в 0 сообщении(ях)
Donker на пути к лучшему
По умолчанию Как отправить массив по I2C через DMA на STM32F105 или F030?

Как отправить массив (uint8_t) по I2C через DMA на STM32F105RBT6 или STM32F030F4 используя CMSIS?

Желательно сначала разобраться как это сделать на STM32F105RBT6 а потом перенести код на STM32F030F4.

Что-то не работает моя переделка снипета от F0 для STM32F105RBT6

Вот часть кода:

Нажмите, чтобы открыть спойлер
Код:
//--------------------------------------------------------------------------------------------

#define		NAME	    0b01111000		//АДРЕС УСТРОЙСТВА НА ШИНЕ        0b01111000 = 0x78
#define		DATS		0b01000000		//ПЕРЕДАЧА НЕСКОЛЬКИХ БАЙТ ДАННЫХ 0b01000000 = 0x40
#define		DAT			0b11000000		//ПЕРЕДАЧА ОДНОГО БАЙТа ДАННЫХ    0b11000000 = 0xC0
#define		COM			0b10000000		//ПЕРЕДАЧА ОДНОГО БАЙТа КОМАНДЫ   0b10000000 = 0x80

uint8_t screen_buff[513]; //буффер экрана 512 байт ((128x32)/8) + самый первый байт для команды DATS

//--------------------------------------------------------------------------------------------

void DMA_init(void)
{
////////////////////////////////////////////////////////////////////////	
RCC->AHBENR |= RCC_AHBENR_DMA1EN; /* Enable the peripheral clock DMA1 */

/* DMA1 Channel4 I2C1_TX config */
/*      Memory to peripheral */                                        
/*      8-bit transfer */
DMA1_Channel4->CPAR = (uint32_t)&(I2C1->DR);         //* (1)  Peripheral address */ DMA1_Channel4->CPAR = (uint32_t)&(I2C1->TXDR);
DMA1_Channel4->CMAR = (uint32_t)screen_buff;         //* (2)  Memory address */
DMA1_Channel4->CCR |= DMA_CCR4_MINC | DMA_CCR4_DIR;  //* (3)  Memory increment */ DMA1_Channel4->CCR |= DMA_CCR_MINC | DMA_CCR_DIR; 
////////////////////////////////////////////////////////////////////////	
}

void I2C_init(void)
{
//////////////////////////////////////////////////////////////////////////////////////	
RCC->APB1ENR |= RCC_APB1ENR_I2C1EN; //включаем тактирование I2C1

I2C1->CR2 &= ~I2C_CR2_FREQ;
I2C1->CR2 |= 36; //частота APB1 в мгц //36

I2C1->CCR &= ~I2C_CCR_CCR;
I2C1->CCR |= 30; //частота SCL//34//
I2C1->CCR |= I2C_CCR_FS; //выбор режима SM Standart mode – 100КГц  или FM Fast mode - 400КГц 

I2C1->TRISE = 12; //максимальное время нарастания импульса //12

I2C1->CR1 |= I2C_CR1_PE; //включаем I2C1
//---------------------------------настройки для DMA--------------------------------------------------
I2C1->CR1 = I2C_CR1_PE | I2C_CR2_DMAEN;  /* (2) Periph enable */ 
I2C1->CR2 =  (512 << 16) | (NAME<<0); /* (3) Slave address = 0x5A, write transfer, 2 bytes to transmit, autoend */ //I2C_CR2_AUTOEND - это где брать?
//////////////////////////////////////////////////////////////////////////////////////
}

void OLED_SendScreen(void)
{
//////////////////////////////////////////////////////////////////////////////////////
//---------------------Посылка буфера экрана через без DMA(работает) -----------------	
//I2C_StartCondition();  
//I2C_SendAddr();  //I2C_SendByte(NAME);		//посыл адреса+0
//for(unsigned int i=0; i<513; i++)
//  {
//  I2C_SendByte(screen_buff[i]);
//  }
//I2C_StopCondition(); 	
//---------------------Посылка буфера экрана через DMA(не работает) ------------------	
	
//if((I2C1->ISR & I2C_ISR_TXE) == (I2C_ISR_TXE))  /* Check Tx empty */
  
	/* start transmission with DMA */
	DMA1_Channel4->CCR &=~ DMA_CCR4_EN;
	DMA1_Channel4->CNDTR = 513;/* Data size */
	DMA1_Channel4->CCR |= DMA_CCR4_EN;

	I2C1->CR1 |= I2C_CR1_START; /* Go */ 	
//////////////////////////////////////////////////////////////////////////////////////		
}

void OLED_init(void)  //ИНИЦИАЛИЗАЦИЯ ДИСПЛЕЯ
{
//////////////////////////////////////////////////////////////////////////////////////
I2C_init();	
DMA_init();		
I2C_StartCondition();
I2C_SendAddr();  
for(unsigned char k=0; k<31; k++)
	{
	I2C_SendByte(COM);
	I2C_SendByte(ini_mass[k]);
	}
I2C_StopCondition();	
screen_buff[0] = 	DATS;
//////////////////////////////////////////////////////////////////////////////////////	
} 
//--------------------------------------------------------------------------------------------


Если раскомментировать в функции OLED_SendScreen пересылку без DMA - тогда работает, если выполнить
OLED_SendScreen в том виде как сейчас, в ЛА видно что происходит "условие старт", после чего линии лежат
в нуле и ничего не передаётся.

Снипет смотрел этот:

Нажмите, чтобы открыть спойлер
Код:
**
  ******************************************************************************
  * @file    03_CommunicationUsingDMA/main.c 
  * @author  MCD Application Team
  * @version V1.2.0
  * @date    19-June-2015
  * @brief   This code example shows how to configure the GPIOs and I2C 
  *          in order to receive with slave and transmit with master.
  *
 ===============================================================================
                    #####       MCU Resources     #####
 ===============================================================================
   - RCC
   - GPIO PB6(I2C1_SCL),PB7(I2C1_SDA),PB10(I2C2_SCL),PB11(I2C2_SDA),PA0,PC8,PC9
   - I2C1 (slave), I2C2 (master)
   - EXTI
   
 ===============================================================================
                    ##### How to use this example #####
 ===============================================================================
   - this file must be inserted in a project containing  the following files :
      o system_stm32f0xx.c, startup_stm32f072xb.s
      o stm32f0xx.h to get the register definitions
      o CMSIS files


 ===============================================================================
                    ##### How to test this example #####
 ===============================================================================
   - Plug wires between PB6/PB10 and PB7/PB11, 4K7 PU are already on the board.
   - Launch the program
   - Press the user button to initiate a transmit request by master 
     then slave receivess a byte
   - The green and orange LEDs toggles if everything goes well

  *    
  ******************************************************************************
  * @attention
  *
  * 

© COPYRIGHT 2015 STMicroelectronics

* * Licensed under MCD-ST Liberty SW License Agreement V2, (the "License"); * You may not use this file except in compliance with the License. * You may obtain a copy of the License at: * * http://www.st.com/software_license_agreement_liberty_v2 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * ****************************************************************************** */ /* Includes ------------------------------------------------------------------*/ #include "stm32f0xx.h" /** @addtogroup STM32F0_Snippets * @{ */ /* Private typedef -----------------------------------------------------------*/ /* Private define ------------------------------------------------------------*/ #define I2C1_OWN_ADDRESS (0x5A) #define I2C_CMD_TOGGLE_ORANGE (0x81) #define I2C_CMD_TOGGLE_GREEN (0x82) #define SIZE_OF_DATA (2) /* Private macro -------------------------------------------------------------*/ /* Private variables ---------------------------------------------------------*/ uint8_t datatosend[SIZE_OF_DATA]={I2C_CMD_TOGGLE_ORANGE,I2C_CMD_TOGGLE_GREEN}; uint8_t datatoreceive[SIZE_OF_DATA]; /* Private function prototypes -----------------------------------------------*/ void Configure_GPIO_LED(void); void Configure_GPIO_I2C1(void); void Configure_DMA_I2C1(void); void Configure_I2C1_Slave(void); void Configure_GPIO_I2C2(void); void Configure_DMA_I2C2(void); void Configure_I2C2_Master(void); void Configure_GPIO_Button(void); void Configure_EXTI(void); /* Private functions ---------------------------------------------------------*/ /** * @brief Main program. * @param None * @retval None */ int main(void) { /*!< At this stage the microcontroller clock setting is already configured, this is done through SystemInit() function which is called from startup file (startup_stm32f072xb.s) before to branch to application main. To reconfigure the default setting of SystemInit() function, refer to system_stm32f0xx.c file */ Configure_GPIO_LED(); Configure_GPIO_I2C1(); Configure_DMA_I2C1(); Configure_I2C1_Slave(); Configure_GPIO_I2C2(); Configure_DMA_I2C2(); Configure_I2C2_Master(); Configure_GPIO_Button(); Configure_EXTI(); /* Initiate I2C sequence in button IRQ handler */ /* Infinite loop */ while (1) { } } /** * @brief This function : - Enables GPIO clock - Configures the Green LED pin on GPIO PC9 - Configures the orange LED pin on GPIO PC8 * @param None * @retval None */ __INLINE void Configure_GPIO_LED(void) { /* Enable the peripheral clock of GPIOC */ RCC->AHBENR |= RCC_AHBENR_GPIOCEN; /* Select output mode (01) on PC8 and PC9 */ GPIOC->MODER = (GPIOC->MODER & ~(GPIO_MODER_MODER8 | GPIO_MODER_MODER9)) \ | (GPIO_MODER_MODER8_0 | GPIO_MODER_MODER9_0); } /** * @brief This function : - Enables GPIO clock - Configures the I2C1 pins on GPIO PB6 PB7 * @param None * @retval None */ __INLINE void Configure_GPIO_I2C1(void) { /* Enable the peripheral clock of GPIOB */ RCC->AHBENR |= RCC_AHBENR_GPIOBEN; /* (1) open drain for I2C signals */ /* (2) AF1 for I2C signals */ /* (3) Select AF mode (10) on PB6 and PB7 */ GPIOB->OTYPER |= GPIO_OTYPER_OT_6 | GPIO_OTYPER_OT_7; /* (1) */ GPIOB->AFR[0] = (GPIOB->AFR[0] & ~(GPIO_AFRL_AFRL6 | GPIO_AFRL_AFRL7)) \ | (1 << ( 6 * 4 )) | (1 << (7 * 4)); /* (2) */ GPIOB->MODER = (GPIOB->MODER & ~(GPIO_MODER_MODER6 | GPIO_MODER_MODER7)) \ | (GPIO_MODER_MODER6_1 | GPIO_MODER_MODER7_1); /* (3) */ } /** * @brief This function configures DMA for I2C1. * @param None * @retval None */ __INLINE void Configure_DMA_I2C1(void) { /* Enable the peripheral clock DMA1 */ RCC->AHBENR |= RCC_AHBENR_DMA1EN; /* DMA1 Channel2 I2C1_RX config */ /* (4) Peripheral address */ /* (5) Memory address */ /* (6) Data size */ /* (7) Memory increment */ /* Peripheral to memory*/ /* 8-bit transfer */ /* Transfer complete IT */ DMA1_Channel3->CPAR = (uint32_t)&(I2C1->RXDR); /* (4) */ DMA1_Channel3->CMAR = (uint32_t)datatoreceive; /* (5) */ DMA1_Channel3->CNDTR = SIZE_OF_DATA; /* (6) */ DMA1_Channel3->CCR |= DMA_CCR_MINC | DMA_CCR_TCIE | DMA_CCR_EN; /* (7) */ /* Configure IT */ /* (8) Set priority for DMA1_Channel2_3_IRQn */ /* (9) Enable DMA1_Channel2_3_IRQn */ NVIC_SetPriority(DMA1_Channel2_3_IRQn, 0); /* (8) */ NVIC_EnableIRQ(DMA1_Channel2_3_IRQn); /* (9) */ } /** * @brief This function configures I2C1, slave. * @param None * @retval None */ __INLINE void Configure_I2C1_Slave(void) { /* Configure RCC for I2C1 */ /* (1) Enable the peripheral clock I2C1 */ /* (2) Use SysClk for I2C CLK */ RCC->APB1ENR |= RCC_APB1ENR_I2C1EN; /* (1) */ RCC->CFGR3 |= RCC_CFGR3_I2C1SW; /* (2) */ /* Configure I2C1, slave */ /* (2) Timing register value is computed with the AN4235 xls file, fast Mode @400kHz with I2CCLK = 48MHz, rise time = 140ns, fall time = 40ns */ /* (3) Periph enable, receive DMA enable */ /* (4) 7-bit address = 0x5A */ /* (5) Enable own address 1 */ I2C1->TIMINGR = (uint32_t)0x00B00000; /* (2) */ I2C1->CR1 = I2C_CR1_PE | I2C_CR1_RXDMAEN | I2C_CR1_ADDRIE; /* (3) */ I2C1->OAR1 |= (uint32_t)(I2C1_OWN_ADDRESS << 1); /* (4) */ I2C1->OAR1 |= I2C_OAR1_OA1EN; /* (5) */ /* Configure IT */ /* (7) Set priority for I2C1_IRQn */ /* (8) Enable I2C1_IRQn */ NVIC_SetPriority(I2C1_IRQn, 0); /* (7) */ NVIC_EnableIRQ(I2C1_IRQn); /* (8) */ } /** * @brief This function : - Enables GPIO clock - Configures the I2C2 pins on GPIO PB10 PB11 * @param None * @retval None */ __INLINE void Configure_GPIO_I2C2(void) { /* Enable the peripheral clock of GPIOB */ RCC->AHBENR |= RCC_AHBENR_GPIOBEN; /* (1) Open drain for I2C signals */ /* (2) AF1 for I2C signals */ /* (3) Select AF mode (10) on PB10 and PB11 */ GPIOB->OTYPER |= GPIO_OTYPER_OT_10 | GPIO_OTYPER_OT_11; /* (1) */ GPIOB->AFR[1] = (GPIOB->AFR[1] &~ (GPIO_AFRH_AFRH2 | GPIO_AFRH_AFRH3)) \ | (1 << (2 * 4)) | (1 << (3 * 4)); /* (2) */ GPIOB->MODER = (GPIOB->MODER & ~(GPIO_MODER_MODER10 | GPIO_MODER_MODER11)) \ | (GPIO_MODER_MODER10_1 | GPIO_MODER_MODER11_1); /* (3) */ } /** * @brief This function configures DMA for I2C2. * @param None * @retval None */ __INLINE void Configure_DMA_I2C2(void) { /* Enable the peripheral clock DMA1 */ RCC->AHBENR |= RCC_AHBENR_DMA1EN; /* DMA1 Channel4 I2C2_TX config */ /* (1) Peripheral address */ /* (2) Memory address */ /* (3) Memory increment */ /* Memory to peripheral */ /* 8-bit transfer */ DMA1_Channel4->CPAR = (uint32_t)&(I2C2->TXDR); /* (1) */ DMA1_Channel4->CMAR = (uint32_t)datatosend; /* (2) */ DMA1_Channel4->CCR |= DMA_CCR_MINC | DMA_CCR_DIR; /* (3) */ } /** * @brief This function configures I2C2, master. * @param None * @retval None */ __INLINE void Configure_I2C2_Master(void) { /* Enable the peripheral clock I2C2 */ RCC->APB1ENR |= RCC_APB1ENR_I2C2EN; /* Configure I2C2, master */ /* (1) Timing register value is computed with the AN4235 xls file, fast Mode @400kHz with I2CCLK = 48MHz, rise time = 140ns, fall time = 40ns */ /* (2) Periph enable */ /* (3) Slave address = 0x5A, write transfer, 2 bytes to transmit, autoend */ I2C2->TIMINGR = (uint32_t)0x00B01A4B; /* (1) */ I2C2->CR1 = I2C_CR1_PE | I2C_CR1_TXDMAEN; /* (2) */ I2C2->CR2 = I2C_CR2_AUTOEND | (SIZE_OF_DATA << 16) | (I2C1_OWN_ADDRESS<<1); /* (3) */ } /** * @brief This function : - Enables GPIO clock - Configures the Push Button GPIO PA0 * @param None * @retval None */ __INLINE void Configure_GPIO_Button(void) { /* Enable the peripheral clock of GPIOA */ RCC->AHBENR |= RCC_AHBENR_GPIOAEN; /* Select mode */ /* Select input mode (00) on PA0 */ GPIOA->MODER = (GPIOA->MODER & ~(GPIO_MODER_MODER0)); } /** * @brief This function configures EXTI. * @param None * @retval None */ __INLINE void Configure_EXTI(void) { /* Configure Syscfg, exti and nvic for pushbutton PA0 */ /* (1) PA0 as source input */ /* (2) unmask port 0 */ /* (3) Rising edge */ /* (4) Set priority */ /* (5) Enable EXTI0_1_IRQn */ SYSCFG->EXTICR[0] = (SYSCFG->EXTICR[0] & ~SYSCFG_EXTICR1_EXTI0) | SYSCFG_EXTICR1_EXTI0_PA; /* (1) */ EXTI->IMR |= EXTI_IMR_MR0; /* (2) */ EXTI->RTSR |= EXTI_RTSR_TR0; /* (3) */ NVIC_SetPriority(EXTI0_1_IRQn, 0); /* (4) */ NVIC_EnableIRQ(EXTI0_1_IRQn); /* (5) */ } /******************************************************************************/ /* Cortex-M0 Processor Exceptions Handlers */ /******************************************************************************/ /** * @brief This function handles NMI exception. * @param None * @retval None */ void NMI_Handler(void) { } /** * @brief This function handles Hard Fault exception. * @param None * @retval None */ void HardFault_Handler(void) { /* Go to infinite loop when Hard Fault exception occurs */ while (1) { } } /** * @brief This function handles SVCall exception. * @param None * @retval None */ void SVC_Handler(void) { } /** * @brief This function handles PendSVC exception. * @param None * @retval None */ void PendSV_Handler(void) { } /** * @brief This function handles SysTick Handler. * @param None * @retval None */ void SysTick_Handler(void) { } /** * @brief This function handles EXTI 0 1 interrupt request. * @param None * @retval None */ void EXTI0_1_IRQHandler(void) { EXTI->PR |= 1; /* start I2C master transmission sequence */ if((I2C2->ISR & I2C_ISR_TXE) == (I2C_ISR_TXE)) /* Check Tx empty */ { // I2C2->TXDR = I2C_BYTE_TO_SEND; /* Byte to send */ //I2C2->CR2 |= I2C_CR2_START; /* Go */ /* start transmission with DMA */ DMA1_Channel4->CCR &=~ DMA_CCR_EN; DMA1_Channel4->CNDTR = SIZE_OF_DATA;/* Data size */ DMA1_Channel4->CCR |= DMA_CCR_EN; I2C2->CR2 |= I2C_CR2_START; /* Go */ } } /** * @brief This function handles I2C1 interrupt request. * @param None * @retval None */ void I2C1_IRQHandler(void) { uint32_t I2C_InterruptStatus = I2C1->ISR; /* Get interrupt status */ if((I2C_InterruptStatus & I2C_ISR_ADDR) == I2C_ISR_ADDR) { I2C1->ICR |= I2C_ICR_ADDRCF; /* Address match event */ } } /** * @brief This function handles DMA1 channel 2 and 3 interrupt request. * @param None * @retval None */ void DMA1_Channel2_3_IRQHandler(void) { if((DMA1->ISR & DMA_ISR_TCIF3) == DMA_ISR_TCIF3) { DMA1->IFCR |= DMA_IFCR_CTCIF3;/* Clear TC flag */ if(datatoreceive[0] == I2C_CMD_TOGGLE_ORANGE) { datatoreceive[0]=0; GPIOC->ODR ^= GPIO_ODR_8; /* Toggle orange LED */ } if(datatoreceive[1] == I2C_CMD_TOGGLE_GREEN) { datatoreceive[1]=0; GPIOC->ODR ^= GPIO_ODR_9; /* toggle green LED */ } DMA1_Channel3->CCR &=~ DMA_CCR_EN; DMA1_Channel3->CNDTR = SIZE_OF_DATA;/* Data size */ DMA1_Channel3->CCR |= DMA_CCR_EN; } else { NVIC_DisableIRQ(DMA1_Channel2_3_IRQn);/* Disable DMA1_Channel2_3_IRQn */ } } /** * @} */ /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/
Реклама:
Donker вне форума  
Непрочитано 13.03.2019, 21:57  
NewWriter
Почётный гражданин KAZUS.RU
 
Аватар для NewWriter
 
Регистрация: 07.09.2014
Сообщений: 2,924
Сказал спасибо: 214
Сказали Спасибо 948 раз(а) в 634 сообщении(ях)
NewWriter на пути к лучшему
По умолчанию Re: Как отправить массив по I2C через DMA на STM32F105 или F030?

Вообще-то, в мануале довольно хорошо по пунктикам разобрана последовательность действий - I2C master mode, а так же при передаче через DMA - Transmission using DMA.
В F1 и F0 модули I2C существенно различаются.
NewWriter вне форума  
Непрочитано 13.03.2019, 22:37  
dgrishin
Вид на жительство
 
Регистрация: 12.02.2013
Сообщений: 414
Сказал спасибо: 8
Сказали Спасибо 83 раз(а) в 79 сообщении(ях)
dgrishin на пути к лучшему
По умолчанию Re: Как отправить массив по I2C через DMA на STM32F105 или F030?

Сообщение от Donker Посмотреть сообщение
Что-то не работает моя переделка снипета от F0 для STM32F105RBT6
В STM32F105RBT6 I2C1_TX висит на 6 канале DMA (у вас настроено для 4)
dgrishin вне форума  
Сказали "Спасибо" dgrishin
mike-y-k (14.03.2019)
Непрочитано 13.03.2019, 23:17  
Donker
Временная регистрация
 
Регистрация: 12.09.2018
Сообщений: 92
Сказал спасибо: 6
Сказали Спасибо 0 раз(а) в 0 сообщении(ях)
Donker на пути к лучшему
По умолчанию Re: Как отправить массив по I2C через DMA на STM32F105 или F030?

Да спасибо, действительно на 6, я уже поправил, но видимо есть какие то ещё ошибки, потому что ничего не изменилось!

По моему, какая то ерунда получается с регистром I2C1->CR2 ?
Donker вне форума  
Непрочитано 14.03.2019, 08:37  
NewWriter
Почётный гражданин KAZUS.RU
 
Аватар для NewWriter
 
Регистрация: 07.09.2014
Сообщений: 2,924
Сказал спасибо: 214
Сказали Спасибо 948 раз(а) в 634 сообщении(ях)
NewWriter на пути к лучшему
По умолчанию Re: Как отправить массив по I2C через DMA на STM32F105 или F030?

Я же говорю - модули в F0 и F1 сильно отличаются. В том числе, и в части CR2. Ну нет в F1 автоэнда. Конец передачи отслеживается вручную подсчетом числа переданных байт, либо по прерыванию завершения DMA-передачи и вручную формируется сигнал stop.
В мануале весь процесс передачи нарисован в картинках и описан буквами.
NewWriter вне форума  
Непрочитано 14.03.2019, 08:51  
dgrishin
Вид на жительство
 
Регистрация: 12.02.2013
Сообщений: 414
Сказал спасибо: 8
Сказали Спасибо 83 раз(а) в 79 сообщении(ях)
dgrishin на пути к лучшему
По умолчанию Re: Как отправить массив по I2C через DMA на STM32F105 или F030?

Для I2C1 надо разрешить DMA для передачи

I2C1->CR2 = I2C_CR2_DMAEN

У вас I2C1->CR1 = I2C_CR1_PE | I2C_CR2_DMAEN

Последний раз редактировалось dgrishin; 14.03.2019 в 08:56.
dgrishin вне форума  
Сказали "Спасибо" dgrishin
mike-y-k (14.03.2019)
Непрочитано 14.03.2019, 13:43  
Donker
Временная регистрация
 
Регистрация: 12.09.2018
Сообщений: 92
Сказал спасибо: 6
Сказали Спасибо 0 раз(а) в 0 сообщении(ях)
Donker на пути к лучшему
По умолчанию Re: Как отправить массив по I2C через DMA на STM32F105 или F030?

Спасибо, раз модуль DMA+I2C в STM32F105 такой не доделаный, без него обойдусь.
Donker вне форума  
Непрочитано 14.03.2019, 16:29  
eddy
Почётный гражданин KAZUS.RU
 
Аватар для eddy
 
Регистрация: 27.01.2005
Адрес: Россия, КЧР, Нижний Архыз
Сообщений: 3,465
Сказал спасибо: 88
Сказали Спасибо 660 раз(а) в 470 сообщении(ях)
eddy на пути к лучшему
По умолчанию Re: Как отправить массив по I2C через DMA на STM32F105 или F030?

Donker, а что там еррата говорит?
ЕМНИП, в 103 вообще не работала связка DMA+I2C!
P.S. Глянул в еррату: нет, наоборот. В 103 не гарантируют нормальную работу I2C без использования DMA!
__________________
https://github.com/eddyem/
http://stackexchange.com/users/2227375/eddy-em
http://eddy-em.livejournal.com/
In the world, only two things are the worst: Windows and Poettering.

Последний раз редактировалось eddy; 14.03.2019 в 17:38.
eddy вне форума  
Непрочитано 14.03.2019, 17:33  
Donker
Временная регистрация
 
Регистрация: 12.09.2018
Сообщений: 92
Сказал спасибо: 6
Сказали Спасибо 0 раз(а) в 0 сообщении(ях)
Donker на пути к лучшему
По умолчанию Re: Как отправить массив по I2C через DMA на STM32F105 или F030?

Тут вроде обещали готовый проект выложить:
http://forum.easyelectronics.ru/view...p?f=35&t=38437
так что если уж получится его приспособить, тогда все вопросы отпадут,
так что пока таймаут.
Donker вне форума  
Непрочитано 14.03.2019, 17:48  
NewWriter
Почётный гражданин KAZUS.RU
 
Аватар для NewWriter
 
Регистрация: 07.09.2014
Сообщений: 2,924
Сказал спасибо: 214
Сказали Спасибо 948 раз(а) в 634 сообщении(ях)
NewWriter на пути к лучшему
По умолчанию Re: Как отправить массив по I2C через DMA на STM32F105 или F030?

Да нормально там всё работает, че вы гоните то. Я же написал - в прерывании по окончании передачи DMA вы должны будете вручную сгенерировать состояние stop. Всё там нормально.
В F0 тоже, если передаете больше 255 байт, вам надо вручную следить, сколько раз перезагружается счетчик байтов и следить, чтобы все было четко по количеству байт.
Да, это вам не SPI или UART кагбе. Так что не нойте.
NewWriter вне форума  
 

Закладки
Опции темы

Ваши права в разделе
Вы не можете создавать новые темы
Вы не можете отвечать в темах
Вы не можете прикреплять вложения
Вы не можете редактировать свои сообщения

BB коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.

Быстрый переход

Похожие темы
Тема Автор Раздел Ответов Последнее сообщение
Кто-нибудь работал с RF модулями nRF2401A? Easyrider83 Автоматика и аппаратура связи 1451 09.01.2019 18:33
STM32 - Tips 'N Tricks nahimovv ARM 8 08.08.2016 14:35
Не работает SPI через DMA eddy ARM 13 20.01.2014 18:27


Часовой пояс GMT +4, время: 16:19.


Powered by vBulletin® Version 3.8.4
Copyright ©2000 - 2019, Jelsoft Enterprises Ltd. Перевод: zCarot