Штука интересная... и возможных решений достаточно много.
Работа с регистрами
Re: Работа с регистрами
Кольцевой буфер...
Штука интересная... и возможных решений достаточно много.

Штука интересная... и возможных решений достаточно много.
Re: Работа с регистрами
при чём тут кольцевой буфер... это буфер FIFO
Re: Работа с регистрами
[uquote="roman.com",url="/forum/viewtopic.php?p=4059196#p4059196"]при чём тут кольцевой буфер... это буфер FIFO[/uquote]
Т.е. у тебя в программе идет обращение к внешней памяти? И какой размер этого FIFO?
Т.е. у тебя в программе идет обращение к внешней памяти? И какой размер этого FIFO?
Re: Работа с регистрами
какая ещё внешняя память... это внутренняя ОЗУ AVR.
STS - инструкция Запись SRAM AVR.
LDS - инструкция Читаем SRAM AVR.
Тут что никто на Ассемблере инструкции не писал что ли))
Да любой))
До 2 килобайта для AVR типа ATmega328 ))

Никто так и не ответил на простой вопрос...
STM может так же как AVR работать через инструкции или нет ???

STS - инструкция Запись SRAM AVR.
LDS - инструкция Читаем SRAM AVR.
Тут что никто на Ассемблере инструкции не писал что ли))
Reflector писал(а):И какой размер этого FIFO?
Да любой))
До 2 килобайта для AVR типа ATmega328 ))

Никто так и не ответил на простой вопрос...
STM может так же как AVR работать через инструкции или нет ???

Re: Работа с регистрами
[uquote="roman.com",url="/forum/viewtopic.php?p=4059232#p4059232"]какая ещё внешняя память... это внутренняя ОЗУ AVR.[/uquote]
Ясно, значит это типа однобайтовое FIFO
Если читать значение считанное с порта в ячейку памяти, сразу из нее читать и выводить в другой порт, то на G0 получится тоже 8 тактов для 140 MHz:
Именно такой цикл выполняется за 10 тактов, но там 2 команды для счетчика без которого точно замерять число тактов проблематично, т.к. помимо конвеера у мк еще есть небольшой кеш инструкций и нужно учитывать латентность флеша которая разная для разных частот. Итого учитывая больший потенциал разгона код выполняется быстрее в ~5 раз на одном из самых простых STM32.
Ясно, значит это типа однобайтовое FIFO
Спойлер
Код: Выделить всё
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.
Re: Работа с регистрами
Большая часть современной периферии 3-х вольтовая
это так
быстродействующие коммутаторы...
обработчики потокового аудио и видео...
внешняя ОЗУ на МК...
это всё делается на ПЛИС.
Да и АВРки уже совсем иные пошли, весьма отличающиеся от "стандартных"...
Они всегда были разные. AtXMega, AVR32...
Кстати... совсем про ПИКи подзабыли
Пики не являются чем-то универсальным. Там под каждую задачу есть свой пик. Иногда, этот самый пик и заменить нечем из-за специфической периферии.
Re: Работа с регистрами
roman.com писал(а):программа буфер FIFO
roman.com писал(а):это буфер FIFO
и как, примерно, делается FIFO
Re: Работа с регистрами
diplodok писал(а):и как, примерно, делается FIFO
Только ушёл от Си на Ассемблер... и вот опять всё сначала))
parovoZZ писал(а):это всё делается на ПЛИС.
Угу)) Сейчас сбегаю за ПЛИС ))
Reflector писал(а):Если читать значение считанное с порта в ячейку памяти, сразу из нее читать и выводить в другой порт, то на G0 получится тоже 8 тактов для 140 MHz
140 MHz
А вот это уже интересно))
Reflector писал(а):там 2 команды для счетчика без которого точно замерять число тактов проблематично
Не понял...
Reflector писал(а):помимо конвеера у мк еще есть небольшой кеш инструкций и нужно учитывать латентность флеша которая разная для разных частот.
У AVR нет никакого кеш инструкций... И флеш не зависит от частоты...
AVR просто берёт инструкции из флеша и выполняет их )) Читает/Записывает регистры/порты.
А результат выполнения инструкций в регистре статуса.
кеш инструкций... Это только у STM так ? Это уже что-то сложное пошло... До этого я ещё не дошёл... ))
Re: Работа с регистрами
Скорее речь о конвеерной предвыборке команд из ПЗУ...

