-
- Недавно подымал тему с CH32V303. У которого внешняя шина глючит на нечотные полуслова. Разрешилось только так, пришлось ваять функцыю на чтение памяти: mse homjak(300 знак., 31.12.2024 17:18)
- Не... это понятно. Непонятно, почему нет какой-нить директивы, типа
#if-#endif только "#выкл-#вкл" оптимизаццыю. - mse homjak(26.12.2024 16:48)
- Зачем вкл/выкл? Вы просто напишите корректный код, а не с
"undefined behavior", как в случае данных, меняемых вне контекста.
А так - да, когда у школьника код глючит, так он оптимизацию
выключает - говорит, помогает. - Nikolay_Po(26.12.2024 17:23)
- А если у меня данные меняются вне контекста? - mse homjak(26.12.2024 17:45)
- Ну просто же. В том файле где меняются вне контекста - volatile, в
остальных без оного. Например при неприоритетной системе
прерываний, в файле прерывания определяем без volatile, в остальных файлах с volatile. А еще лучше использовать гетер, и волатильную
переменную не светить по всему проекту. Например так IBAH(439 знак., 26.12.2024 19:18)
- Ещё лучше исползовать локальную копию volatile там, где код в прерывании либо прерывания временно запрещены. - vpv.vpv(27.12.2024 06:55)
- Ну, скажэм так, зачем нужна переменная в прерывании, для передачи
данных из внешнего порта, если её нельзя пользовать в проекте? Т.е.
только волатильность. mse homjak(417 знак., 26.12.2024 19:55)
- Это АВР? 8бит? Волатильность не только оптимизация, это еще и
должно быть атомарное чтение - IBAH(26.12.2024 20:10)
- Не... Там даные идут регулярно и с запасом по времени. Т.е.
атомарность чтения соблюдать не надо. Об этом подумано изначально. - mse homjak(26.12.2024 20:23)
- Ну как не надо? два байта за одну команду не переслать, а если
модификация произойдет после чтение первого байта? - IBAH(26.12.2024 20:40)
- Месье намекает, что к моменту следующей модификации, его код из
main(), уже всё закончит и модификация ни на что не повлияет. А
после модификации будет поднят флаг и всё спокойно обработается
снова и завершиться раньше, чем наступит следующее обновление. - Nikolay_Po(26.12.2024 20:56)
- а к моменту первой модификации? - IBAH(26.12.2024 21:01)
- У ТС нет проблем с первой модификацией. - Nikolay_Po(26.12.2024 21:06)
- Хужэ того, если не будет успевать, то устройство принципиально неработоспособно. - mse homjak(26.12.2024 21:22)
- У ТС нет проблем с первой модификацией. - Nikolay_Po(26.12.2024 21:06)
- а к моменту первой модификации? - IBAH(26.12.2024 21:01)
- Месье намекает, что к моменту следующей модификации, его код из
main(), уже всё закончит и модификация ни на что не повлияет. А
после модификации будет поднят флаг и всё спокойно обработается
снова и завершиться раньше, чем наступит следующее обновление. - Nikolay_Po(26.12.2024 20:56)
- Ну как не надо? два байта за одну команду не переслать, а если
модификация произойдет после чтение первого байта? - IBAH(26.12.2024 20:40)
- Не... Там даные идут регулярно и с запасом по времени. Т.е.
атомарность чтения соблюдать не надо. Об этом подумано изначально. - mse homjak(26.12.2024 20:23)
- Во-во. Поэтому всегда тщательно анализируйте, какие переменные внутри контекста, а какие - из прерываний. И назначайте соответствующие квалификаторы. Я при каждом ревью кода внимательно смотрю, вплоть до составления списка, какие переменные у меня обновляются или вычитываются вне контекста. И объявляю их волатильными. Nikolay_Po(267 знак., 26.12.2024 20:01)
- Это АВР? 8бит? Волатильность не только оптимизация, это еще и
должно быть атомарное чтение - IBAH(26.12.2024 20:10)
- В общем, вредный совет насчёт там волатильная, а сям - нет. Когда-то так и делал. Нюанс в том, что запись тоже оптимизируется. Поэтому если в контексте, допустим, прерывания, запись в неволатильную память на этот контекст не влияет, она может быть упразднена. Nikolay_Po(290 знак., 26.12.2024 19:39)
- Значит, обращайтесь к ним с модификатором volatile. Если есть
уверенность, что на конкретном участке выполнения, значение
меняться не будет, то, чтобы не блокировать оптимизацию,
используйте временную не-волатильную переменную или просто
приведение типа к не-волатильному. - Nikolay_Po(26.12.2024 19:06)
- Тут неприятность возникла исключительно как частный случай. mse homjak(184 знак., 26.12.2024 20:01)
- Ну просто же. В том файле где меняются вне контекста - volatile, в
остальных без оного. Например при неприоритетной системе
прерываний, в файле прерывания определяем без volatile, в остальных файлах с volatile. А еще лучше использовать гетер, и волатильную
переменную не светить по всему проекту. Например так IBAH(439 знак., 26.12.2024 19:18)
- А если у меня данные меняются вне контекста? - mse homjak(26.12.2024 17:45)
- Как это нет? Вы плохо искали, наверное. - SciFi(26.12.2024 16:51)
- Зачем вкл/выкл? Вы просто напишите корректный код, а не с
"undefined behavior", как в случае данных, меняемых вне контекста.
А так - да, когда у школьника код глючит, так он оптимизацию
выключает - говорит, помогает. - Nikolay_Po(26.12.2024 17:23)
- Немного расширю первый пункт. Хорошо спроектированная программа не
нуждается в volatile. - IBAH(26.12.2024 14:49)
- Гы. У меня все программы просто идеальны. Иду за пивом, тащась от собственной крути. Бapбoc(57 знак., 26.12.2024 16:03)
- Подтверждаю. Идеальной программе не нужна аппаратура. Нет volatile-
регистровадресов памятипортов периферии. Поэтому volatile - да, не нужны. - Nikolay_Po(26.12.2024 16:01)- Это конечно передергивание. Я имел ввиду немного другое. Нужно
читать-писать из переменных и регистров ВВ таким образом, чтобы не
требовался модификатор volatile. Хорошим примером является FIFO буфер UART, нет
необходимости объявлять указатели головы/хвоста и регистр ВВ Уарт
волатильными, не смотря на то, что они меняется вне
контекста. - IBAH(26.12.2024 16:19)
- Если что, без volatile нет гарантии, что порядок доступа к
переменным не будет изменён. Это бывает реже, чем кеширование,
поэтому и баг будете искать дольше. - SciFi(26.12.2024 19:47)
- а как это изменение порядка доступа к переменным? то есть читаю А,
читаю В, а по факту может быть наоборот? - IBAH(26.12.2024 20:45)
- Так точно. Сам такое видел. - SciFi(26.12.2024 21:30)
- Интересно узнать, на каком процессоре? - IBAH(26.12.2024 21:49)
- На любом, лишь бы компилятор был современный, навороченный. Nikolay_Po(1005 знак., 26.12.2024 22:46)
- У нас тут Cortex-M обычно, вот он и был. - SciFi(26.12.2024 22:34)
- Интересно узнать, на каком процессоре? - IBAH(26.12.2024 21:49)
- Так точно. Сам такое видел. - SciFi(26.12.2024 21:30)
- а как это изменение порядка доступа к переменным? то есть читаю А,
читаю В, а по факту может быть наоборот? - IBAH(26.12.2024 20:45)
- Так у вас получится сделать
одинконечный автомат с одним приоритетом задач. Что-то более сложное, с разными приоритетами задач, вынудит вас использовать volatile или скрыть это в ОСРВ, которая внутри пользуется volatile-источниками и приёмниками данных. - Nikolay_Po(26.12.2024 17:25)
- Если что, без volatile нет гарантии, что порядок доступа к
переменным не будет изменён. Это бывает реже, чем кеширование,
поэтому и баг будете искать дольше. - SciFi(26.12.2024 19:47)
- Это конечно передергивание. Я имел ввиду немного другое. Нужно
читать-писать из переменных и регистров ВВ таким образом, чтобы не
требовался модификатор volatile. Хорошим примером является FIFO буфер UART, нет
необходимости объявлять указатели головы/хвоста и регистр ВВ Уарт
волатильными, не смотря на то, что они меняется вне
контекста. - IBAH(26.12.2024 16:19)