Перейти к содержанию

STM32 для чайника


ART_ME

Рекомендуемые сообщения

Есть такой. Каждый раз, после компиляции, пересоздаётся.
Вот его внтуренности :

Цитата

; *************************************************************
; *** Scatter-Loading Description File generated by uVision ***
; *************************************************************

LR_IROM1 0x08000000 0x00200000  {    ; load region size_region
  ER_IROM1 0x08000000 0x00200000  {  ; load address = execution address
   *.o (RESET, +First)
   *(InRoot$$Sections)
   .ANY (+RO)
  }
  RW_IRAM1 0x20000000 0x00030000  {  ; RW data
   .ANY (+RW +ZI)
  }
}

Но что тут ? Ни на что вообще не похоже :o
Даже если сюда что-нибудь и добавить - Кейл его заново пересоздаст.

PS: Ущербный какой-то этот кейл... <_<

Ссылка на комментарий
Поделиться на другие сайты

Реклама: ООО ТД Промэлектроника, ИНН: 6659197470, Тел: 8 (800) 1000-321

20% скидка на весь каталог электронных компонентов в ТМ Электроникс!

Акция "Лето ближе - цены ниже", успей сделать выгодные покупки!

Плюс весь апрель действует скидка 10% по промокоду APREL24 + 15% кэшбэк и бесплатная доставка!

Перейти на страницу акции

Реклама: ООО ТМ ЭЛЕКТРОНИКС, ИНН: 7806548420, info@tmelectronics.ru, +7(812)4094849

Выбираем схему BMS для корректной работы литий-железофосфатных (LiFePO4) аккумуляторов

 Обязательным условием долгой и стабильной работы Li-FePO4-аккумуляторов, в том числе и производства EVE Energy, является применение специализированных BMS-микросхем. Литий-железофосфатные АКБ отличаются такими характеристиками, как высокая многократность циклов заряда-разряда, безопасность, возможность быстрой зарядки, устойчивость к буферному режиму работы и приемлемая стоимость. Но для этих АКБ, также как и для других, очень важен контроль процесса заряда и разряда, а специализированных микросхем для этого вида аккумуляторов не так много. Инженеры КОМПЭЛ подготовили список имеющихся микросхем и возможных решений от разных производителей. Подробнее>>

Реклама: АО КОМПЭЛ, ИНН: 7713005406, ОГРН: 1027700032161

Попробовал поставить SEGGER Embedded Studio - такая шняга ... :o:wacko:
Есть вообще нормальные среды разработки под STM32 ? Чтобы GCC можно было подцепить.  Ну и со всеми там плюшками, типа всплывающих подсказок и т.д...

PS: Всё-таки решился на освоение STM'ов. Но уже начинает бесить меня эта затея :D

Ссылка на комментарий
Поделиться на другие сайты

23 минуты назад, Alex сказал:

Но что я там смогу увидеть ?

Но ведь именно здесь кнопка редактирования sct файла. Возможно в нем и надо что то прописывать. (предположил)

Сергей.

Ссылка на комментарий
Поделиться на другие сайты

On 15.02.2019 at 9:59 PM, my504 said:

Приведи в соответствие свою совесть с рандомностью изрекаемых тобой глупостей

иди мальчик, иди :bye:

Нужно делать то, что нужно. А то, что не нужно, делать не нужно. (С) Винни Пух

Ссылка на комментарий
Поделиться на другие сайты

@Alex Поставь Atollic True Studio, официальная среда от вендоров. Там как раз Eclipse, куча плюшек, отличная отладка, GCC и нормальный скрипт линкера.  

Ссылка на комментарий
Поделиться на другие сайты

7 часов назад, Alex сказал:

Есть такой. Каждый раз, после компиляции, пересоздаётся.
Вот его внтуренности :

Но что тут ? Ни на что вообще не похоже :o
Даже если сюда что-нибудь и добавить - Кейл его заново пересоздаст.

PS: Ущербный какой-то этот кейл... <_<

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

 

Изменено пользователем Oxford
Ссылка на комментарий
Поделиться на другие сайты

@Oxford , вместо злых смайлов, лучше скажите как это реализовывается. Можно ещё и о смещении адресов рассказать, для реализации бутлодыря и загружаемого ПО.

В скриптах GCC это всё делается элементарно. А тут .... Даже гугл не спасает. Никто ничего об этом не знает. Ну или рассказывать не хочет :)

1 час назад, MasterElectric сказал:

Поставь Atollic True Studio, официальная среда от вендоров.

Спасибо, попробую.

Ссылка на комментарий
Поделиться на другие сайты

