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

STM32 для чайника


ART_ME

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

GOR23, спасибо, действительно не проходит проверку контрольной суммы, убрал ее и заработало. Где, та оптимазация компилятора в IAR я не знаю.

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

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

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

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

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

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

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

Такой вопрос "начинающего":

В чем отличие/преимущество DMA от обычных  прерываний при работе с I2C в stm32? Частота контроллера 72 МГц, частота шины I2C - 400 кГц. Если работать с I2c  блокирующими функциями (операции read/write), толку от частоты контроллера немного - большую часть времени будем ждать на этих функциях I2C.

Можно сделать, чтоб операции read/write, по их окончании, вызывали обработчики прерывания. Тогда микроконтроллер не будет простаивать на read/write вызовах, они вернут управление моментально, в то время как модуль I2C дождется окончания операции и дернет прерывание, когда данные будут приняты или отправлены.

Почему в таких случаях предпочитают DMA, какой дополнительный ощутимый выигрыш он дает ?

 

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

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

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

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

тем, что при работе DMA ядро свободно, а при обработке прерываний занято. То есть если коротко, то при использовании DMA у тебя двухядерный проц, а на прерываниях нет

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

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

В общем случае, ДМА, занимая шину, тоже частично блокирует ядро. Конечно гораздо меньше, чем обработчик прерываний, но если транзакции идут плотно, можно практически остановить ядро. Особенно если оно требует работы с шиной (ОЗУ и периферия). Регистровые операции (РОНы) обращения к шине не требуют.

戦う前に相手のベルトの色に注目

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

хорошо, что есть такие умные ребята, которые точно знают кто что и на сколько блокирует. Это радует, несомненно.

Но вопрос звучал так - в чем разница с ДМА и без и почему предпочитают именно ДМА

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

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

On 8/23/2017 at 2:53 AM, mail_robot said:

в чем разница с ДМА и без и почему предпочитают именно ДМА

Без DMA микроконтроллер должен скопировать по шине AHB данные из одного участка памяти (или регистров периферии) к себе в регистр, потом скопировать эти же данные обратно по то же шине в другой участок памяти (или регистры периферии). Все это занимет время и ресурсы (шины + контроллера). Если используется DMA то данные ходят по шине "автоматически", без участия микропроцессора, что выходит значительно быстрее и еще и экономит ресурсы контроллера.

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

В 23.08.2017 в 04:55, my504 сказал:

Регистровые операции (РОНы) обращения к шине не требуют.

То есть можно организовать одномоментное обращение ядра к памяти и ПДП к регистру устройства?

А я думал, что они лежат в едином адресном пространстве и дешифруются единым адресным дешифратором для обмена по единой шине данных..

Блин, век живи, век учись. :mellow: 

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

дуют то они по одной шине, а вот механизмы адресации разные

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

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

В 24.08.2017 в 15:48, Alex Falcon сказал:

То есть можно организовать одномоментное обращение ядра к памяти и ПДП к регистру устройства?

А я думал, что они лежат в едином адресном пространстве и дешифруются единым адресным дешифратором для обмена по единой шине данных..

Блин, век живи, век учись. :mellow: 

Они ТЕРРИТОРИАЛЬНО находятся в разных позициях.

Например, письмо может быть адресовано как в свой дом, так и в свой город, так и в свою страну. Единое адресное пространство, но совершенно разные пути доставки.

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

В 23.08.2017 в 09:03, mail_robot сказал:

а ответ был хоть как то уточнен?

Как показала практика - БЫЛ. :)

Изменено пользователем my504

戦う前に相手のベルトの色に注目

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

В 27.08.2017 в 06:19, my504 сказал:

Единое адресное пространство, но совершенно разные пути доставки.

Дешифратор может быть подключен к шине адресов как внутри ядра, так и на общую шину

Как на "пути доставки" влияет конкретизация адреса "Страна", "Город", "Улица".. и т.п.

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

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

А с чего Вы решили, что дешифратор один?

Вы полагаете, что сделать единый дешифратор для всех и тащить в совершенно разные концы кристалла тысячи шин - это хорошая идея?

:lol:

По моему, не надо быть сильным специалистом по топологии, чтобы понять, что гораздо проще сделать столько дешифраторов, сколько групп регистров имеется на кристалле и таскать в эти узлы только 32 линии адреса.

