Программирование 32-х разрядных МК

ssss
Offline
Зарегистрирован: 01.07.2016

diger67 пишет:

К примеру создается ТЗ, пишутся програмные модули, проверяются по отдельности. Ура все работает. Следующий шаг, собираем модули(библиотеки) воедино и получаем результат не отвечающий поставленной задаче. Возвращаемся к нулевому циклу(выбор железа), находим подходящее по спецификации поставленых задачь, процесс изучения начинается заново. Почему, да потому что это у AVR перифирия почти неизменна и достаточно проста для изучения. У ARM независимо от производителя все гараздо сложнее. Возьмем к примеру LTDC, QSPI, привязка новых устройств к файловой системе, оптимизация алгоритмов вывода изображений наTFT.

И как вы думаете, у многих ли здесь есть опыт общения с Ф446 или Ф7 ?

a5021
Offline
Зарегистрирован: 07.07.2013

Ему пофиг. Главное, чтобы все говорили о том, что интересно конкретно ему.

diger67
Offline
Зарегистрирован: 25.07.2015

Думаю что здесь не многие имеют опыт работы, я с F7 тоже буду общаться впервые когда он приедет. a5021, название темы почитайте и вам все будет ясно, она и создана чтобы спрашивать или делится идеями по програмированию. По поводу CD или flash работающей по QSPI. Мне ненужно таскать содержимое с устройства на устройство, там будет хранится определенная информация, как ОС в планшете, спрайты как Nextion, шрифты для разных языков и т д.

a5021
Offline
Зарегистрирован: 07.07.2013

diger67 пишет:
a5021, название темы почитайте и вам все будет ясно, она и создана чтобы спрашивать или делится идеями по програмированию.

И что ж вы не делитесь? Вы то меня задалбывали бредом, что у F030 нет ни одного таймера наружу, то капризничали, что я не должен "пересказывать то что давно опиано на просторах тырнета" (чего вы никогда не видели и не могли видеть), наконец, мечтательно рассказывали о том, как это хорошо и здорово, иметь старший камень в линейке и для убедительности сыпали разнообразными аббревиатурами. И где тут "название темы" ?

Хрена ли вы мне постоянно какие-то упреки выставляете, придумывая небылицы для убедительности, если сами занимаетесь полнейшей херней и бессвязными рассуждениями ни о чем?

diger67
Offline
Зарегистрирован: 25.07.2015

Да пока делиться особо не чем. Все что я знаю можно узнать набрав в google запрос. Пока идет платка с F7 изучаю HAL, т.к. работать сним в CMSIS уверен геморой еще тот, конкретно разбираюсь с QSPI и хочу его скрестить с фаловой системой чтобы потом сделать загркзку в 25Q128 через USB бинарников.

a5021
Offline
Зарегистрирован: 07.07.2013

А зачем вам вообще F7, если вы все время вспоминаете экран и файловую систему? Для этого существуют SoC с линуксом или андроидом на борту. Там все это и много чего еще есть искаропки, чтобы не изобретать велосипедов.

diger67
Offline
Зарегистрирован: 25.07.2015

a5021 пишет:

А зачем вам вообще F7, если вы все время вспоминаете экран и файловую систему? Для этого существуют SoC с линуксом или андроидом на борту. Там все это и много чего еще есть искаропки, чтобы не изобретать велосипедов.

Не все так чудесно, есть у меня raspberi pi2. Можно и на нем собрать проект, получится раза в два дороже.. Прототип собран на A10, там WinXP. И в конечном итоге его цена выростает до 500000 у производителя. Все повторено на mega2560, вот только вывод графики тормозной, не хватает производительности у него на все задачи.

a5021
Offline
Зарегистрирован: 07.07.2013

Очень похоже на пургу. Проект, который работает на меге, но требует F7, где последний оказывается в два раза дешевле распбери 2 и все это за пол-мульта у производителя. Ага.

Arhat109-2
Offline
Зарегистрирован: 24.09.2015

digger67, писал: "Все повторено на mega2560, вот только вывод графики тормозной, не хватает производительности у него на все задачи".

Блин .. Вы же вроде как сами писали выше что "камень надо выбирать под задачу", а сами во что упираетесь? Ну нет среди задач "мег" и 2560 - не исключение, задач "вывода графики". Ну и остальные предложения как-то не очень "стыкуются" по смыслу, соглашусь...

diger67
Offline
Зарегистрирован: 25.07.2015

Не согласуется, потому что у вас напрочь отсутствует логическое мышление. По пунктам, увидел устройство, захотел создать что то подобное, попробовал на mega2560. Чем больше модулей подключалось, тем больше убеждался что камень не справляется. Взял f103, переложил проект на него, неустроило. Попробовал F429, снова не достиг желаемого результата. Решил попробовать F746, тем более там уже стоит 16Мбайт SDRAM. И все это за 1800 р.

a5021
Offline
Зарегистрирован: 07.07.2013

А что это за удивительный проект?

Yarik.Yar
Offline
Зарегистрирован: 07.09.2014

Сегодня разобрался с I2C у STM32F030 CMSIS-онли без HALа. Большой шаг для меня, маленький шаг для всего человечества.

Написал функции записи/чтения и всего такого через UART (отчасти использовал консоль отсюда).

Причешу код - выложу.

Ах да, ещё я перешёл на 5 Keil, и он мне определённо нравится!)

a5021
Offline
Зарегистрирован: 07.07.2013

I2C у F030 весьма простой. Вот вся инициализация:

void initI2C(void)  {
  
  RCC->APB1ENR |= RCC_APB1ENR_I2C1EN;         // I2C1 clock enable
 
  I2C1->CR2 = (            // I2C Control register 2
    0 * I2C_CR2_SADD        |   // Slave address (master mode)
    0 * I2C_CR2_RD_WRN      |   // Transfer direction (master mode)
    0 * I2C_CR2_ADD10       |   // 10-bit addressing mode (master mode)
    0 * I2C_CR2_HEAD10R     |   // 10-bit address header only read direction (master mode)
    0 * I2C_CR2_START       |   // START generation
    0 * I2C_CR2_STOP        |   // STOP generation (master mode)
    0 * I2C_CR2_NACK        |   // NACK generation (slave mode)
    0 * I2C_CR2_NBYTES      |   // Number of bytes
    0 * I2C_CR2_RELOAD      |   // NBYTES reload mode
    0 * I2C_CR2_AUTOEND     |   // Automatic end mode (master mode)
    0 * I2C_CR2_PECBYTE         // Packet error checking byte
  );
    
  I2C1->OAR1 = (           // I2C Own address 1 register
      0 * I2C_OAR1_OA1      |   // Interface own address 1
      0 * I2C_OAR1_OA1MODE  |   // Own address 1 10-bit mode
      0 * I2C_OAR1_OA1EN        // Own address 1 enable
  );
    
  I2C1->OAR2 = (           // I2C Own address 2 register
      0 * I2C_OAR2_OA2      |   // Interface own address
      0 * I2C_OAR2_OA2MSK   |   // Own address 2 masks
      0 * I2C_OAR2_OA2EN        // Own address 2 enable
  );

  I2C1->TIMINGR = (uint32_t)0x0010020A;  // 400kHz at 8mHz main clock

  //I2C1->TIMINGR = (uint32_t)0x0010020A;
  //I2C1->TIMINGR = (uint32_t)0x00310309;
  //I2C1->TIMINGR = (uint32_t)0x00B01A4B;  // I2C Timing register
  //I2C1->TIMEOUTR  = 0;     // I2C Timeout register -- valid only in SMB mode
  //I2C1->ISR                // I2C Interrupt and status register
  //I2C1->ICR                // I2C Interrupt clear register
  //I2C1->PECR               // I2C PEC register
  //I2C1->RXDR               // I2C Receive data register
  //I2C1->TXDR               // I2C Transmit data register
  
  I2C1->CR1 = (            // I2C Control register 1
    1 * I2C_CR1_PE          |   // Peripheral enable
    1 * I2C_CR1_TXIE        |   // TX interrupt enable
    1 * I2C_CR1_RXIE        |   // RX interrupt enable
    0 * I2C_CR1_ADDRIE      |   // Address match interrupt enable
    0 * I2C_CR1_NACKIE      |   // NACK received interrupt enable
    1 * I2C_CR1_STOPIE      |   // STOP detection interrupt enable
    0 * I2C_CR1_TCIE        |   // Transfer complete interrupt enable
    1 * I2C_CR1_ERRIE       |   // Errors interrupt enable
    0 * I2C_CR1_DFN         |   // Digital noise filter
    0 * I2C_CR1_ANFOFF      |   // Analog noise filter OFF
    0 * I2C_CR1_SWRST       |   // Software reset
    0 * I2C_CR1_TXDMAEN     |   // DMA transmission requests enable
    0 * I2C_CR1_RXDMAEN     |   // DMA reception requests enable
    0 * I2C_CR1_SBC         |   // Slave byte control
    0 * I2C_CR1_NOSTRETCH   |   // Clock stretching disable
    0 * I2C_CR1_WUPEN       |   // Wakeup from STOP enable
    0 * I2C_CR1_GCEN        |   // General call enable
    0 * I2C_CR1_SMBHEN      |   // SMBus host address enable
    0 * I2C_CR1_SMBDEN      |   // SMBus device default address enable
    0 * I2C_CR1_ALERTEN     |   // SMBus alert enable
    0 * I2C_CR1_PECEN           // PEC enable
  );
}

Просто ставим единицы и нули, что включить, что выключить. Единственная заковыка, регистр

I2C1->TIMINGR

Его значение для разных частот самого камня и интерфейса I2C нужно вычислять специально. Где-то на сайте ST был даже экселевский макрос для этого рассчета.

Yarik.Yar
Offline
Зарегистрирован: 07.09.2014

Инициализация-то простая, я больше мучался с передачей и приёмом. Сниппеты не очень информативны на этот счёт.
Вообще, первый раз работал с IIC. День прошёл не зря, теперь в моём внутреннем резюме стоит "работал со всеми интерфейсами STM32F030".
Завтра попробую помучить гироскоп FXAS21002, тоже IIC, и лежат 4 нераспаянных SI7021, ждут своего подключения...

diger67
Offline
Зарегистрирован: 25.07.2015

Yarik.Yar пишет:

Сегодня разобрался с I2C у STM32F030 CMSIS-онли без HALа. Большой шаг для меня, маленький шаг для всего человечества.

Поздравляю это радует. Если интересно вот пример f103rb на SPL работа DMA mem-to-mem в CooCox:

#include "main.h"
//---------------------------------------------------------------------
void  DMA1_Channel1_IRQHandler(void)
{
 if(DMA_GetITStatus(DMA1_IT_TC1) == SET)
 {
  DMA_ClearITPendingBit(DMA1_IT_TC1);
 }
}

