Работа с регистрами

Ардуинщики всех стран - объединяйтесь! В этом форуме, конечно.
Аватара пользователя
BOB51
Друг Кота
Сообщения: 15545
Зарегистрирован: Вт мар 16, 2010 22:02:27
Откуда: ДОНЕЦК

Re: Работа с регистрами

Сообщение BOB51 »

Кольцевой буфер...
Штука интересная... и возможных решений достаточно много.
8)
roman.com
Друг Кота
Сообщения: 9147
Зарегистрирован: Вт мар 13, 2012 12:16:13
Откуда: .ru

Re: Работа с регистрами

Сообщение roman.com »

при чём тут кольцевой буфер... это буфер FIFO
Reflector
Поставщик валерьянки для Кота
Сообщения: 2089
Зарегистрирован: Вс июн 19, 2016 09:32:03

Re: Работа с регистрами

Сообщение Reflector »

[uquote="roman.com",url="/forum/viewtopic.php?p=4059196#p4059196"]при чём тут кольцевой буфер... это буфер FIFO[/uquote]
Т.е. у тебя в программе идет обращение к внешней памяти? И какой размер этого FIFO?
roman.com
Друг Кота
Сообщения: 9147
Зарегистрирован: Вт мар 13, 2012 12:16:13
Откуда: .ru

Re: Работа с регистрами

Сообщение roman.com »

какая ещё внешняя память... это внутренняя ОЗУ AVR.

STS - инструкция Запись SRAM AVR.
LDS - инструкция Читаем SRAM AVR.
инструкции AVR.jpg
(100.89 КБ) 198 скачиваний
Тут что никто на Ассемблере инструкции не писал что ли))
Reflector писал(а):И какой размер этого FIFO?
Да любой))
До 2 килобайта для AVR типа ATmega328 ))
SRAM AVR.jpg
(92.17 КБ) 209 скачиваний
:tea:
Никто так и не ответил на простой вопрос...
STM может так же как AVR работать через инструкции или нет ???
:tea:
Reflector
Поставщик валерьянки для Кота
Сообщения: 2089
Зарегистрирован: Вс июн 19, 2016 09:32:03

Re: Работа с регистрами

Сообщение Reflector »

[uquote="roman.com",url="/forum/viewtopic.php?p=4059232#p4059232"]какая ещё внешняя память... это внутренняя ОЗУ AVR.[/uquote]
Ясно, значит это типа однобайтовое FIFO :) Если читать значение считанное с порта в ячейку памяти, сразу из нее читать и выводить в другой порт, то на G0 получится тоже 8 тактов для 140 MHz:
Спойлер

Код: Выделить всё

int i = 1000;
while(i--)
{
	volatile uint32_t fifo = GPIOB->IDR;
	GPIOC->ODR = fifo;
}


ldr r2, [r0, #16]
subs r3, #1 
str r2, [sp, #52]
ldr r2, [sp, #52]
str r2, [r1, #20]
cmp r3, #0 
bne.n 0x800019fe
Именно такой цикл выполняется за 10 тактов, но там 2 команды для счетчика без которого точно замерять число тактов проблематично, т.к. помимо конвеера у мк еще есть небольшой кеш инструкций и нужно учитывать латентность флеша которая разная для разных частот. Итого учитывая больший потенциал разгона код выполняется быстрее в ~5 раз на одном из самых простых STM32.
parovoZZ
Мудрый кот
Сообщения: 1759
Зарегистрирован: Пт июн 01, 2018 07:28:45

Re: Работа с регистрами

Сообщение parovoZZ »

Большая часть современной периферии 3-х вольтовая
это так
быстродействующие коммутаторы...
обработчики потокового аудио и видео...
внешняя ОЗУ на МК...
это всё делается на ПЛИС.
Да и АВРки уже совсем иные пошли, весьма отличающиеся от "стандартных"...
Они всегда были разные. AtXMega, AVR32...
Кстати... совсем про ПИКи подзабыли
Пики не являются чем-то универсальным. Там под каждую задачу есть свой пик. Иногда, этот самый пик и заменить нечем из-за специфической периферии.
diplodok
Мудрый кот
Сообщения: 1762
Зарегистрирован: Чт авг 10, 2017 20:57:51

Re: Работа с регистрами

Сообщение diplodok »

roman.com писал(а):программа буфер FIFO
roman.com писал(а):это буфер FIFO
и как, примерно, делается FIFO
roman.com
Друг Кота
Сообщения: 9147
Зарегистрирован: Вт мар 13, 2012 12:16:13
Откуда: .ru

Re: Работа с регистрами

Сообщение roman.com »

diplodok писал(а):и как, примерно, делается FIFO
Только ушёл от Си на Ассемблер... и вот опять всё сначала))
parovoZZ писал(а):это всё делается на ПЛИС.
Угу)) Сейчас сбегаю за ПЛИС ))
Reflector писал(а):Если читать значение считанное с порта в ячейку памяти, сразу из нее читать и выводить в другой порт, то на G0 получится тоже 8 тактов для 140 MHz
140 MHz
А вот это уже интересно))
:tea:
Reflector писал(а):там 2 команды для счетчика без которого точно замерять число тактов проблематично
Не понял...
Reflector писал(а):помимо конвеера у мк еще есть небольшой кеш инструкций и нужно учитывать латентность флеша которая разная для разных частот.
:shock:
У AVR нет никакого кеш инструкций... И флеш не зависит от частоты...
AVR просто берёт инструкции из флеша и выполняет их )) Читает/Записывает регистры/порты.
А результат выполнения инструкций в регистре статуса.
Screenshot_1.jpg
(60.95 КБ) 190 скачиваний
:roll:

кеш инструкций... Это только у STM так ? Это уже что-то сложное пошло... До этого я ещё не дошёл... ))
:roll:
Аватара пользователя
BOB51
Друг Кота
Сообщения: 15545
Зарегистрирован: Вт мар 16, 2010 22:02:27
Откуда: ДОНЕЦК

Re: Работа с регистрами

Сообщение BOB51 »

Скорее речь о конвеерной предвыборке команд из ПЗУ...
:roll:
roman.com
Друг Кота
Сообщения: 9147
Зарегистрирован: Вт мар 13, 2012 12:16:13
Откуда: .ru

Re: Работа с регистрами

Сообщение roman.com »

Reflector писал(а):2 команды для счетчика без которого точно замерять число тактов проблематично
зачем там счётчик ? а низя просто читать инструкции подряд и просто их выполнять...
BOB51 писал(а):предвыборке команд из ПЗУ...
а какая там предвыборка ?

На примере простой программы (см. выше):

Например при записи регистра порта-
OUT PORTD, R0 // Запись Port D -1 такт
По идеи процессор просто берёт инструкции из флеша и сразу их выполняет. Т.е. записывает регистр порта (включает порт).

Например при чтении регистра порта-
IN R0, PINC // Читаем Port С -1 такт
STS _x, R0 // Запись SRAM -2 такт
По идеи процессор читает регистр порта и сразу пишет в ОЗУ.
Screenshot_1.jpg
(117.59 КБ) 169 скачиваний
И далее инструкции по списку...))

Сколько на это все эти инструкции уходит тактов проца... фиг его знает))
:tea:
parovoZZ
Мудрый кот
Сообщения: 1759
Зарегистрирован: Пт июн 01, 2018 07:28:45

Re: Работа с регистрами

Сообщение parovoZZ »

По идеи процессор просто берёт инструкции из флеша и сразу их выполняет.
Это на медленных AVR так можно. А на быстрых камнях так не получается - флеш не сразу отдаёт данные, а через определённый интервал.
Программу можно загрузить целиком в ОЗУ (как это делает ESP) и выполнять оттуда. Но такое можно на фон неймане. А у АВР гарвард - там такое нельзя никак.
Reflector
Поставщик валерьянки для Кота
Сообщения: 2089
Зарегистрирован: Вс июн 19, 2016 09:32:03

Re: Работа с регистрами

Сообщение Reflector »

[uquote="roman.com",url="/forum/viewtopic.php?p=4059371#p4059371"]У AVR нет никакого кеш инструкций... И флеш не зависит от частоты...[/uquote]
AVR простой и работает на низких частотах, потому дополнительные такты ожидания для медленного флеша не требуются. У STM32 есть буфер предвыборки в который заранее читаются сразу несколько инструкций чтобы нивелировать тормоза флеша, у некоторых кортексов работающих на частотах порядка 500Mhz чтение происходит по целой 256-ти битной шине... Также может быть кеш инструкций и данных, например, в вышеприведенном коде первый раз при переходе в начало цикла инструкции там находящиеся попадут в кеш и последующие разы переход будет выполняться за 1 такт, иначе придется сбросить конвеер и дождаться чтения инструкций из флеша, а это 2 такта требуемых на заполнение конвеера плюс само чтение с учетом тактов ожидания флеша которые зависят от частоты, потому если постоянно не пишешь на ассме для одной серии на одной частоте, то вручную подсчитать количество тактов не так просто, в итоге я добавил счетчик и замерял при помощи таймера сколько выполняются 1000 итераций... У более продвинутых кортексов может работать сразу два конвеера, читаться сразу два 32-х битных значения из RAM и выполняться две команды за такт, там вообще писать на ассме подсчитывая такты гиблое дело(при пошаговой отладке будет показывать не совсем то, что происходит на полной скорости)... Но есть серии где код можно выполнять из CCM RAM, тогда многие проблемы пропадают и на любой частоте код выполняется максимально быстро.
Аватара пользователя
Мурик
Друг Кота
Сообщения: 3383
Зарегистрирован: Пн окт 11, 2010 19:00:08