А кроме того, РОНы  в регистровых операциях  адресуются из дешифратора КОМАНД коротким адресом содержащимся прямо в команде. Их видимость в общем адресном пространстве - это СПЕЦИАЛЬНЫЙ механизм доступа, а не признак того, что они управляются от дешифратора общей шины.

Ну и последнее. При работе с общей шиной, процессор так строит транзакции, чтобы МИНИМИЗИРОВАТЬ ее занятость. В том числе и для эффективного механизма внепроцессорных транзакций (ДМА, например). И бесполезно занимать ее (внешнюю шину) при внутрипроцессорных пересылках - совершенная глупость.

戦う前に相手のベルトの色に注目

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

Здравствуйте!
Подскажите пожалуйста, где можно найти распиновку на микроконтроллеры с его альтернативными функциями?
У меня STM32f3 Discovery. Сейчас по даташиту на саму дискавери и stm32f3 играюсь тем, что на плате, но пора уже курить stmку дальше, а распиновку не могу найти :(

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

В 19.08.2017 в 16:25, Электронщик сказал:

GOR23, спасибо, действительно не проходит проверку контрольной суммы, убрал ее и заработало. Где, та оптимизация компилятора в IAR я не знаю.

В IAR оптимизатор вообще как-то странно работает, по крайней мере в STM8 натыкаюсь часто на неадекватное поведение программы.

 

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

Делал в иаре на стм8 один проект. Нужно было вытягивать с потока по rs-485 "свои" байты на скорости 256 Кбод. То у меня с оптимизацией только и работало. Без нее камень не успевал фильтровать.

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

@GOR23  ну вот  примерный кусок кода

if ( (c=somefunc() ) > 0 )
{
... //какие-то операции с переменной с
}

Вроде бы стандартная конструкция, но после нескольких заходов в этот кусок возвращаемое значение перестаёт присваиваться.

Ещё пример. Решил сделать аналог HAL_Delay(). Есть переменная unsigned long int sys_clk, она инкрементируется потаймеру и в отладчике видно, что с этим всё ок. Теперь функция sys_delay()

void sys_delay( unsigned long int wait_ms )
{
  unsigned long int start_time = sys_clk;
  while ( sys_clk - start_time < wait_ms );
}

Вот в таком виде функция не работает, хотя sys_clk тикает и все аргументы в функцию попали. Но стоит внутрь цикла влепить nop, как всё прекрасно начинает работать.

 

И это далеко не всё, было дело, когда выпадали целые куски из компиляции.

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

Я стараюсь присвоения и какие либо арифметические операции в условиях не лепить, делаю это в какую-то переменную, а потом в условии с ней уже работаю. Так и для отладки удобней. А так тоже пару раз натыкался на похожую хрень, правда в авр студии. А у вас sys_clk volatile или нет? Если она в прерывании изменяется, то комплятор часто жару дает)

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

  • 2 недели спустя...

Вообщем решил прицепить к STM32, nrf24, накидал библиотеку(как накидал, большую часть позаимствовал с библиотеки ардуино), и все бы хорошо, на Атмеге работает все кроме, функций передачи и приема байта данных, вроде бы все просто, дернуть ногой CE, а дальше считать регистр, и сделать ресет флага прерывания, но  все функции настройки моей билиотеки для атмеги работают, а вот функцию приема и передачи байта данных использую с библиотеки ардуино(точнее вызываю ее), там какое-то приведение, никогда с ним дела не имел, и не пойму как его нормально прописать. Еще вопрос такой, на атмеге nrf24 SPI на атмеге настроен на 4МГц, на STM32 при максимальной тактируемой частоте 72МГц, я взял делитель на 32, и SPI у меня настроен на 2,25МГц, так как я не знаю будет ли работать nrf24 на 4,5МГц при делителе на 16.

Вот с бибилиотеки ардуино как заменить reinterpret cast, читал что плохая штука, да и IAR не понимает

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

uint8_t RF24::write_payload(const void* buf, uint8_t len)
{
  uint8_t status;

  const uint8_t* current = reinterpret_cast<const uint8_t*>(buf);

  uint8_t data_len = min(len,payload_size);
  uint8_t blank_len = dynamic_payloads_enabled ? 0 : payload_size - data_len;
  
  //printf("[Writing %u bytes %u blanks]",data_len,blank_len);
  
  csn(LOW);
  status = SPI.transfer( W_TX_PAYLOAD );
  while ( data_len-- )
    SPI.transfer(*current++);
  while ( blank_len-- )
    SPI.transfer(0);
  csn(HIGH);

  return status;
}

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