Re: Работа с регистрами
Reflector писал(а):2 команды для счетчика без которого точно замерять число тактов проблематично
зачем там счётчик ? а низя просто читать инструкции подряд и просто их выполнять...
BOB51 писал(а):предвыборке команд из ПЗУ...
а какая там предвыборка ?
На примере простой программы (см. выше):
Например при записи регистра порта-
OUT PORTD, R0 // Запись Port D -1 такт
По идеи процессор просто берёт инструкции из флеша и сразу их выполняет. Т.е. записывает регистр порта (включает порт).
Например при чтении регистра порта-
IN R0, PINC // Читаем Port С -1 такт
STS _x, R0 // Запись SRAM -2 такт
По идеи процессор читает регистр порта и сразу пишет в ОЗУ.
И далее инструкции по списку...))
Сколько на это все эти инструкции уходит тактов проца... фиг его знает))

Re: Работа с регистрами
По идеи процессор просто берёт инструкции из флеша и сразу их выполняет.
Это на медленных AVR так можно. А на быстрых камнях так не получается - флеш не сразу отдаёт данные, а через определённый интервал.
Программу можно загрузить целиком в ОЗУ (как это делает ESP) и выполнять оттуда. Но такое можно на фон неймане. А у АВР гарвард - там такое нельзя никак.
Re: Работа с регистрами
[uquote="roman.com",url="/forum/viewtopic.php?p=4059371#p4059371"]У AVR нет никакого кеш инструкций... И флеш не зависит от частоты...[/uquote]
AVR простой и работает на низких частотах, потому дополнительные такты ожидания для медленного флеша не требуются. У STM32 есть буфер предвыборки в который заранее читаются сразу несколько инструкций чтобы нивелировать тормоза флеша, у некоторых кортексов работающих на частотах порядка 500Mhz чтение происходит по целой 256-ти битной шине... Также может быть кеш инструкций и данных, например, в вышеприведенном коде первый раз при переходе в начало цикла инструкции там находящиеся попадут в кеш и последующие разы переход будет выполняться за 1 такт, иначе придется сбросить конвеер и дождаться чтения инструкций из флеша, а это 2 такта требуемых на заполнение конвеера плюс само чтение с учетом тактов ожидания флеша которые зависят от частоты, потому если постоянно не пишешь на ассме для одной серии на одной частоте, то вручную подсчитать количество тактов не так просто, в итоге я добавил счетчик и замерял при помощи таймера сколько выполняются 1000 итераций... У более продвинутых кортексов может работать сразу два конвеера, читаться сразу два 32-х битных значения из RAM и выполняться две команды за такт, там вообще писать на ассме подсчитывая такты гиблое дело(при пошаговой отладке будет показывать не совсем то, что происходит на полной скорости)... Но есть серии где код можно выполнять из CCM RAM, тогда многие проблемы пропадают и на любой частоте код выполняется максимально быстро.
AVR простой и работает на низких частотах, потому дополнительные такты ожидания для медленного флеша не требуются. У STM32 есть буфер предвыборки в который заранее читаются сразу несколько инструкций чтобы нивелировать тормоза флеша, у некоторых кортексов работающих на частотах порядка 500Mhz чтение происходит по целой 256-ти битной шине... Также может быть кеш инструкций и данных, например, в вышеприведенном коде первый раз при переходе в начало цикла инструкции там находящиеся попадут в кеш и последующие разы переход будет выполняться за 1 такт, иначе придется сбросить конвеер и дождаться чтения инструкций из флеша, а это 2 такта требуемых на заполнение конвеера плюс само чтение с учетом тактов ожидания флеша которые зависят от частоты, потому если постоянно не пишешь на ассме для одной серии на одной частоте, то вручную подсчитать количество тактов не так просто, в итоге я добавил счетчик и замерял при помощи таймера сколько выполняются 1000 итераций... У более продвинутых кортексов может работать сразу два конвеера, читаться сразу два 32-х битных значения из RAM и выполняться две команды за такт, там вообще писать на ассме подсчитывая такты гиблое дело(при пошаговой отладке будет показывать не совсем то, что происходит на полной скорости)... Но есть серии где код можно выполнять из CCM RAM, тогда многие проблемы пропадают и на любой частоте код выполняется максимально быстро.
Re: Работа с регистрами
А как насчет 480 МГц? https://www.st.com/en/microcontrollers- ... 750vb.htmlroman.com писал(а):140 MHz А вот это уже интересно))
В добавок 2 МБ флеша и 1 МБ ОЗУ.
Только это МК не для подсчета каждого такта. К ядре есть кеши инструкций и данных, конвейер и др. что затрудняет точный подсчет времени до такта.
Потому что частоты низкие. Когда речь идет о сотнях МГц, из флеша не успевает производится чтение на такой скорости и применяются различные методы позволяющие снизить скорость чтения не снижая производительность МК.roman.com писал(а):И флеш не зависит от частоты
Re: Работа с регистрами
parovoZZ писал(а):Программу можно загрузить целиком в ОЗУ (как это делает ESP) и выполнять оттуда.
а ОЗУ не тормозит ?
ESP вроде загружает пользовательские программы из внешнего EEPROM...
Reflector писал(а):если постоянно не пишешь на ассме для одной серии на одной частоте, то вручную подсчитать количество тактов не так просто
Reflector писал(а):придется сбросить конвейер и дождаться чтения инструкций из флеша
Мурик писал(а):К ядре есть кеши инструкций и данных, конвейер и др. что затрудняет точный подсчет времени до такта.
Короче... пипец)) Ну я примерно так и думал... что не всё так просто))
Короче надо подробней всё это изучить...

