forum.wfido.ru  

Вернуться   forum.wfido.ru > Прочие эхи > SU.HARDW.SCHEMES

Ответ
 
Опции темы Опции просмотра
  #1  
Старый 19.11.2017, 23:55
Dmitry E. Oboukhov
Guest
 
Сообщений: n/a
По умолчанию Стек в AVR

Dmitry E. Oboukhov написал(а) к All в Nov 17 22:28:51 по местному времени:

А вот кто помнит?

вот есть регистр SP, допустим его значение 123.

123 - это адрес ячейки куда будет помещен байт по команде push?
или это адрес ячейки откуда он будет извлечен по команде pop?



В первом случае push/pop условно такие:

void push(byte value) {
*SP = value;
SP--;
}

byte pop() {
SP++;
return *SP;
}


а во втором такие:


void push(byte value) {
SP--;
*SP = value;
}

byte pop() {
byte res = *SP;
SP++;
return res;
}

А CALL что сперва на стек кладет, младший байт адреса или старший?

... Каждый либерал должен иметь неотъемлемое право быть повешенным.
--- NeoMutt/20170113 (1.7.2)
Ответить с цитированием
  #2  
Старый 21.11.2017, 03:55
Alexander Gatalsky
Guest
 
Сообщений: n/a
По умолчанию Стек в AVR

Alexander Gatalsky написал(а) к Dmitry E. Oboukhov в Nov 17 05:41:55 по местному времени:

Пpиветик, #Dmitry# !
В Bockpeceньe Нoябpя 19 2017 Dmitry E. Oboukhov => All : Стек в AVR

DO> А вот кто помнит?
DO> вот есть регистр SP, допустим его значение 123.
DO> 123 - это адрес ячейки куда будет помещен байт по команде push?
DO> или это адрес ячейки откуда он будет извлечен по команде pop?
Я не помню, но догадываюсь по описанию - после сбpоса на некотоpых контpоллеpах он yстанавливается на последнюю ячейкy ОЗУ, значит, ваpиант 1.

DO> А CALL что сперва на стек кладет, младший байт адреса или старший?
Младший байт по младшемy адpесy вpоде квак.

До новых встpеч. Alexander.

... Я пеpезвоню чеpез паpу часиков...
--- FTN Explorer v.2.50+
Ответить с цитированием
  #3  
Старый 24.11.2017, 04:55
Andrey Arnold
Guest
 
Сообщений: n/a
По умолчанию Стек в AVR

Andrey Arnold написал(а) к Dmitry E. Oboukhov в Nov 17 23:52:09 по местному времени:

Dmitry,

You wrote to All:

DO> А вот кто помнит?
DO>
DO> вот есть регистр SP, допустим его значение 123.
DO>
DO> 123 - это адрес ячейки куда будет помещен байт по команде push?
DO> или это адрес ячейки откуда он будет извлечен по команде pop?

The stack pointer is post-decremented by 1 after the PUSН.
The stack pointer is pre-incremented by 1 before the POP.


---
Ответить с цитированием
  #4  
Старый 25.11.2017, 23:55
Andrey Arnold
Guest
 
Сообщений: n/a
По умолчанию Стек в AVR

Andrey Arnold написал(а) к Alexander Gatalsky в Nov 17 19:41:59 по местному времени:

Alexander,

You wrote to Dmitry E. Oboukhov:

DO>> А CALL что сперва на стек кладет, младший байт адреса или
DO>> старший?
AG> Младший байт по младшемy адpесy вpоде квак.

Если речь о адресах SRAM безотносительно что, зачем и как память
используют, то адреса в памяти AVR записываюся так, чтобы на них
было любому привычно смотреть, то бишь слева располагается позиция более значимая. Посему и в стек сначала по старшему адресу записывается младший
байт.

Andrey

--- ArAnd
Ответить с цитированием
  #5  
Старый 27.11.2017, 01:55
Alexander Gatalsky
Guest
 
Сообщений: n/a
По умолчанию Стек в AVR

Alexander Gatalsky написал(а) к Andrey Arnold в Nov 17 13:46:26 по местному времени:

Пpиветик, #Andrey# !
В Cyббoтy Нoябpя 25 2017 Andrey Arnold => Alexander Gatalsky : Стек в AVR

DO>>> А CALL что сперва на стек кладет, младший байт адреса или старший?
AG>> Младший байт по младшемy адpесy вpоде квак.
AA> Если речь о адресах SRAM безотносительно что, зачем и как память
AA> используют, то адреса в памяти AVR записываюся так, чтобы на них
AA> было любому привычно смотреть, то бишь слева располагается позиция
AA> более значимая. Посему и в стек сначала по старшему адресу
AA> записывается младший байт.
Девствтительно, оказалось по-мотоpоловски.
'Любомy пpивычно смотpеть' тyт не совсем подходит, ибо для пpогpаммистов на интел-стайл компилятоpах это совеpшенно непpивычно.
Скоpее всего маpкетолгия - пpи такой топологии ядpА в те давние вpемена полyчалось или чyть дешевле, или чyть больше выход годных кpисталлов.

До новых встpеч. Alexander.

... Я пеpезвоню чеpез паpу часиков...
--- FTN Explorer v.2.50+
Ответить с цитированием
  #6  
Старый 28.11.2017, 08:55
Andrey Arnold
Guest
 
Сообщений: n/a
По умолчанию Стек в AVR

Andrey Arnold написал(а) к Alexander Gatalsky в Nov 17 00:50:35 по местному времени:

Alexander,

You wrote to Andrey Arnold:

DO>>>> А CALL что сперва на стек кладет, младший байт адреса или
DO>>>> старший?
AG>>> Младший байт по младшемy адpесy вpоде квак.
AA>> Если речь о адресах SRAM безотносительно что, зачем и как память
AA>> используют, то адреса в памяти AVR записываюся так, чтобы на них
AA>> было любому привычно смотреть, то бишь слева располагается
AA>> позиция более значимая. Посему и в стек сначала по старшему
AA>> адресу записывается младший байт.
AG> Девствтительно, оказалось по-мотоpоловски.
AG> 'Любомy пpивычно смотpеть' тyт не совсем подходит, ибо для
AG> пpогpаммистов на интел-стайл компилятоpах это совеpшенно
AG> непpивычно. Скоpее всего маpкетолгия - пpи такой топологии ядpА в те
AG> давние вpемена полyчалось или чyть дешевле, или чyть больше выход
AG> годных кpисталлов.

Просто старший разряд числа в старший байт.


Andrey

--- ArAnd
Ответить с цитированием
Ответ


Ваши права в разделе
Вы не можете создавать новые темы
Вы не можете отвечать в темах
Вы не можете прикреплять вложения
Вы не можете редактировать свои сообщения

BB коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.

Быстрый переход


Текущее время: 08:40. Часовой пояс GMT +4.


Powered by vBulletin® Version 3.8.7
Copyright ©2000 - 2024, vBulletin Solutions, Inc. Перевод: zCarot