//---------------------------------------------------------------------
int main(void)
{
 DMA_ini();
 for(count_buf = 0; count_buf < 200; count_buf++)
       {
        temp = temp + 1;
        DATA_Tx[count_buf] = temp;
       }

    while(1)
    {
     DMA_Cmd(DMA1_Channel1, ENABLE);
     while(DMA_GetCurrDataCounter(DMA1_Channel1) !=0);
     while(1){}
    }
}
//-----------------------------------------------------------------------
void DMA_ini(void)
{
 DMA_InitTypeDef DMA_init_m2m;

 RCC_AHBPeriphClockCmd(RCC_AHBPeriph_DMA1, ENABLE);

 DMA_init_m2m.DMA_PeripheralBaseAddr = (uint32_t) DATA_Tx;
 DMA_init_m2m.DMA_MemoryBaseAddr = (uint32_t) DATA_Rx;
 DMA_init_m2m.DMA_DIR = DMA_DIR_PeripheralSRC;
 DMA_init_m2m.DMA_BufferSize = BufSize;
 DMA_init_m2m.DMA_PeripheralInc = DMA_PeripheralInc_Enable;
 DMA_init_m2m.DMA_MemoryInc = DMA_MemoryInc_Enable;;
 DMA_init_m2m.DMA_PeripheralDataSize = DMA_PeripheralDataSize_Word;
 DMA_init_m2m.DMA_MemoryDataSize = DMA_MemoryDataSize_Word;
 DMA_init_m2m.DMA_Mode = DMA_Mode_Normal;
 DMA_init_m2m.DMA_Priority = DMA_Priority_Medium;
 DMA_init_m2m.DMA_M2M = DMA_M2M_Enable;
 DMA_Init(DMA1_Channel1, &DMA_init_m2m);

 NVIC_EnableIRQ(DMA1_Channel1_IRQn);
 DMA_ITConfig(DMA1_Channel1, DMA_IT_TC, ENABLE);
}
#ifndef MAIN_H
#define MAIN_H

#include "stm32f10x.h"
#include "stm32f10x_gpio.h"
#include "stm32f10x_rcc.h"
#include "stm32f10x_dma.h"

void DMA_ini(void);

#define BufSize 800

__IO uint16_t count_buf = 0;
uint32_t DATA_Rx[BufSize] = {0};
uint32_t DATA_Tx[BufSize] = {0};
uint16_t temp = 0;

#endif

Вот еще пример для f303 ADC:

#include "stm32f30x.h"
#include "stm32f30x_adc.h"
#include "stm32f30x_gpio.h"
#include "stm32f30x_rcc.h"

uint32_t delay_count = 0;
uint32_t delay_temp = 0;

uint16_t Data_ADC;

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

void SysTick_Handler(void)
{
 if(delay_count > 0)
  delay_count--;
}

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

void ADC1_2_IRQHandler(void)
{
 if(ADC_GetITStatus(ADC1, ADC_IT_EOC) == SET)
 {
  ADC_ClearITPendingBit(ADC1, ADC_IT_EOC);
 }
 Data_ADC = ADC_GetConversionValue(ADC1);
}

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

void delay_ms(uint16_t delay_temp)
{
 delay_count = delay_temp;
 while(delay_count){}
}

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

get_adc_value()
{
 uint16_t  data_adc;
 ADC_StartConversion(ADC1);
 while(ADC_GetFlagStatus(ADC1, ADC_FLAG_EOC) == RESET);
 ADC_StopConversion(ADC1);
 return ADC_GetConversionValue(ADC1);
}

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

int main(void)
{
 SysTick_Config(SystemCoreClock/1000); //1ms

 ADC_CommonInitTypeDef ADC_comminit;
 ADC_InitTypeDef ADC_ini_dif;
 GPIO_InitTypeDef GPIO_ini_user;

 RCC_ADCCLKConfig(RCC_ADC12PLLCLK_Div2);

 RCC_AHBPeriphClockCmd(RCC_AHBPeriph_GPIOA | RCC_AHBPeriph_GPIOC, ENABLE);

 GPIO_ini_user.GPIO_Pin = GPIO_Pin_3 | GPIO_Pin_4;
 GPIO_ini_user.GPIO_Mode = GPIO_Mode_AN;
 GPIO_ini_user.GPIO_Speed = GPIO_Speed_Level_3;
 GPIO_ini_user.GPIO_OType = GPIO_OType_PP;
 GPIO_ini_user.GPIO_PuPd = GPIO_PuPd_NOPULL;

 GPIO_Init(GPIOA, &GPIO_ini_user);

 GPIO_ini_user.GPIO_Pin = GPIO_Pin_1;
 GPIO_ini_user.GPIO_Mode = GPIO_Mode_OUT;
 GPIO_ini_user.GPIO_Speed = GPIO_Speed_Level_3;
 GPIO_ini_user.GPIO_OType = GPIO_OType_PP;
 GPIO_ini_user.GPIO_PuPd = GPIO_PuPd_NOPULL;

 GPIO_Init(GPIOA, &GPIO_ini_user);

 RCC_AHBPeriphClockCmd(RCC_AHBPeriph_ADC12, ENABLE);

 ADC_comminit.ADC_Mode = ADC_Mode_Independent;
 ADC_comminit.ADC_Clock = ADC_Clock_SynClkModeDiv1; //ADC_Clock_AsynClkMode;
 ADC_comminit.ADC_DMAAccessMode = ADC_DMAAccessMode_Disabled;
 ADC_comminit.ADC_DMAMode = ADC_DMAMode_OneShot;
 ADC_comminit.ADC_TwoSamplingDelay = 0;
 ADC_Init(ADC1, &ADC_comminit);

 ADC_ini_dif.ADC_ContinuousConvMode = ADC_ContinuousConvMode_Disable;
 ADC_ini_dif.ADC_Resolution = ADC_Resolution_12b;
 ADC_ini_dif.ADC_ExternalTrigConvEvent = ADC_ExternalTrigConvEvent_0;
 ADC_ini_dif.ADC_ExternalTrigEventEdge = ADC_ExternalTrigEventEdge_None;
 ADC_ini_dif.ADC_DataAlign = ADC_DataAlign_Right;
 ADC_ini_dif.ADC_OverrunMode = ADC_OverrunMode_Disable;
 ADC_ini_dif.ADC_AutoInjMode = ADC_AutoInjec_Disable;
 ADC_ini_dif.ADC_NbrOfRegChannel = 1;
 ADC_Init(ADC1, &ADC_ini_dif);

 ADC_RegularChannelConfig(ADC1, ADC_Channel_3, 1, ADC_SampleTime_7Cycles5);
 ADC_SelectDifferentialMode(ADC1, ADC_Channel_3, ENABLE);

 ADC_VoltageRegulatorCmd(ADC1, ENABLE);
 delay_ms(1);
 ADC_SelectCalibrationMode(ADC1, ADC_CalibrationMode_Differential);
 ADC_StartCalibration(ADC1);
 while (ADC_GetCalibrationStatus(ADC1));

 NVIC_EnableIRQ(ADC1_2_IRQn);
 ADC_ITConfig(ADC1, ADC_IT_EOC, ENABLE);
 ADC_Cmd(ADC1, ENABLE);

 //ADC_ResetCalibration(ADC1);
 //while (ADC_GetResetCalibrationStatus(ADC1));


 uint32_t i;
    while(1)
    {
     //Data_ADC = get_adc_value();
     ADC_StartConversion(ADC1);
     GPIOA->ODR ^= GPIO_Pin_1;
     delay_ms(500);
    }
}

 

