|
libopencm3, Неплохая либа для кортексов... |
|
|
|
 |
Ответов
|
Apr 15 2015, 05:47
|

Ally
     
Группа: Модераторы
Сообщений: 6 232
Регистрация: 19-01-05
Пользователь №: 2 050

|
Цитата(Golikov A. @ Apr 15 2015, 08:12)  ДМА настраивать на обмен 6 байтами - глупо, а 2 ДМА для приема 4 еще глупее. Да, если недальновидно выбран микроконтроллер. Я например сразу планирую сколько скоростных последовательных каналов будет в системе и прикидываю сколько каналов DMA понадобится. Чем больше каналов DMA тем лучше чип заточен под RTOS. Лучше всего здесь дела обстоять у Kinetis (32 канала), похуже у STM32F4 (16 каналов), еще хуже у LPC17xx (8 каналов)
|
|
|
|
|
Apr 15 2015, 07:37
|
Профессионал
    
Группа: Свой
Сообщений: 1 386
Регистрация: 5-04-05
Из: моська, RF
Пользователь №: 3 863

|
Цитата(AlexandrY @ Apr 15 2015, 08:47)  Лучше всего здесь дела обстоять у Kinetis (32 канала), похуже у STM32F4 (16 каналов), еще хуже у LPC17xx (8 каналов) Тут дело даже не в "канальности". У STM32F4 например к каждому каналу (точнее, стриму) привязано до 8 определённых источников/приёмников данных. Поэтому если вы хотите использовать ДМА для 2-3-4 источников, привязанных к одному стриму, то вас может ждать облом. Точнее, облом был бы неминуем, но один и тот же источних часто (но не всегда) привязан к двум стримам (а в целом они распределены хаотично), но всё же облом вероятен (я — уже). Нет и речи о том чтобы использовать хотя бы половину стримов. А к примеру в "тупике эволюции" блэкфине каналы ДМА не привязаны к конкретной периферии. При этом забавно, что там каналов чуть ли не больше чем источников данных :-)))
|
|
|
|
|
Apr 15 2015, 09:07
|
Гуру
     
Группа: Свой
Сообщений: 5 228
Регистрация: 3-07-08
Из: Омск
Пользователь №: 38 713

|
Цитата(Dr.Alex @ Apr 15 2015, 13:37)  Поэтому если вы хотите использовать ДМА для 2-3-4 источников, привязанных к одному стриму, то вас может ждать облом. Точнее, облом был бы неминуем, но один и тот же источних часто (но не всегда) привязан к двум стримам (а в целом они распределены хаотично), но всё же облом вероятен (я — уже). Нет и речи о том чтобы использовать хотя бы половину стримов. Это одна из главных причин из-за которой недавно, при выборе МК для новой железки, мы отказались от STM32F4. Очень убого реализована периферия в нём - ни буферизации (FIFO) ни достаточного числа DMA-каналов для решения проблемы без FIFO.  Цитата(Golikov A. @ Apr 15 2015, 13:44)  Опять же иногда ДМА настроить дольше чем перепихать данные... LPC кстати имеет фифо - что здорово облегчает иногда дело, но все равно проблемы имеются... LPC, Tiva имеют нормальные FIFO (UARTы, SPI, etc). STM32 экономит на пуговицах непонятно зачем, значительно ухудшая характеристики МК.
|
|
|
|
|
Apr 15 2015, 17:41
|
Гуру
     
Группа: Участник
Сообщений: 2 219
Регистрация: 16-08-12
Из: Киров
Пользователь №: 73 143

|
Цитата(jcxz @ Apr 15 2015, 12:07)  Это одна из главных причин из-за которой недавно, при выборе МК для новой железки, мы отказались от STM32F4. Очень убого реализована периферия в нём - ни буферизации (FIFO) ни достаточного числа DMA-каналов для решения проблемы без FIFO. Че-то не пойму, или все пытаются использовать стм для ЦОС, с несколькими стримами по 100 мегабайт\сек или используют сразу всю периферию, что каналов дма нехватает или что еще... Вот никогда эти фифо не использовал, муторно с ними, работал с 5 уартами и 2 спи одновременно, по 100мег не передавал, конечно, ибо для таких задач существуют коммуникационные процы или плис. Никаких проблем не испытывал, либо, принимал по прерываниям, либо дма, для больших пакетов. Тут, по моему, искусственно создают бурю в стакане воды...
|
|
|
|
|
Apr 16 2015, 02:16
|
Гуру
     