Поддерживает вплоть до С++14. Проект как по мне лучше создавать пунктом Embedded C Project, потом можно выкосить лишнее.

Изменено пользователем MasterElectric
Ссылка на комментарий
Поделиться на другие сайты

Т.е. в созданный С-проект уже не добавить .cpp ? Интересно, чем они могут отличаться... <_<
Кстати, среда довольно приятная. Это же Eclips (ну или очень на него похож). Всё запустилось без проблем (отладка, ...). Уже перепробовал много всяких сред, отладчик смог прикрутить только в Кейле и в Atollic. А из-за Segger'овской среды вообще пришлось перешить St-link (который на дискаверени стоит) в J-link. И обратно уже хрен :unsure:

Ссылка на комментарий
Поделиться на другие сайты

Странно я и туда и обратно, обратно бывает не с первого раза, но получаеться. Да она полностью на основе Eclipse. RTT пробовал работает, по отладке очень много там всего. http://blog.atollic.com в блоге много интересного.

Изменено пользователем MasterElectric
Ссылка на комментарий
Поделиться на другие сайты

1 минуту назад, MasterElectric сказал:

обратно бывает не с первого раза, но получаеться

STLinkReflash пишет, что всё сделал, но ST-Link уже нерабочий. Пробовал несколько раз - нифига :unsure:

Да ну и ладно. В пути уже настоящий J-Link от Segger'а. Будем его мучить, отомстим за испорченный ST-Link :lol:

Ссылка на комментарий
Поделиться на другие сайты

Такс, ещё осталось узнать как из неё прошить. Отладка запускается без проблем, но вот как просто прошить и запустить ?
Приходится врубать отладку, выключать и жать Резет :wacko:

Ссылка на комментарий
Поделиться на другие сайты

В общем всё пока круто.
Переменные в SDRAM тоже разместил без проблем. Студия даже показывает размер секции и сколько у меня там занято.

Скрытый текст

2019-02-17_03-13-59.thumb.png.e6571fccba8a68c91e6efb1e02635d22.png

Мало того, я ещё эти данные могу дебажить - не только просматривать, но и изменять в окне watch.
Супер ! B)

Ссылка на комментарий
Поделиться на другие сайты

можно все это делать до вызова main, написать инициализацию секции .sdram_bss и обнулять или если это секция .sdram_data (SDRAM) заполнять данными. 

Ссылка на комментарий
Поделиться на другие сайты

Не понял....

Я инициализацию SDRAM вызываю в стартапе, сразу после инита стека. Инициализированные переменные, находящиеся в этой секции, принимают нужные значения.
Воть :

    .section  .text.Reset_Handler
  .weak  Reset_Handler
  .type  Reset_Handler, %function
Reset_Handler:  
  ldr   sp, =_estack    /* Atollic update: set stack pointer */
  
  bl  SDRAM_Init

/* Copy the data segment initializers from flash to SRAM */  
  movs  r1, #0
  b  LoopCopyDataInit

 

Теперь когда я пишу, например

Цитата

SDRAM    int        ii=100;

то на main переменна ii приходит уже инициализированная числом 100.

 

Вы об этом ?

Ссылка на комментарий
Поделиться на другие сайты

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

Изменено пользователем MasterElectric
Ссылка на комментарий
Поделиться на другие сайты

9 часов назад, MasterElectric сказал:

На какой платке вы тренируетесь? Быстро осваиваетесь!

Пропустил вопрос. Видимо ,Вы его добавили позже.
Плата STM32F429I-Disco.

Следующим шагом - подцепить дисплей по FMC и заюзать для него буферы во внешней SDRAM через DMA.

Ссылка на комментарий
Поделиться на другие сайты

чудесный форум. скопировал код сюда, пока ждал ответа не чо не трогая еще раз скомпилил и все работает :D

 

Изменено пользователем DrobyshevAlex
Ссылка на комментарий
Поделиться на другие сайты

Помогите разобраться с PWM в stm32f030