uint8_t RF24::read_payload(void* buf, uint8_t len)
{
  uint8_t status;
  uint8_t* current = reinterpret_cast<uint8_t*>(buf);

  uint8_t data_len = min(len,payload_size);
  uint8_t blank_len = dynamic_payloads_enabled ? 0 : payload_size - data_len;
  
  //printf("[Reading %u bytes %u blanks]",data_len,blank_len);
  
  csn(LOW);
  status = SPI.transfer( R_RX_PAYLOAD );
  while ( data_len-- )
    *current++ = SPI.transfer(0xff);
  while ( blank_len-- )
    SPI.transfer(0xff);
  csn(HIGH);

  return status;
}

 

 

Брал разные материалы, и разные куски кода пробовал, но ничего, может у кого есть функции приема и передачи байта данных nrf24?

Пробовал с этих источников и с многих других источников функции чтения, записи. не работают  

http://141.70.125.224/AVRLib/nRF24L01/

https://drive.google.com/file/d/0B610P3FMdTo6TTJILWlYMGpQVDg/edit

http://we.easyelectronics.ru/Radio/radiomodul-nrf24l01-bystryy-start.html

https://drive.google.com/file/d/0B610P3FMdTo6TTJILWlYMGpQVDg/edit

http://nrf24l01.pp.ua/nrf24l01/struktura-paketa-nrf24l01-priem-peredacha/

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

  • Сообщения

    • Ну вот, пока готовил эскиз, на все вопросы ответили :-) Действительно, в 3D моделях DipTrace нет (или не нашёл) модели корпуса ТО220 с распайкой с нижней стороны и креплением к радиатору - по этому и получился такой 3D-портрет платы. Задуманная конструкция выглядит примерно так:  По факту, для наладки, сейчас подключаю транзисторы, закрепленные на радиаторе, проводами.
    • Чтобы потом не допиливать паровоз до истребителя. Заводские варианты схемотехники куда более предсказуемы. Из "вольностей" в первую очередь как-то решать проблему коммутации, подходящий переключатель для режимов искать история долгая и грустная. Что-то там с реле. На диапазоны 6п4н вроде же ?  пг2 хрен найдёшь, п2г тугое неудобство(  Рассыпушный ацп делать, боже упаси. Ну разве что был грешен, побаловался когда-то пнч-ацп. С 1108пп1 и 155 серией
    • Но зачем повторять 1в1? Там дана просто топология   Но не совсем же с нуля. Маловероятно, что вы найдете расширение диапазона 7135 до 200мВ по тому же методу, что это реализовано в В7-38, тем не менее, это вполне реализуемо. А вот до 20мВ я спустить диапазон не смог Что-то предусилитель интегратора отказывается вести себя хорошо   Для сравнения, та же точка (вход интегратора) при 200мв пределе, усиление х10   Ну и 2В Госпаде боже лтц2400, на этой штуке можно и 6 разрядник собрать, лютый АЦП, какие 4.5 разряда Цена на него сейчас конечно негуманная кстати.
    • Что то не нашёл примеров такой реализации замены. С нуля целесообразность подобного действа под вопросом. Тут мои полномочия всё) Как бы почему смотрю на hm8011-3, возможность реализации +/- норм настольного мультиметра без всякой там жести в виде кодинга и микро-мелких современных элементов. Для калибровки валяется где-то в1-12 и прецизионных резисторов если моих не хватит, есть где заказать.  На данный момент разве что качественного файла нет, пытался там всякими улучшайками чего сделать, увы. Пойду через впн лазить по уголочкам всяким, вдруг всплывёт чего. ------------- 8012, 80c32 + 27c512. Чертежи плат есть, осталось hex раздобыть 
    • Вот на этом фото? Я думал  тут радиатор будет под ними, и они к нему "пузом" будут прикручиваться, а дырочки - для отвёртки. У @asng60 транзисторы в наружную сторону "мордой" смотрят. "Пузом" на плату ложатся. Плата так разведена. Вот и непонятно, как их "пузом" к радиатору прикручивать.
    • Что касаемо модели Парафина, я бы порекомендовал товарищу Джексону проверить ток покоя выходного каскада, это первым делом, и вторым делом- проверить модель ОУ. Ибо в ОМ нет никаких оу а в парафине- есть. 
×
×
  • Создать...