a5021
Offline
Зарегистрирован: 07.07.2013

Кому он нужен этот SPL нынче?

Yarik.Yar пишет:
Инициализация-то простая, я больше мучался с передачей и приёмом.

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

#define I2C_START_WRITING(ADDR, COUNT, VALUE) \
          I2C1->TXDR = VALUE; \
          I2C1->CR2 = (       \
            I2C_CR2_AUTOEND | \
            ((COUNT) << 16) | \
            ((ADDR) << 1)   | \
            I2C_CR2_START     \
          )

#define I2C_START_READING(ADDR, COUNT) \
          I2C1->CR2 = (       \
            I2C_CR2_AUTOEND | \
            ((COUNT) << 16) | \
            I2C_CR2_RD_WRN  | \
            ((ADDR) << 1)   | \
            I2C_CR2_START     \
          )

#define I2C_WAIT_FOR_STOP_FLAG() \
          while((I2C1->ISR & I2C_ISR_STOPF) != I2C_ISR_STOPF);\
          I2C1->ICR = I2C_ICR_STOPCF
            
#define I2C_WAIT_FOR_RX_FLAG() \
          while((I2C1->ISR & I2C_ISR_RXNE) != I2C_ISR_RXNE)

#define I2C_WAIT_FOR_TX_FLAG() \
          while((I2C1->ISR & I2C_ISR_TXE) != I2C_ISR_TXE)

 

Теперь описать любой ввод/вывод по I2C можно просто комбинируя вышеприведенные макросы. Вот так, например, может быть составлена функция чтения калибровочных данных датчика BMP180:

uint8_t static bmp180_prom[BMP180_PROM_DATA_LEN];

...

void bmp180_readPROM(void) {
  uint8_t *buf = (uint8_t *)(bmp180_prom + 1);

  I2C_START_WRITING(BMP180_I2C_ADDRESS, 1, BMP180_PROM_START_ADDR);
  I2C_WAIT_FOR_STOP_FLAG();
  
  I2C_START_READING(BMP180_I2C_ADDRESS, BMP180_PROM_DATA_LEN);
  for (uint8_t i = 0; i < BMP180_PROM_DATA_LEN / 2; i++) {
    I2C_WAIT_FOR_RX_FLAG();
    *buf = I2C1->RXDR;
    I2C_WAIT_FOR_RX_FLAG();
    *--buf = I2C1->RXDR;
    buf += 3;
  }
  
  I2C_WAIT_FOR_STOP_FLAG();
}

 

diger67
Offline
Зарегистрирован: 25.07.2015

Ну да, для f4XX уже наверное HAL лучше юзать. А для f7XX альтернативы просто нет. Использовать CMSIS наверное для некоторой периферии будет проблематично. Что касается I2C проблем при работе со всякого рода датчиками нет, а вот с flash памятью на младших линейках есть косяки. Ну и есть недостаток в использоваии CMSIS, частенько одни и теже регистры в разных линейках имеют разные дефайны, что приводит к ошибкам при переносе с одной линейки на другую. А поиск ошибки занимает времени больше чем написание программы заново.

a5021
Offline
Зарегистрирован: 07.07.2013

diger67 пишет:
Ну да, для f4XX уже наверное HAL лучше юзать. А для f7XX альтернативы просто нет.

Свежачок с my.st.com, как раз из темы про F7: "Please make SPL for all new MCU, because HAL is killing us."

Если SPL можно назвать просто уродством, то для характеристики HAL-а такого эпитета будет уже недостаточно. Дерзайте. Изучайте HAL, как изучали SPL в свое время. Глядишь, через годик-другой, ST похоронит HAL и выкатит еще какой-нибудь отстой. Ну, чтобы потребители не скучали.

Цитата:
Использовать CMSIS наверное для некоторой периферии будет проблематично.

Чевойта вдруг? Регистры оживут и начнут разбегаться в разные стороны?

Цитата:
Что касается I2C проблем при работе со всякого рода датчиками нет, а вот с flash памятью на младших линейках есть косяки.

Боюсь даже спрашивать. В прошлый раз подобное любопытство обошлось мне в три дня объяснений, как из F4P6 достать наружу таймеры. Что, теперь флеш отказывается выходить?

Цитата:
Ну и есть недостаток в использоваии CMSIS, частенько одни и теже регистры в разных линейках имеют разные дефайны, что приводит к ошибкам при переносе с одной линейки на другую. А поиск ошибки занимает времени больше чем написание программы заново.

Я спокойно таскаю взад-вперед собственный код между F030, STM8S и ATMEGA8, а вы мне тут леденящие душу истории про внутривидовое портирование рассказываете.

diger67
Offline
Зарегистрирован: 25.07.2015

Я уже говорил, вы слушаете только себя. Но возвращаться к этому вопросу, просто не уважать себя и тратить время на человека который по всей видимости работал с камнями от stm за три копейки с периферией как у mega8. Может я и не прав, только ваши посты говорят об этом. Вы все время пытаетесь изобрести велосипед. Что касается разного рода библиотек, то я обычно вношу правки в стандартные библиотеки, если это оправдано и приводит к оптимизации.