Re: Работа с регистрами

Сообщение Мурик »

roman.com писал(а):140 MHz А вот это уже интересно))
А как насчет 480 МГц? https://www.st.com/en/microcontrollers- ... 750vb.html
В добавок 2 МБ флеша и 1 МБ ОЗУ.
Только это МК не для подсчета каждого такта. К ядре есть кеши инструкций и данных, конвейер и др. что затрудняет точный подсчет времени до такта.
roman.com писал(а):И флеш не зависит от частоты
Потому что частоты низкие. Когда речь идет о сотнях МГц, из флеша не успевает производится чтение на такой скорости и применяются различные методы позволяющие снизить скорость чтения не снижая производительность МК.
roman.com
Друг Кота
Сообщения: 9147
Зарегистрирован: Вт мар 13, 2012 12:16:13
Откуда: .ru

Re: Работа с регистрами

Сообщение roman.com »

parovoZZ писал(а):Программу можно загрузить целиком в ОЗУ (как это делает ESP) и выполнять оттуда.
а ОЗУ не тормозит ?
ESP вроде загружает пользовательские программы из внешнего EEPROM...
Reflector писал(а):если постоянно не пишешь на ассме для одной серии на одной частоте, то вручную подсчитать количество тактов не так просто
Reflector писал(а):придется сбросить конвейер и дождаться чтения инструкций из флеша
:roll:
Мурик писал(а):К ядре есть кеши инструкций и данных, конвейер и др. что затрудняет точный подсчет времени до такта.
:roll:
Короче... пипец)) Ну я примерно так и думал... что не всё так просто))
Короче надо подробней всё это изучить...
:tea:
parovoZZ
Мудрый кот
Сообщения: 1759
Зарегистрирован: Пт июн 01, 2018 07:28:45

Re: Работа с регистрами

Сообщение parovoZZ »

ESP вроде загружает пользовательские программы из внешнего EEPROM...
Так и ARM можно заставить делать так же.
Morroc
Друг Кота
Сообщения: 19494
Зарегистрирован: Чт фев 20, 2014 18:57:55

Re: Работа с регистрами

Сообщение Morroc »

[uquote="roman.com",url="/forum/viewtopic.php?p=4059806#p4059806"]Короче... пипец)) Ну я примерно так и думал... что не всё так просто))
Короче надо подробней всё это изучить...
:tea:[/uquote]
Да нафиг этот асм и подсчет тактов :) Возьмите пожирнее что нибудь.
"Вся военная пропаганда, все крики, ложь и ненависть исходят от людей, которые на эту войну не пойдут !" / Джордж Оруэлл /
"Война - это,когда за интересы других,гибнут совершенно безвинные люди." / Уинстон Черчилль /
roman.com
Друг Кота
Сообщения: 9147
Зарегистрирован: Вт мар 13, 2012 12:16:13
Откуда: .ru

Re: Работа с регистрами

Сообщение roman.com »

есть целый список узкоспециализированных задач...
пожирнее что нибудь типа Intel Core i9 10 x 3600 МГц ?)) Этот справится ))
а на сколько хватит одной батарейки ? на 5 минут ? ))
:tea:
Аватара пользователя
Мурик
Друг Кота
Сообщения: 3383
Зарегистрирован: Пн окт 11, 2010 19:00:08

Re: Работа с регистрами

Сообщение Мурик »

Нужно по максимуму перекладывать работу на железо, тогда не придется подсчитывать такты команд. В идеале процессор только конфигурирует и обслуживает железо.
Аватара пользователя
BOB51
Друг Кота
Сообщения: 15545
Зарегистрирован: Вт мар 16, 2010 22:02:27
Откуда: ДОНЕЦК

Re: Работа с регистрами

Сообщение BOB51 »

В то же время никто не запрещает использование внешних специализированных микросхем сопровождения.
В том числе и самодельных.
Да и "рассыпухи" средней степени интеграции в избытке.
Попривыкали уже все в одном "клопе" делать.
:wink:
roman.com
Друг Кота
Сообщения: 9147
Зарегистрирован: Вт мар 13, 2012 12:16:13
Откуда: .ru

Re: Работа с регистрами

Сообщение roman.com »

Можно делать всё на "рассыпухи"
1.jpg
(103.66 КБ) 167 скачиваний
А можно сделать всё на одном "клопе"
2.jpg
(53.15 КБ) 161 скачивание
И т.д. и т.п. ))
Что проще дешевле быстрей... каждый решает сам))
:tea:
Ответить

Вернуться в «Arduino»