#define LCD_PORT GPIOA
#define LCD_CONT_PIN GPIO_Pin_10
#define LCD_CONT_TIM TIM1

	GPIO_InitTypeDef port;
	GPIO_StructInit(&port);

	port.GPIO_Mode = GPIO_Mode_AF;
	port.GPIO_Pin = LCD_CONT_PIN;
	port.GPIO_Speed = GPIO_Speed_50MHz;
	port.GPIO_OType = GPIO_OType_PP;
	port.GPIO_PuPd = GPIO_PuPd_UP;

	GPIO_PinAFConfig(LCD_PORT, LCD_CONT_PIN, GPIO_AF_2);

	GPIO_Init(LCD_PORT, &port);

	RCC_APB2PeriphClockCmd(RCC_APB2Periph_TIM1, ENABLE);


	LCD_CONT_TIM->PSC = 48000;
	LCD_CONT_TIM->ARR = 10000;
	LCD_CONT_TIM->CCR3 = 9999;

	LCD_CONT_TIM->CCER |= TIM_CCER_CC3E;
	LCD_CONT_TIM->BDTR |= TIM_BDTR_MOE;

	LCD_CONT_TIM->CCMR2 |= TIM_CCMR2_OC3M_0 | TIM_CCMR2_OC3M_1 | TIM_CCMR2_OC3M_2;

	LCD_CONT_TIM->CR1 |= TIM_CR1_CEN;

	LCD_CONT_TIM->EGR |= TIM_EGR_UG;

Что не так?) Что бы я не писал в CCR3 на ноге всегда 3В

 

Изменено пользователем DrobyshevAlex
Ссылка на комментарий
Поделиться на другие сайты

Присоединяйтесь к обсуждению

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

Гость
Unfortunately, your content contains terms that we do not allow. Please edit your content to remove the highlighted words below.
Ответить в этой теме...

×   Вставлено с форматированием.   Восстановить форматирование

  Разрешено использовать не более 75 эмодзи.

×   Ваша ссылка была автоматически встроена.   Отображать как обычную ссылку

×   Ваш предыдущий контент был восстановлен.   Очистить редактор

×   Вы не можете вставлять изображения напрямую. Загружайте или вставляйте изображения по ссылке.