a5021
Offline
Зарегистрирован: 07.07.2013

diger67 пишет:
Я уже говорил, вы слушаете только себя.

Вообще-то я ваши слова комментировал. Не находите, что это сделать было бы весьма затруднительно, если бы я слушал только себя? Ваше вступление: "Я уже говорил...", так и вовсе наводит на грусные мысли, если вспомнить чего вы вообще здесь успели наговорить.

Цитата:
Но возвращаться к этому вопросу, просто не уважать себя и тратить время на человека который по всей видимости работал с камнями от stm за три копейки с периферией как у mega8.

Как странно. Вы только что тратили свое время, отвечая Yarik.Yar по поводу "камня от stm за три копейки с периферией как у mega8". Не уважали себя, выходит? Даже какие-то собственные коды, ручной работы, приводили. Правда, они как-то подозрительно похожи на примеры из SPL пятилетней давности, да и совсем для других МК, но это не первый случай, когда вы промахиваетесь с темой, т.ч. наверное не стоит на это обращать внимание и придираться лишний раз.

Цитата:
Вы все время пытаетесь изобрести велосипед.

Ну раз вы не хотите изобретать здесь космический корабль, я, чтобы тема не завяла, велосипедами пробавляюсь. Что ж тут плохого? Вы постоянно надрываетесь здесь в претензиях, что я делаю это не так, то не эдак, но сами не делаете вообще ничего. Ну и хрен здесь тухлый бубнеж устраивать? Либо ведите тему за собой, либо помалкивайте, когда это делают другие.

Нет, чтобы захреначить что-нибудь такое, отчего бы все рты поразевали, вы какими-то полуистлевшими SPL-примерами трясете, да еще и в ответ на сообщение о использовании подхода "CMSIS-онли". Вот это называется "слушать только себя". Он вам про CMSIS, а вы ему: "вот тебе мои SPL-примеры".

Цитата:
Что касается разного рода библиотек, то я обычно вношу правки в стандартные библиотеки, если это оправдано и приводит к оптимизации.

У меня волосы встают дыбом, как представлю, чего вы можете туда навносить.

ssss
Offline
Зарегистрирован: 01.07.2016

Незнайка a5021 опять жидко обосрался с головы до ног. )))))))))))))))))

"Твоя" форма инита горячо обсуждалась лет несколько назад на элхе. Как вариант, не более. Мне, например, такая форма не нравится. Не нравится своим заведомым излишеством.

И HAL, при жирных камнях и неторопливых задачах периферии, имеет право на жизнь, как бы там что не говорили. Это типа ардуины для СТМ, но не ардуина во всех её скверных проявлениях. И чё ты докопался до diger67, что ты знаешь о его задаче? А ничего! Если у него в приоритете только вывод на ТФТ, а всё остальное со скоростью черепахи, то HAL вполне может прокатить. Небольшое снижение производительности и разрастание размера кода для жирного МК не особо существенно. Тем более что он заявил, что не боится править либы, даже стандартные. Т.е. всё вполне логично - запускает "как есть", потом допиливает узкие места до нужной кондиции. С учётом освоения новой периферии ещё и неизвестно что по времени будет лучше, а при наличии большого количества либ верхнего уровня применение HAL может быть и оправданым в его случае. 

ssss
Offline
Зарегистрирован: 01.07.2016

diger67 пишет:

увидел устройство, захотел создать что то подобное, попробовал на mega2560. Чем больше модулей подключалось, тем больше убеждался что камень не справляется. Взял f103, переложил проект на него, неустроило. Попробовал F429, снова не достиг желаемого результата. Решил попробовать F746, тем более там уже стоит 16Мбайт SDRAM. И все это за 1800 р.

А узкие места не пробовали выделять? Задачу переосмыслить, не?

ssss
Offline
Зарегистрирован: 01.07.2016

diger67 пишет:

Ну и есть недостаток в использоваии CMSIS, частенько одни и теже регистры в разных линейках имеют разные дефайны, что приводит к ошибкам при переносе с одной линейки на другую. А поиск ошибки занимает времени больше чем написание программы заново.

Надумано. HAL тоже изобилует подобными ошибками. Следить за периферией задача кодера.

diger67
Offline
Зарегистрирован: 25.07.2015

Замечания справедливые, вот только если скорость вывода ниже необходимой, единственный способ это использование чипа с более высокой тактовой частотой. И ни какая оптимизация здесь не поможет, тем более что оптимизировать дальше не куда, кроме как оставить тело main и вложенный в него while() пустыми. Что касается SPL и HAL. Думаю совершенно ошибочно сравнивать их с ардуино. Опять же осуждать людей юзающих исключительно CMSIS, ну не дано им. Им только кажется что они досканально знают все изнутри. А по сути используют понятные только им макросы и определения, и их каляки моляки также требуют глубокого изучения. Это как Linux, сколько ламеров, столько сборок, которые корректно работают только на одной отдельно взятой задаче.  

ssss
Offline
Зарегистрирован: 01.07.2016

diger67 пишет:

Замечания справедливые, вот только если скорость вывода ниже необходимой, единственный способ это использование чипа с более высокой тактовой частотой. И ни какая оптимизация здесь не поможет, тем более что оптимизировать дальше не куда, кроме как оставить тело main и вложенный в него while() пустыми.

Всё относительно. Если у вас при работе с ТФТ всё упирается в обработку данных, то да, более мощный камень неизбежен. А если всё упирается в ограничения периферии - либо другой камень, либо оптимизация вывода. Но тогда уже всё упирается в ваши знания и понимание работы периферии камня.

Цитата:

Что касается SPL и HAL. Думаю совершенно ошибочно сравнивать их с ардуино.