Группа: Свой
Сообщений: 5 228
Регистрация: 3-07-08
Из: Омск
Пользователь №: 38 713

|
Цитата(mantech @ Apr 15 2015, 23:41)  Че-то не пойму, или все пытаются использовать стм для ЦОС, с несколькими стримами по 100 мегабайт\сек или используют сразу всю периферию, что каналов дма нехватает или что еще... Вот никогда эти фифо не использовал, муторно с ними, работал с 5 уартами и 2 спи одновременно, по 100мег не передавал, конечно, ибо для таких задач существуют коммуникационные процы или плис. Не для ЦОС (хотя и она там возможно в каком-то количестве будет чуть позже), но в устройстве нужно 5-6 UART (одновременно работающих и при этом желательно - не перегружающих систему прерываниями в десятки кГц) + 2 одновременно работающих SPI (20-40МГц). Это как минимум то, что в STM32 придётся делать с DMA. В старых устройствах на LPC17x примерно то же самое работает занимая всего 4 DMA-канала (2 SPI), а UART-ы без DMA нормально работают, так как имеют FIFO. Да и SPI-каналы имеют FIFO, так что, как я понимаю, меньше занимают шину блочными пересылками. А в новом устройстве планируется более интенсивный поток по SPI-каналам (к тому-же - реалтаймовый). По этой причине в основном и отказались от STM32. Как тут уже написали - работать с FIFO - то же самое что и без, практически никакой разницы, только частота обслуживания может быть в 16 раз меньше.
|
|
|
|
Сообщений в этой теме
demiurg_spb libopencm3 Mar 15 2013, 06:35 zhevak Цитата(demiurg_spb @ Mar 15 2013, 12:35) ... Mar 15 2013, 07:04 esaulenka Тут есть пользователи этой библиотеки?
Первое впе... Apr 3 2015, 08:06 demiurg_spb Цитата(esaulenka @ Apr 3 2015, 11:06) Тут... Apr 3 2015, 13:24 AlexandrY Цитата(demiurg_spb @ Mar 15 2013, 09:35) ... Apr 3 2015, 10:38 klen голосую за libcm3
Spl еще както было похоже на что... Apr 4 2015, 07:36 kan35 Цитата(klen @ Apr 4 2015, 10:36) голосую ... Apr 12 2015, 15:50  Dr.Alex Цитата(kan35 @ Apr 12 2015, 18:50) Запуск... Apr 12 2015, 17:17 _Pasha Цитата(esaulenka @ Apr 3 2015, 11:06) Соб... Apr 6 2015, 14:49 esaulenka Цитата(_Pasha @ Apr 6 2015, 17:49) у меня... Apr 7 2015, 10:45 Golikov A. А какая связь наличие или отсутствия while (бит) и... Apr 13 2015, 06:45 Dr.Alex Цитата(Golikov A. @ Apr 13 2015, 09:45) А... Apr 13 2015, 07:27 Golikov A. строго говоря я не под что не пишу while(условие).... Apr 13 2015, 09:28 Dr.Alex Цитата(Golikov A. @ Apr 13 2015, 12:28) с... Apr 13 2015, 09:44 AlexandrY Цитата(Golikov A. @ Apr 13 2015, 12:28) с... Apr 13 2015, 09:52 Golikov A. понятно, спасибо... Apr 13 2015, 09:56 SasaVitebsk Вы знаете, но честно говоря меня напрягают оценки ... Apr 13 2015, 10:00 mantech Цитата(SasaVitebsk @ Apr 13 2015, 13:00) ... Apr 13 2015, 11:10 Golikov A. А вот теперь я задумался, а как с учетом заточенос... Apr 14 2015, 11:16 AHTOXA Тут всё просто. Если ждать долго, то надо на оконч... Apr 14 2015, 14:21  Dr.Alex Цитата(AHTOXA @ Apr 14 2015, 17:21) Если ... Apr 14 2015, 14:35   AHTOXA Цитата(Dr.Alex @ Apr 14 2015, 19:35) Кто ... Apr 14 2015, 17:01    Dr.Alex Цитата(AHTOXA @ Apr 14 2015, 20:01) Ну за... Apr 14 2015, 17:04     AHTOXA Цитата(Dr.Alex @ Apr 14 2015, 22:04) С та... Apr 14 2015, 17:59 mantech Цитата(Golikov A. @ Apr 14 2015, 14:16) А... Apr 14 2015, 14:51 Golikov A. ЦитатаВообще-то для этого под оси и пишутся драйве... Apr 14 2015, 18:16 AlexandrY Цитата(Golikov A. @ Apr 14 2015, 21:16) М... Apr 14 2015, 18:40  jcxz Цитата(AlexandrY @ Apr 15 2015, 00:40) Ра... Apr 15 2015, 03:04   AlexandrY Цитата(jcxz @ Apr 15 2015, 06:04) Иногда ... Apr 15 2015, 04:46    jcxz Цитата(AlexandrY @ Apr 15 2015, 10:46) В ... Apr 15 2015, 06:55     scifi Цитата(jcxz @ Apr 15 2015, 09:55) при опи... Apr 15 2015, 07:29  mantech Цитата(AlexandrY @ Apr 14 2015, 21:40) Ра... Apr 15 2015, 05:02 AHTOXA Цитата(Golikov A. @ Apr 14 2015, 23:16) И... Apr 15 2015, 03:59     den_po Цитата(mantech @ Apr 15 2015, 22:41) Вот ... Apr 15 2015, 19:06     Dr.Alex Цитата(mantech @ Apr 15 2015, 20:41) Че-т... Apr 15 2015, 19:08      mantech Цитата(jcxz @ Apr 16 2015, 05:16) Как тут... Apr 16 2015, 04:59       jcxz Цитата(mantech @ Apr 16 2015, 10:59) Это ... Apr 16 2015, 07:02        SasaVitebsk Цитата(jcxz @ Apr 16 2015, 10:02) Готовно... Apr 16 2015, 09:23         jcxz Цитата(SasaVitebsk @ Apr 16 2015, 15:23) ... Apr 17 2015, 02:27          mantech Цитата(jcxz @ Apr 17 2015, 05:27) Вот соб... Apr 17 2015, 05:17           jcxz Цитата(mantech @ Apr 17 2015, 11:17) Дак ... Apr 17 2015, 07:01            mantech Цитата(jcxz @ Apr 17 2015, 10:01) Какие п... Apr 17 2015, 08:50             jcxz Цитата(mantech @ Apr 17 2015, 14:50) CRC ... Apr 17 2015, 09:42              mantech Цитата(jcxz @ Apr 17 2015, 12:42) 64-битн... Apr 17 2015, 17:17 mantech Цитата(Golikov A. @ Apr 15 2015, 08:12) В... Apr 15 2015, 08:42 Golikov A. еще матрица шин, а потом доступ проца и каналы кро... Apr 15 2015, 07:44 Golikov A. ЦитатаПрием - запускаю дма и счетчик таймаута, жду... Apr 15 2015, 09:47 SasaVitebsk Когда у человека появляется красивый инструмент, в... Apr 15 2015, 09:59 jcxz Цитата(SasaVitebsk @ Apr 15 2015, 15:59) ... Apr 15 2015, 10:29  SasaVitebsk Цитата(jcxz @ Apr 15 2015, 13:29) Прелест... Apr 16 2015, 05:05 Golikov A. Цитатакоторые нужно парсить "на лету", т... Apr 16 2015, 07:26 mantech Цитата(Golikov A. @ Apr 16 2015, 10:26) Э... Apr 16 2015, 16:42 Golikov A. ЦитатаТогда объясните алгоритм приема пакета с фиф... Apr 16 2015, 17:06 mantech Цитата(Golikov A. @ Apr 16 2015, 20:06) F... Apr 16 2015, 18:31  den_po Цитата(mantech @ Apr 16 2015, 23:31) Хоро... Apr 16 2015, 18:48 Golikov A. ЦитатаПринимаю пакет, фифо настроен на 16 байт, а ... Apr 17 2015, 05:11 den_po Цитата(Golikov A. @ Apr 17 2015, 10:11) А... Apr 17 2015, 05:37 Golikov A. Если фифо железное, то глубина фифо определена жес... Apr 17 2015, 05:57 Golikov A. А еще любое прерывание - это сброс всех конвейеров... Apr 17 2015, 11:19 Эдди Если кому интересно, можно глянуть на систему упра... Apr 23 2015, 09:47 drozel А позвольте некропостнуть и вступить в полемику по... Oct 6 2015, 04:10 mantech Цитата(drozel @ Oct 6 2015, 07:10) Объясн... Oct 6 2015, 06:27 Эдди Вкратце: CUBE — признак идиота. Это как ардуйня. Т... Oct 6 2015, 05:43 drozel Цитата(Эдди @ Oct 6 2015, 11:43) Вкратце:... Oct 6 2015, 05:46 Golikov A. Вот вам на пальцах:
Ну берем SPI, настраиваем по ... Oct 6 2015, 06:28 mantech Цитата(Golikov A. @ Oct 6 2015, 09:28) К ... Oct 6 2015, 06:34  scifi Цитата(mantech @ Oct 6 2015, 09:34) Но ИМ... Oct 6 2015, 07:17   mantech Цитата(scifi @ Oct 6 2015, 10:17) Конечно... Oct 6 2015, 07:30   drozel Цитата(scifi @ Oct 6 2015, 13:17) +1. Зап... Oct 6 2015, 08:18    ViKo Цитата(drozel @ Oct 6 2015, 11:18) Код не... Oct 6 2015, 08:49 SasaVitebsk Мне кажется пример для UART вы неудачный выбрали. ... Oct 6 2015, 07:11 Golikov A. ЦитатаДак так и получается, если делать не один пр... Oct 6 2015, 10:58 _Pasha Сабж нормальный. Но API в некоторых местах не нрав... Oct 6 2015, 12:01 drozel Цитата(_Pasha @ Oct 6 2015, 18:01) dma - ... Oct 7 2015, 03:28  _Pasha Цитата(drozel @ Oct 7 2015, 06:28) Ну так... Oct 7 2015, 04:45 drozel Люди, помогите с либой.
Пытаюсь завести USB CDC с ... Oct 8 2015, 09:24 SasaVitebsk Цитата(drozel @ Oct 8 2015, 12:24) Что пр... Oct 8 2015, 10:34 drozel Цитата(SasaVitebsk @ Oct 8 2015, 16:34) В... Oct 8 2015, 16:41 _Pasha usbd_device *usbd_init
возвращает указатель на sta... Oct 8 2015, 18:53 drozel Да, уже нашел, спасибо. Просто непривычно: вместо ... Oct 9 2015, 01:57 esaulenka Цитата(drozel @ Oct 9 2015, 04:57) Да, уж... Oct 9 2015, 09:11 drozel Почти мигрировал с stdlib и cube на сабж.
Остался ... Oct 12 2015, 11:10 _Pasha Цитата(drozel @ Oct 12 2015, 14:10) Почти... Oct 12 2015, 11:40  drozel Цитата(_Pasha @ Oct 12 2015, 17:40) это с... Oct 12 2015, 11:55   _Pasha RE: libopencm3 Oct 12 2015, 12:14    drozel Цитата(_Pasha @ Oct 12 2015, 18:14) держи... Oct 13 2015, 03:33     _Pasha Цитата(drozel @ Oct 13 2015, 06:33) Спаси... Oct 13 2015, 04:58      drozel Цитата(_Pasha @ Oct 13 2015, 10:58) я не ... Oct 13 2015, 07:58       Эдди Цитата(drozel @ Oct 13 2015, 10:58) Если ... Oct 13 2015, 08:26        drozel Цитата(Эдди @ Oct 13 2015, 14:26) Кодls l... Oct 13 2015, 08:35 esaulenka Цитата(drozel @ Oct 12 2015, 14:10) Где ф... Oct 12 2015, 12:43  drozel Цитата(esaulenka @ Oct 12 2015, 18:43) Я ... Oct 12 2015, 17:14 Эдди Быстрее по даташиту с регистрами разобраться, неже... Oct 12 2015, 18:14 Golikov A. ЦитатаКак сказать.. GCC я никогда не пользовался, ... Oct 13 2015, 08:39
2 страниц
1 2 >
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0
|
|
|