Загрузка...
  • Последние посетители   0 пользователей онлайн

    • Ни одного зарегистрированного пользователя не просматривает данную страницу

  • Сообщения

    • Повторюсь - НЕТ, так как у вас там крутилки, что приведет к искажениям при работе в мостовой схеме.
    • Все верно, вы почти все что нужно сделали.  Только не нужно было добавлять это b=UDR; Сразу после старта сбросить флаг flags = 0; А в основном цикле ждать установки флага FLAG_END_RX. И если он установлен, проверять на совпадение строки в буфере (rx_buf) с вашей строкой (AT+QM \ r \ n .....   .....  AT+MP \ r \ n) При совпадении вызывать выполнение нужного алгоритма.
    • У меня до саба ещё дело не дошло, только сейчас думаю купить амп на полкиловатта, но так можно, при условии, что на входе будет моно, и будет срез частот
    • Про флаг Т: если он не используется в основной программе, а у меня он постоянно в деле. для меня меня отложенная обработка прерывания обычное дело, нужно лишь правильно расставить приоритеты частей программы. И обычное дело: выставляешь частоту задающего генератора побольше, делишь его до получения частоты 1000 Гц каким либо таймером, загоняешь в прерывание с флагом. затем закольцовываешь основную программу с проверкой флага прерывания от таймера 1000Гц. загоняешь программу в Sleep. Получаешь кольцо обработки с образцовым интервалом в 1 мс. После любого прерывания проверяешь флаг от таймера, если он, то сбрасываешь флаг и начинаешь перебирать подпрограммы обработки индикаторов, клавиатуры, и тд. и тп, подпрограммы обработки флагов и др. После окончания обработки всех подпрограмм возвращаешься к Sleep. И так по кольцу. Если происходит прерывание не от таймера, программа выходит из Sleep, проверяется флаг от таймера, если не он (а это не он) обратно к Sleep. В большенстве программ использую этот алгоритм.   GPIOR1 и GPIOR2 в 88 условно можно использовать как флаги, но их адреса больше 0х1Е, на них не распространяются команды cbi, sbi, sbic, sbis, и их сначала нужно загрузить в общий регистр, промодифицировать, и заново сохранить. Эта последовательность длинная, и модифицирует SREG, что сводит на нет работу по сравнению с  классическим GPIOR.
    • @korsaj Сегодня попробовал сделать как ты посоветовал. Получился следующий код. #define F_CPU 7372800UL #define BAUND 9600L #define UBRRL_value (F_CPU/(BAUND*16))-1 #include <avr/io.h> #include <util/delay.h> #include <avr/interrupt.h> #include <stdlib.h> void init_pin(void); #define C_PC0 (~PINC&(1<<PC0)) #define C_PC1 (~PINC&(1<<PC1)) #define LED_1_ON() PORTD|=(1<<PD2) #define LED_1_OFF() PORTD&=~(1<<PD2) #define LED_2_ON() PORTD|=(1<<PD3) #define LED_2_OFF() PORTD&=~(1<<PD3) #define FLAG_END_RX (1<<3) #define FLAG_ERR_RX (1<<4) #define BUF_SIZE 20 char rx_buf[BUF_SIZE]; char buf_index = 0; volatile start=1, flags; char b; ISR(USART_RXC_vect) { b=UDR; if(!(flags & FLAG_END_RX)) { rx_buf[buf_index]=UDR; if(rx_buf[buf_index] == 0x0D) { flags |= FLAG_END_RX; return; } buf_index++; if(buf_index >= BUF_SIZE) { buf_index = 0; flags |= FLAG_ERR_RX; } } } void init_UART() { UBRRL = UBRRL_value; UBRRH = UBRRL_value>>8; UCSRB|=(1<<TXEN); UCSRB|=(1<<RXEN); UCSRC|=((1<<URSEL)|(1<<UCSZ0)|(1<<UCSZ1)); UCSRB|=(1<<RXCIE); sei(); flags = 0; } void send_UART(char value) { while(!(UCSRA&(1<<UDRE))); UDR=value; } int main(void) { init_pin(); init_UART(); while(1) { if (start==1) { _delay_ms(500); send_UART('O'); send_UART('K'); send_UART('!'); send_UART(0x0D); send_UART(0x0A); _delay_ms(10); start=0; } if (b == '0') { LED_1_ON(); LED_2_OFF(); send_UART('N'); send_UART('+'); send_UART('0'); send_UART('0'); send_UART(0x0D); send_UART(0x0A); _delay_ms(10); b=4; } if (b == '1') { LED_1_OFF(); LED_2_ON(); send_UART('N'); send_UART('+'); send_UART('0'); send_UART('1'); send_UART(0x0D); send_UART(0x0A); _delay_ms(10); b=4; } if (b == '2') { LED_1_ON(); LED_2_ON(); send_UART('N'); send_UART('+'); send_UART('0'); send_UART('2'); send_UART(0x0D); send_UART(0x0A); _delay_ms(10); b=4; } if (b == '3') { LED_1_OFF(); LED_2_OFF(); send_UART('N'); send_UART('+'); send_UART('0'); send_UART('3'); send_UART(0x0D); send_UART(0x0A); _delay_ms(10); b=4; } if (C_PC0) { send_UART('P'); send_UART('C'); send_UART('0'); send_UART(0x0D); send_UART(0x0A); _delay_ms(250); } if (C_PC1) { send_UART('P'); send_UART('C'); send_UART('1'); send_UART(0x0D); send_UART(0x0A); _delay_ms(250); } } } void init_pin(void) { DDRC = 0b00000000; PORTC = 0b11111111; DDRD |= ((1<<2)|(1<<3)); PORTD &=~ ((1<<2)|(1<<3)); } Ну как сказать всё работает, но вот меня очень интересует приём команд на саму ATMEGA16. Он так и работает только с цифрами. Более ничего корректно принять не получается даже используя таблицу ascii. А мне нужно будет принимать команды и посложней чем просто буквенно - цифровые. Потому как возвращаясь к командам самого плеера там в этих командах хранятся различные данные. Вот примерно так это всё выглядит. AT+QM \ r \ n Запрос режима работы [0: Bluetooth], [1: MP3] AT+M1 \ r \ n Номер текущего файла AT+M2 \ r \ n Общее количество звуковых файлов AT+MD \ r \ n Источник музыки USB или SD Card AT+MT \ r \ n Общее время воспроизведения текущего файла AT+MK \ r \ n Время воспроизведения текущего файла AT+MP \ r \ n Текущее состояние плеера [0]Стоп, [1]Воспроизведение, [2]Пауза К примеру при отправке команды AT+M1 \ r \ n в ответ мы получим M1 + 000002 \ r \ n при этом здесь может быть любое число в hex формате. Мне же нужно каким то образом принять эти данные и обработать их соответствующим образом. Но при этом и нужно учитывать так же что плеер может сам отправить эти данные по началу воспроизведения трека. Вот в этом сейчас и стоит основная задача. Чего я и пытаюсь получить в итоге.
    • Ну тогда дорога к сименсу в гости - они вам какой-нибудь Desigo CC или даже Siematic предложат, тыщ за 10 долларов. Ну и ещё тыщ 5 надо будет отдать за контроллеры и их конфигурирование.   А если попроще - то можно к отечественным MasterSCADA обратиться, либо к WiredBoard - у них не совсем SCADA система, но нормальные контроллеры, довольно просто настраиваются и можно графическую оболочку рисовать.
×
×
  • Создать...