Почему? SPL и HAL тоже типа "не надо думать", как и ардуина. Т.е. силикон для мозгов, размер становится больше, а толку с этого аж никакого.

Цитата:

Опять же осуждать людей юзающих исключительно CMSIS, ну не дано им. Им только кажется что они досканально знают все изнутри. А по сути используют понятные только им макросы и определения, и их каляки моляки также требуют глубокого изучения.

Не дано им что? Это вам не дано знать то, что знают они. Может поэтому вы всё время переходите на более быстрый камень?

Цитата:

Это как Linux, сколько ламеров, столько сборок, которые корректно работают только на одной отдельно взятой задаче.  

И тем не менее, линух в некоторых приложениях более предпочтителен.

a5021
Offline
Зарегистрирован: 07.07.2013

ssss пишет:
Незнайка a5021 опять жидко обосрался с головы до ног. "Твоя" форма инита горячо обсуждалась лет несколько назад на элхе. Как вариант, не более.

Вы так убедительны, когда рассказываете о чем-то в этом своем припадке женской логики. Непонятно одно -- как вы вообще что-то ухитряетесь программировать с таким-то талантами?

Цитата:
И чё ты докопался до diger67, что ты знаешь о его задаче? А ничего!

Не только я. Похоже, что и он сам о ней ничего не знает.

Цитата:
Тем более что он заявил, что не боится править либы, даже стандартные.

Править стандартные либы -- занятие исключительно для высокоодаренных. Выйдет новая версия, потребуется по новой править и когда это случится, придется вспоминать все подробности прошлой правки. Для настоящих энтузиастов спортивного граблехождения, уникальная возможность заняться любимым делом с максимальной интенсивностью.

Цитата:
а при наличии большого количества либ верхнего уровня применение HAL может быть и оправданым в его случае.

Лучше бы вы лицом в навоз упали, чем такую херню нести.

ssss
Offline
Зарегистрирован: 01.07.2016

a5021 пишет:

Не только я. Похоже, что и он сам о ней ничего не знает.

Да, что-то не так, в королевстве датском. )))))))))

Цитата:

Править стандартные либы -- занятие исключительно для высокоодаренных. Выйдет новая версия, потребуется по новой править и когда это случится, придется вспоминать все подробности прошлой правки. Для настоящих энтузиастов спортивного граблехождения, уникальная возможность заняться любимым делом с максимальной интенсивностью.

Если с этого есть толк, то почему бы и нет? Как там, "Разрешено всё, что не запрещено."(с).

Цитата:

Лучше бы вы лицом в навоз упали, чем такую херню нести.

Не, ваше место мне ни к чему! ))))))))))))))))))

Если ему нужен результат при отсутствии знаний? Какой у него ещё есть выход?

a5021
Offline
Зарегистрирован: 07.07.2013

ssss пишет:
Если ему нужен результат при отсутствии знаний? Какой у него ещё есть выход?

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

Файлово-экранные дела лучше на SoC-е делать, впрочем, об этом уже говорили.

diger67
Offline
Зарегистрирован: 25.07.2015

ssss, RM для меня почти настольная книга, библиотеки на периферию от первой до последней строки просматриваются, чего вряд ли делают адепты CMSIS. По этой причине они пыжаться и пишут макросы которые работают в два раза медленнее чем немног правленная родная библа на C. Ну не идиотизм полностью гулять по регистру когда надо сменить пару бит. Вот и получается что только при инициализации периферии они теряют до 200 - 300 тактов. А все почему, да потому что не понимают как она работает, прочитали гдето, что CMSIS это библия для STM. А все остальное от лукавого. Профессиональный програмер умеет гибко использовать все доступные инструменты. Был у меня в практике опыт, использовал раннюю версию SPL для F4, начал изучать SRAM, косяк за косяком. Заставил работать, а потом оказалось надо было просто обновить библиотеку. Но фак остается факто, кто умеет заставить работать то что работать не должно имеет высшую цену. 

a5021, нищеброды впихивающие свой тощий моск в рамки гениальности - это круть, завидую вашему апломбу!!!!!

ssss
Offline
Зарегистрирован: 01.07.2016

diger67 пишет:

ssss, RM для меня почти настольная книга,

Может "Не в коня корм."(с)?

Цитата:

библиотеки на периферию от первой до последней строки просматриваются, чего вряд ли делают адепты CMSIS.

А зачем им это делать, если они пишут свои, более лаконичные и более быстрые, да ещё и под задачу?

Цитата:

По этой причине они пыжаться и пишут макросы которые работают в два раза медленнее чем немног правленная родная библа на C. Ну не идиотизм полностью гулять по регистру когда надо сменить пару бит.

Вы о чём сейчас? Вы точно ничего не путаете?

Цитата:

Вот и получается что только при инициализации периферии они теряют до 200 - 300 тактов. А все почему, да потому что не понимают как она работает,

Как кто работает? СПЛ или ХАЛ? Они не работают, они создают видимость работы. Вы не наблюдаете там кучу левых телодвижений?

Цитата:

прочитали гдето, что CMSIS это библия для STM. А все остальное от лукавого.

СПЛ и ХАЛ написаны на основе CMSIS. А докажите обратное! Что CMSIS написан на основе СПЛ и ХАЛ!?

Цитата:

Профессиональный програмер умеет гибко использовать все доступные инструменты. Был у меня в практике опыт, использовал раннюю версию SPL для F4, начал изучать SRAM, косяк за косяком. Заставил работать, а потом оказалось надо было просто обновить библиотеку. Но фак остается факто, кто умеет заставить работать то что работать не должно имеет высшую цену. 

Не совсем понял мысль. Но не суть! Вы профессиональный програмер? Тогда зацените спор на котах.

Цитата:

Ещё вопрос по N1616. Кто использовал его совместно с STM32F10x и SPI+DMA? Как в этом случае корректно передавать 9 бит через 16 без дезактивации через nCS?