Re: Работа с регистрами
ESP вроде загружает пользовательские программы из внешнего EEPROM...
Так и ARM можно заставить делать так же.
Re: Работа с регистрами
[uquote="roman.com",url="/forum/viewtopic.php?p=4059806#p4059806"]Короче... пипец)) Ну я примерно так и думал... что не всё так просто))
Короче надо подробней всё это изучить...
[/uquote]
Да нафиг этот асм и подсчет тактов
Возьмите пожирнее что нибудь.
Короче надо подробней всё это изучить...
[/uquote]Да нафиг этот асм и подсчет тактов
"Вся военная пропаганда, все крики, ложь и ненависть исходят от людей, которые на эту войну не пойдут !" / Джордж Оруэлл /
"Война - это,когда за интересы других,гибнут совершенно безвинные люди." / Уинстон Черчилль /
"Война - это,когда за интересы других,гибнут совершенно безвинные люди." / Уинстон Черчилль /
Re: Работа с регистрами
есть целый список узкоспециализированных задач...
пожирнее что нибудь типа Intel Core i9 10 x 3600 МГц ?)) Этот справится ))
а на сколько хватит одной батарейки ? на 5 минут ? ))

пожирнее что нибудь типа Intel Core i9 10 x 3600 МГц ?)) Этот справится ))
а на сколько хватит одной батарейки ? на 5 минут ? ))

Re: Работа с регистрами
Нужно по максимуму перекладывать работу на железо, тогда не придется подсчитывать такты команд. В идеале процессор только конфигурирует и обслуживает железо.
Re: Работа с регистрами
В то же время никто не запрещает использование внешних специализированных микросхем сопровождения.
В том числе и самодельных.
Да и "рассыпухи" средней степени интеграции в избытке.
Попривыкали уже все в одном "клопе" делать.

В том числе и самодельных.
Да и "рассыпухи" средней степени интеграции в избытке.
Попривыкали уже все в одном "клопе" делать.
Re: Работа с регистрами
Можно делать всё на "рассыпухи"
А можно сделать всё на одном "клопе"
И т.д. и т.п. ))
Что проще дешевле быстрей... каждый решает сам))

А можно сделать всё на одном "клопе"
И т.д. и т.п. ))
Что проще дешевле быстрей... каждый решает сам))
