реклама на сайте
подробности

 
 
> Как сделать идеологически выдержанно, "в стиле РТОС"
nanorobot
сообщение Dec 9 2016, 11:08
Сообщение #1


Местный
***

Группа: Участник
Сообщений: 244
Регистрация: 29-02-08
Пользователь №: 35 503



Дивайс состоит из двух узлов на STM32 связанных по SPI. Программа как для мастера так и для слейва пишется с использованием RTOS: мастер CortexM4/ChibiOS, слейв - CortexM0/nil(облегченный вариант ChibiOS). Слейв, в частности формирует слово состояния - набор битов, которое передается мастеру, а так же используется самой программой слейва. Причем биты могут использоваться в разных тредах(процессах). С точки зрения парадигмы RTOS они являются об'ектами синхронизации процессов. В этом случае они должны иметь тип BinarySemaphore с другой стороны для передачи слова состояния мастеру они(биты) должны быть упакованы в переменную типа uint16_t. Сейчас у меня используется union одно поле которого битовая структура, другое поле uint16_t. Покамест УМВР, но беспокоят возможные проблемы из за отхода от парадигмы RTOS. Напрашивается вариант: любое бращение к битам состояния защищать от коллизий доступа с помощью мютекса, но nil их не имеет, а использовать для слейва полную ChibiOs - тяжеловато будет, там и требования к скорости обработки повыше и процессор послабее. Что посоветуют знатоки?

Сообщение отредактировал nanorobot - Dec 9 2016, 12:07
Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов
novikovfb
сообщение Dec 9 2016, 11:33
Сообщение #2


Знающий
****

Группа: Участник
Сообщений: 518
Регистрация: 29-09-11
Пользователь №: 67 450



Цитата(nanorobot @ Dec 9 2016, 14:08) *
Напрашивается вариант: любое бращение к битам состояния защищать от коллизий доступа с помощью мютекса, но nil их не имеет

а что он имеет?
Напрашивается вместо битов признаки разнести по разным байтам и иметь доступ к ним без коллизий, если, конечно, между битами нет взаимосвязей.
Go to the top of the page
 
+Quote Post
nanorobot
сообщение Dec 9 2016, 11:42
Сообщение #3


Местный
***

Группа: Участник
Сообщений: 244
Регистрация: 29-02-08
Пользователь №: 35 503



Цитата(novikovfb @ Dec 9 2016, 17:33) *
а что он имеет?
Напрашивается вместо битов признаки разнести по разным байтам и иметь доступ к ним без коллизий, если, конечно, между битами нет взаимосвязей.


Это ничего не даст, пмсм.. Кроме того это никак не снимет необходимости упаковывать "байтовые" биты в uint16_t для отсылки мастеру. С такимже успехом можно опросить полтора десятка бинарных семафоров и собрать из них uint16_t и парадигма не нарушится. Это самый очевидный и громоздкий способ. Кроме того байты здесь 32 битовые wink.gif

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

Сообщение отредактировал nanorobot - Dec 9 2016, 11:50
Go to the top of the page
 
+Quote Post
novikovfb
сообщение Dec 9 2016, 11:56
Сообщение #4


Знающий
****

Группа: Участник
Сообщений: 518
Регистрация: 29-09-11
Пользователь №: 67 450



Цитата(nanorobot @ Dec 9 2016, 14:42) *
Это ничего не даст, пмсм..