Цитата:

У данного чипа нет возможности аппаратно передавать 9 бит по SPI линии. Только программная реализация.

Цитата:

Вроде уже делали и всё работало на максимальной скорости и на аппаратном SPI без дёргания CS. Перекодировку на лету ещё никто не отменял.

И кто из них прав? И можно ли передать 9 бит данные через SPI STM32F10x, ваше мнение, как профи?

diger67
Offline
Зарегистрирован: 25.07.2015

Дефайны на проц не есть библиотека. Да, те кто пишет свои библиотеки претендуют на совершенство, но писал ранее вся их работа сизифов труд.  Утверждение на оптимальность вводят пользователей в заблуждение. Все что пишут адепты CMSIS заточено под их узкую задачу, шаг влево шаг в право, зависание программы или полный лок камня. Знать CMSIS обязательно. Использование оного в чистом виде не гарантирует оптимальный вариант.

Что касается последнего вопроса, тут все без проблем. Я вижу решение в обычном сдвиге данных в регистре. Сейчас могу ошибится, но если старшим битом вперед, то сдвигаем 9 бит данных вверх, потом посылка и по CS high получаем то что нужно. Если знать алгоритм работы протокола то все становится ясно, а как решить задачу, это пристрастие програмера.

a5021
Offline
Зарегистрирован: 07.07.2013

ssss пишет:
Вы о чём сейчас? Вы точно ничего не путаете?

Гы. Представляю, какой бы вы закатили ор, скажи я такое. А тут, ну просто торжество дипломатии. Да-с, клевого вы себе единомышленничка подобрали.

Цитата:
Цитата:

Вот и получается что только при инициализации периферии они теряют до 200 - 300 тактов. А все почему, да потому что не понимают как она работает,

Как кто работает?

Дет Пихто. Маститытый программист-профессионал, в побитовой разблюдовке единичных присвоений, узрел множество отдельных операций. Примерно так 200-300, с его слов. Рентген, мать ети. Пожалуй, это еще более громкий и торжественный аккорд профессионализма, чем даже в случае с таймерами.

Сделаете вид, что еще не поняли?

Цитата:
Вы профессиональный програмер? Тогда зацените спор на котах.

Глупость какая. Ща он вам назаценивает.

ssss
Offline
Зарегистрирован: 01.07.2016

diger67 пишет:

Дефайны на проц не есть библиотека.

А что даёт библиотека, кучу ненужного и не даёт то что нужно?

Цитата:

Да, те кто пишет свои библиотеки претендуют на совершенство, но писал ранее вся их работа сизифов труд. 

Неужели? Но вы же правите и переписываете чужое? Тоже сизифов труд?

Цитата:

Утверждение на оптимальность вводят пользователей в заблуждение. Все что пишут адепты CMSIS заточено под их узкую задачу, шаг влево шаг в право, зависание программы или полный лок камня.

Смотрите пост выше! 9 бит СПИ на 103-ем камне. Может ваша либа передать 9 бит через СПИ в непрерывном пежиме хардварно?

Цитата:

Знать CMSIS обязательно. Использование оного в чистом виде не гарантирует оптимальный вариант.

Ваши либы уж точно ничего не гарантируют, однозначно. Особенно в плане оптимальности, ибо они избыточны изначально и не охватывают при этом всех возможных применений.

diger67
Offline
Зарегистрирован: 25.07.2015

a5021, смотрите при компиляции лог asm и вы все поймете деточка. Хватит срать в теме, учитесь кодить на серьезном железеи, выскажите хоть раз свое мнеие, а не то что прочитали в интернете. А потом повторили на практике.

ssss
Offline
Зарегистрирован: 01.07.2016

a5021 пишет:

Гы. Представляю, какой бы вы закатили ор, скажи я такое. А тут, ну просто торжество дипломатии.

Не подсказывать! Мне и так уже весело! )))))))))))))))

Цитата:

Маститытый программист-профессионал, в побитовой разблюдовке единичных присвоений, узрел множество отдельных операций. Примерно так 200-300, с его слов. Рентген, мать ети. Пожалуй, это еще более громкий и торжественный аккорд профессионализма, чем даже в случае с таймерами.

Сделаете вид, что еще не поняли?

Та ладно! "А помнишь ... ?"(с) )))))))))))))))))))))))))))))

Ты тоже когда-то так неистово спорил... да и сейчас... порой... )))))))))))))))))))

Он же начинающий, это сразу видно.

 

diger67
Offline
Зарегистрирован: 25.07.2015

Детишки, воспитание коллективом это в младшую группу яслей. Костность не есть признак мастерства. Вы тупо повторяете чужие ошибки. Еще раз повторюсь. Знание CMSIS помогает быстро и грамотно найти ошибку в любом примере. А таких ошибок в примерах ваших братьев хоть отбавляй. 90% работают на одной линейке, радуйтесь жизни ламеры.

ssss
Offline
Зарегистрирован: 01.07.2016

diger67 пишет:

смотрите при компиляции лог asm и вы все поймете

Да не только лог АСМа приходится смотреть, а и анализатором пользоваться, и время функций считать. Только причём здесь это?

Кстати. Меньший по объёму код не всегда самый быстрый.

ssss
Offline
Зарегистрирован: 01.07.2016

diger67 пишет:

Еще раз повторюсь. Знание CMSIS помогает быстро и грамотно найти ошибку в любом примере.

Хоть это понимаете! Уже что-то. )))))))))))))

Цитата:

А таких ошибок в примерах ваших братьев хоть отбавляй.

А сестёр не забыли? ))))))))))))))))))

Докажите, что СПЛ и ХАЛ интуитивно исправляют любые ошибки юзера! Слабо? ))))))))))))))

diger67
Offline
Зарегистрирован: 25.07.2015

ssss пишет:

Кстати. Меньший по объёму код не всегда самый быстрый.

Не объем кода решает оптимальность. Оптимизация это довольно интересный процесс, при котором имеет значение последовательность и дробление выполняемых задачь.

diger67
Offline
Зарегистрирован: 25.07.2015

ssss. роль юродива вам не клицу. А темболее клоуна!!! Ошибки есть везде. а вот умение их найти и исправить дано не каждому.

Yarik.Yar
Offline
Зарегистрирован: 07.09.2014

diger67 пишет:
Опять же осуждать людей юзающих исключительно CMSIS, ну не дано им. Им только кажется что они досканально знают все изнутри. А по сути используют понятные только им макросы и определения, и их каляки моляки также требуют глубокого изучения

Не дано знать библиотеку высокого уровня? Это как говорить ассемблерщику, что ему не дано знать С и что ему всё только кажется. Использование своих "каляк-маляк" вполне оправдано - точно знаешь, что оно у тебя работает, а остальное и не особо важно - хобби для себя. Мой набор "каляк" прост, как бревно - числовые, вручную посчитанные значения, которые я заношу в регистры. Кстати, понемногу отхожу и от CMSIS в сторону чисто своих дефайнов.

А на счёт ошибок в CMSIS - я как-то неделю сношался с чем-то по SPI, а оно не работало. Использовал SPL. Что оказалось? Ах да, ошибочка в SPL, режим SPI не тот выбирался, бывает. Сколько работаю со своими макросами - такого не было. Библиотеки тоже свои пишу.

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

Всё вышесказанное - ИМХО.

ssss
Offline
Зарегистрирован: 01.07.2016

diger67 пишет:

 радуйтесь жизни

Стараемся, как можем! )))))))))))))))

А поводу 9 бит СПИ совета профи так и не услышим? Не? Может либа СПЛ не той системы? )))))))))))))

ssss
Offline
Зарегистрирован: 01.07.2016

diger67 пишет:

ssss пишет:

Кстати. Меньший по объёму код не всегда самый быстрый.

Не объем кода решает оптимальность. Оптимизация это довольно интересный процесс, при котором имеет значение последовательность и дробление выполняемых задачь.

Для моих задач и способов их решения ваши либы категорически противопоказаны. Что поделать! Зато я свободен в выборе МК и решений задачи.

diger67
Offline
Зарегистрирован: 25.07.2015

ssss пишет:

А поводу 9 бит СПИ совета профи так и не услышим? Не? Может либа СПЛ не той системы? )))))))))))))

Читать умеете, писал "могу ошибаться", так что свой сарказм засуньте, ну вы в курсе. По поводу профи. Сколько людей, столько вариантов решения задачи. И с этим вы думаю спорить не будите. Иначе вы просто параноик с обициями на маниюю....

diger67
Offline
Зарегистрирован: 25.07.2015

ssss пишет:

Для моих задач и способов их решения ваши либы категорически противопоказаны. Что поделать! Зато я свободен в выборе МК и решений задачи.

Задачи помигать светодиодом, передать через блютуз или Wi-Fi, это для школьников, общаться с кирпичами где все описано в даташите ума не надо. А вот создать устройство имеющие свой интерфейс похожий на ОС требует немного больше усилий. 

ssss
Offline
Зарегистрирован: 01.07.2016

diger67 пишет:

 Ошибки есть везде. а вот умение их найти и исправить дано не каждому.

А где вы видели мои жалобы, открытые темы, вопросы по неработающим функциям или железу? Могу облегчить ваш труд - их нет нигде, ни на каком из форумов!

ssss
Offline
Зарегистрирован: 01.07.2016

diger67 пишет:

передать через блютуз или Wi-Fi, это для школьников, общаться с кирпичами где все описано в даташите ума не надо. А вот создать устройство имеющие свой интерфейс похожий на ОС требует немного больше усилий. 

Перспектива человека-оркестра меня как-то не очень прельщает. Особенно глядя на отсутствие вашего результата.

diger67
Offline
Зарегистрирован: 25.07.2015

Yarik.Yar пишет:

Не дано знать библиотеку высокого уровня? Это как говорить ассемблерщику, что ему не дано знать С и что ему всё только кажется. Использование своих "каляк-маляк" вполне оправдано - точно знаешь, что оно у тебя работает, а остальное и не особо важно - хобби для себя. Мой набор "каляк" прост, как бревно - числовые, вручную посчитанные значения, которые я заношу в регистры. Кстати, понемногу отхожу и от CMSIS в сторону чисто своих дефайнов.

А на счёт ошибок в CMSIS - я как-то неделю сношался с чем-то по SPI, а оно не работало. Использовал SPL. Что оказалось? Ах да, ошибочка в SPL, режим SPI не тот выбирался, бывает. Сколько работаю со своими макросами - такого не было. Библиотеки тоже свои пишу.

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

Всё вышесказанное - ИМХО.

Все что вы написали говорит о том что вы не умеете работать с документами. Я могу честно признаться что сколько не читал так и не смог понять пиципы работы USB. Читаешь вроде ни чего сложного, а на практике ступор. Для кого то это семечки, но не для меня. К чему это, да к тому что в оисании часто многое опускается, автор подразумевает что многое и так понятно. К стати библиотека SPL для f4 там есть косяк с работой BSRR, я для себя решил этот ворпрос исправив определения в CMSIS, В CMSIS, что для адептов кащумство.

ssss
Offline
Зарегистрирован: 01.07.2016

diger67 пишет:

По поводу профи. Сколько людей, столько вариантов решения задачи. И с этим вы думаю спорить не будите.

Спорить не буду. А вот по поводу оптимальности решения задачи очень даже буду, если вы понимаете о чём речь.

diger67
Offline
Зарегистрирован: 25.07.2015

ssss пишет:

Перспектива человека-оркестра меня как-то не очень прельщает. Особенно глядя на отсутствие вашего результата.

Вы по определению человек оркестр....