Это позволит изменять разные признаки в разных тредах не боясь при попытке одновременной модификации двух признаков (первый начал менять, прерывание, второй начал и закончил, вернулся в первый закончил и записал в ячейку только свой результат, стерев результат второго треда.
Цитата(nanorobot @ Dec 9 2016, 14:42) *
Кроме того это никак не снимет необходимости упаковывать "байтовые" биты в uint16_t для отсылки мастеру.

да, но при упаковке можно будет тупо пройтись и снять слепок в текущем состоянии. Опять же, если нет взаимозависимостей между битами в упакованном слове для мастера.

Насколько я понимаю, запись байта - атомарная операция в микропроцессоре, а модификация бита во многих реализациях идет через временное значение в регистре (и Cortex M0 - в их числе).
Go to the top of the page
 
+Quote Post
nanorobot
сообщение Dec 9 2016, 12:18
Сообщение #5


Местный
***

Группа: Участник
Сообщений: 244
Регистрация: 29-02-08
Пользователь №: 35 503



Цитата(novikovfb @ Dec 9 2016, 17:56) *
Это позволит изменять разные признаки в разных тредах не боясь при попытке одновременной модификации двух признаков (первый начал менять, прерывание, второй начал и закончил, вернулся в первый закончил и записал в ячейку только свой результат, стерев результат второго треда.

ну здраво в общем. Но наверное использовать массив бинарных семафоров будет более корректно...
И да интересно, еслипроцессор имеет bit-banding для SRAM - компилятор будет его использовать для изменения отдельных битов в структуре? не думаю...

Цитата(AHTOXA @ Dec 9 2016, 17:40) *
Достаточно обеспечить атомарность доступа. Для этого можно просто запрещать прерывания на время записи переменной.



почему то напрягает лишний раз прерывания запрещать. Такой вот предрассудок...


Сообщение отредактировал nanorobot - Dec 9 2016, 12:17
Go to the top of the page
 
+Quote Post

Сообщений в этой теме
- nanorobot   Как сделать идеологически выдержанно, "в стиле РТОС"   Dec 9 2016, 11:08
- - AHTOXA   Цитата(nanorobot @ Dec 9 2016, 16:08) Нап...   Dec 9 2016, 11:40
- - zltigo   Цитата(AHTOXA @ Dec 9 2016, 13:40) Достат...   Dec 9 2016, 13:27
|- - nanorobot   Цитата(zltigo @ Dec 9 2016, 19:27) Именно...   Dec 9 2016, 15:14
|- - zltigo   Цитата(nanorobot @ Dec 9 2016, 17:14) Есл...   Dec 9 2016, 16:00
|- - jcxz   Цитата(nanorobot @ Dec 9 2016, 18:14) Кас...   Dec 13 2016, 21:52
|- - zltigo   Цитата(jcxz @ Dec 13 2016, 23:52) Вы отст...   Dec 13 2016, 22:32
|- - AlexandrY   Цитата(jcxz @ Dec 13 2016, 23:52) Хотя в ...   Dec 14 2016, 08:35
|- - zltigo   Цитата(AlexandrY @ Dec 14 2016, 10:35) Хо...   Dec 14 2016, 09:46
|- - jcxz   Цитата(AlexandrY @ Dec 14 2016, 11:35) Та...   Dec 19 2016, 14:18
- - AlexandrY   Цитата(nanorobot @ Dec 9 2016, 13:08) Нап...   Dec 9 2016, 15:55
- - nanorobot   Цитата(AlexandrY @ Dec 9 2016, 21:55) Воо...   Dec 9 2016, 16:07
- - zltigo   Цитата(nanorobot @ Dec 9 2016, 18:07) не ...   Dec 9 2016, 17:24
|- - nanorobot   Цитата(zltigo @ Dec 9 2016, 23:24) Но тем...   Dec 9 2016, 17:58
|- - AlexandrY   Цитата(nanorobot @ Dec 9 2016, 19:58) Что...   Dec 9 2016, 18:07
||- - nanorobot   Цитата(AlexandrY @ Dec 10 2016, 00:07) Та...   Dec 9 2016, 18:14
||- - AHTOXA   Если отвлечься от вопроса, зачем мастеру знать сос...   Dec 9 2016, 20:19
|||- - nanorobot   Цитата(AHTOXA @ Dec 10 2016, 02:19) Если ...   Dec 9 2016, 21:35
|||- - zltigo   Цитата(nanorobot @ Dec 9 2016, 23:35) Тем...   Dec 10 2016, 08:16
||||- - nanorobot   Цитата(zltigo @ Dec 10 2016, 14:16) Плохо...   Dec 10 2016, 09:30
||||- - AlexandrY   Цитата(nanorobot @ Dec 10 2016, 11:30) Кр...   Dec 10 2016, 20:28
||||- - zltigo   Цитата(nanorobot @ Dec 10 2016, 11:30) По...   Dec 10 2016, 21:03
||||- - AlexandrY   Цитата(zltigo @ Dec 10 2016, 23:03) Это с...   Dec 10 2016, 22:32
||||- - zltigo   Цитата(AlexandrY @ Dec 11 2016, 00:32) Кс...   Dec 11 2016, 08:22
||||- - AlexandrY   Цитата(zltigo @ Dec 11 2016, 10:22) Посмо...   Dec 11 2016, 10:02
||||- - zltigo   Цитата(AlexandrY @ Dec 11 2016, 12:02) Но...   Dec 11 2016, 11:50
|||- - sanny444   Цитата(nanorobot @ Dec 9 2016, 21:35) Все...   Jul 13 2017, 06:55
||- - AlexandrY   Цитата(nanorobot @ Dec 9 2016, 20:14) Так...   Dec 9 2016, 21:15
|- - zltigo   Цитата(nanorobot @ Dec 9 2016, 19:58) Что...   Dec 9 2016, 20:33
- - AlexandrY   Цитата(nanorobot @ Dec 9 2016, 18:07) м.б...   Dec 9 2016, 17:25


Reply to this topicStart new topic
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0

 


RSS Текстовая версия Сейчас: 6th July 2025 - 18:37
Рейтинг@Mail.ru


Страница сгенерированна за 0.01457 секунд с 7
ELECTRONIX ©2004-2016