Перейти к содержанию

rcall


Jabus

Рекомендуемые сообщения

Реклама: ООО ТД Промэлектроника, ИНН: 6659197470, Тел: 8 (800) 1000-321

20% скидка на весь каталог электронных компонентов в ТМ Электроникс!

Акция "Лето ближе - цены ниже", успей сделать выгодные покупки!

Плюс весь апрель действует скидка 10% по промокоду APREL24 + 15% кэшбэк и бесплатная доставка!

Перейти на страницу акции

Реклама: ООО ТМ ЭЛЕКТРОНИКС, ИНН: 7806548420, info@tmelectronics.ru, +7(812)4094849

3 часа назад, Jabus сказал:

по моему это засорение стека.

четыре раза pop  r0  перед выходом исключают переполнение,  выравнивая количество записей-чтений стека.

戦う前に相手のベルトの色に注目

Ссылка на комментарий
Поделиться на другие сайты

Выбираем схему BMS для корректной работы литий-железофосфатных (LiFePO4) аккумуляторов

 Обязательным условием долгой и стабильной работы Li-FePO4-аккумуляторов, в том числе и производства EVE Energy, является применение специализированных BMS-микросхем. Литий-железофосфатные АКБ отличаются такими характеристиками, как высокая многократность циклов заряда-разряда, безопасность, возможность быстрой зарядки, устойчивость к буферному режиму работы и приемлемая стоимость. Но для этих АКБ, также как и для других, очень важен контроль процесса заряда и разряда, а специализированных микросхем для этого вида аккумуляторов не так много. Инженеры КОМПЭЛ подготовили список имеющихся микросхем и возможных решений от разных производителей. Подробнее>>

Реклама: АО КОМПЭЛ, ИНН: 7713005406, ОГРН: 1027700032161

2 часа назад, my504 сказал:

четыре раза

Если бы так... rcall только оставляет на вершине адрес возврата, а сам указатель как был так и остается неизменным.

Я не раздаю удочки. Я продаю рыбу.

Ссылка на комментарий
Поделиться на другие сайты

Это вы бабушкам у подъезда расскажите. Любой вызов - это запись в стек и перевод указателя, причем на два слова, ибо адрес вдвое шире. Можно вкладывать вызовы, углубляя стек. 

戦う前に相手のベルトの色に注目

Ссылка на комментарий
Поделиться на другие сайты

Всё бы так, но только до первого ret. В итоге остаемся при своих, только в стеке остался адрес возврата.

37 минут назад, my504 сказал:

бабушкам у подъезда расскажите.

Не устраивайте истерику. Мы говорим же о вопросе ТС, а не о работе стека.

Я не раздаю удочки. Я продаю рыбу.

Ссылка на комментарий
Поделиться на другие сайты

Причем тут ret? Ret вернет в PC ровно то, на что указывает указатель стека. POP переведет указатель на нкобходимую позицию, возмещая отсутствие ret у двух пустых вызовов. 

 

戦う前に相手のベルトの色に注目

Ссылка на комментарий
Поделиться на другие сайты

В догон, дело как раз в работе стека. Фантазировать о причинах работы компилятора можно до посинения. Я комментировал лишь сентенцию автора о замусоривании стека. 

Стек не переполняется. 

戦う前に相手のベルトの色に注目

Ссылка на комментарий
Поделиться на другие сайты

void u32_color(uint32_t h){
    R_color=*(h+0);
    G_color=*(h+1);
    B_color=*(h+2);
}

18 часов назад, солар сказал:

Оставляем на стеке адрес. Остается вопрос - зачем два раза.

Сишную программу можно увидеть?

 

17 часов назад, my504 сказал:

четыре раза pop  r0  перед выходом исключают переполнение,  выравнивая количество записей-чтений стека.

считай при выполнение каждой такой функции минимум 6 байт в озу,ну а если много таких функций будет? стек может залезть на переменные... в attiny13 такое запросто провернуть, там всего 64 байта.

Изменено пользователем Jabus
так надо
Ссылка на комментарий
Поделиться на другие сайты

Это ВСЕГО четыре слова. Чтобы они суммировались, нужна вложенность функций. 

И таки да, если ОЗУ крошечное, то оно может быстро закончиться. И произойдет это совсем не из-за стека. 

ОЗУ нужно выбирать под задачу и используемый язык написания кода.

Ну и учитывать уровень оптимизации, канешна. 

 

戦う前に相手のベルトの色に注目

Ссылка на комментарий
Поделиться на другие сайты

On 6/17/2019 at 6:57 AM, Jabus said:

зачем он это делает?

Компиляторы аргуметны функций передают через стэк. Соответственно для функции void u32_color(uint32_t h) он помещает в стек 4 байта, а при выходе их удаляет. Для других типов он наверно использует другие команды типа push.

Ссылка на комментарий
Поделиться на другие сайты

Только что, snn_krs сказал:

Компиляторы аргуметны функций передают через стэк.

Сферические компиляторы в вакууме. AVR-GCC до 8 параметров передает в регистрах, и только сверх этого - через стек (разумеется, от размера параметров зависит тоже).

Не понятен вообще интерес к тому, что делает компилятор - раз делает, значит, так надо. 

Если забанить всех, кто набрался смелости думать независимо, здорово будет на форуме - как на кладбище: тишина, птички поют...

Ссылка на комментарий
Поделиться на другие сайты

5 часов назад, my504 сказал:

Это ВСЕГО четыре слова. Чтобы они суммировались, нужна вложенность функций. 

И таки да, если ОЗУ крошечное, то оно может быстро закончиться. И произойдет это совсем не из-за стека. 

ОЗУ нужно выбирать под задачу и используемый язык написания кода.

Ну и учитывать уровень оптимизации, канешна. 

 

если не ошибаюсь стек идет с конца озу и ниже, и если будет 3-4 вложенные функции то 6*4=24 байта, если там будут лежать переменные то он и покоцает.

Ссылка на комментарий
Поделиться на другие сайты

Только что, Jabus сказал:

и если будет 3-4 вложенные функции то 6*4=24 байта

Вы посмотрите на код внимательно: там задействовано 6 байт стека сверх тех двух, что потрачены на вызов самой функции. К чему фантазии о 24 байтах?

Если забанить всех, кто набрался смелости думать независимо, здорово будет на форуме - как на кладбище: тишина, птички поют...

Ссылка на комментарий
Поделиться на другие сайты

На скриншоте видно, что функция main( uint32_t x ) тоже задана с аргументом и 6 байт стека сразу используются. Сделайте функцию main( void ) и освободятся 6 байт.

Ссылка на комментарий
Поделиться на другие сайты

В 20.06.2019 в 11:13, солар сказал:

Но в вашем случае непонятно откуда берутся rcall.

а чего там непонятного то - сэкономили разработчики компилятора - вместо 4-х инструкций вставили две.

Можно сделать все! Но чем больше можно, тем больше нельзя!

Ссылка на комментарий
Поделиться на другие сайты

знаю какие у меня кривые руки, так что не бомбите а укажите где ошибка

вот код (написан в arduino IDE для вывода данных)
void setup(){
  uint16_t t;
  Serial.begin(115200);
  asm volatile(
    "RCALL .+0  \n"
    "POP %B[a]  \n"
    "POP %A[a]  \n"
    :
    [a] "+r" ((uint16_t)t)
  );
  Serial.println(t,HEX);
}

void loop(){}

изображение.png

Изменено пользователем Jabus
Ссылка на комментарий
Поделиться на другие сайты

зачем ты создаешь новую тему об одном и том же, если у тебя уже есть созданная тема.

я объединил обе темы в одну.

Мудрость приходит вместе с импотенцией...

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

Ссылка на комментарий
Поделиться на другие сайты

где же ты видел, чтобы адрес состоял из одного байта?

 

Мудрость приходит вместе с импотенцией...

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

Ссылка на комментарий
Поделиться на другие сайты

я предположил т.к. rjmp и jmp переходят по байтам.

но проблемы продолжаются. компилятор что-то делает с командами sts и lds, если рядом дотрагивались до одних и тех же переменных.5d16833fdc49c_.thumb.png.a72341be2fa92f8feb66dd26d0720497.png

Ссылка на комментарий
Поделиться на другие сайты

4 часа назад, Jabus сказал:

я предположил т.к. rjmp и jmp переходят по байтам.

все команды имеют размер слова, а слово состоит из двух байт.

поэтому ты предположил глупость, и ни о каком переходе по байтам речи быть не может.

Мудрость приходит вместе с импотенцией...

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

Ссылка на комментарий
Поделиться на другие сайты

Присоединяйтесь к обсуждению

Вы можете написать сейчас и зарегистрироваться позже. Если у вас есть аккаунт, авторизуйтесь, чтобы опубликовать от имени своего аккаунта.
Примечание: Ваш пост будет проверен модератором, прежде чем станет видимым.

Гость
Unfortunately, your content contains terms that we do not allow. Please edit your content to remove the highlighted words below.
Ответить в этой теме...

×   Вставлено с форматированием.   Восстановить форматирование

  Разрешено использовать не более 75 эмодзи.

×   Ваша ссылка была автоматически встроена.   Отображать как обычную ссылку

×   Ваш предыдущий контент был восстановлен.   Очистить редактор

×   Вы не можете вставлять изображения напрямую. Загружайте или вставляйте изображения по ссылке.

Загрузка...
  • Последние посетители   0 пользователей онлайн

    • Ни одного зарегистрированного пользователя не просматривает данную страницу
  • Сообщения

    • Тут я уже писАл, какой ток что на самом деле протекает.  
    • Как к модеру к нему конечно были вопросы. Ну и правила его не касались, когда кидался оскорблениями в адрес Василича. А за ответы на оскорбления Василич баны выхватывал
    • Смотрю, многие в усилителях избегают катодного повторителя. Либо сразу берут токовые лампы с хорошим усилением, либо два каскада последовательно на токовых лампах с низким усилением. Вроде бы на звук не влияет...
    • Имел дело с зарядкой батареек еще с советских времен. Тогда еще в магазине (!) купил специальную зарядку для ртутно-цинковых батареек, очень миниатюрная, зарядка шла от встроенного солнечного элемента (и это еще в советские времена!). Использовал для зарядки батареек для наручных часов, после первой зарядки батарейки хватало примерно на полгода, потом на 3-4 месяца. Потом (когда батарейка служила меньше двух месяцев) батарейка отправлялась на упокой. Спасала студента тогда очень эта вещица. Жалею что тогда не срисовал ее внутренности. А вот с зарядкой щелочных батареек пришлось заниматься уже значительно позже. Мне кто-то подарил такой набор (зарядка с комплектом перезаряжаемых батареек) - вот его обзор https://aphnetworks.com/reviews/pure_energy_xl  Все было нормально, но у всех этих батареек ресурс очень ограничен, примерно 25 циклов максимум. После чего емкость уменьшается и нет смысла их дальше использовать. После каждой зарядки емкость уменьшается, но не сильно. Реально раз десять заряжать можно точно без проблем. После того как выработался ресурс последней батарейки стал вопрос - а можно ли заряжать обычные батарейки тоже? Зарядка-то осталась... И как раз в то время приобрел обычные (т.е. "незаряжаемые") батарейки той же фирмы (PureEnergy). Оказалось что они заряжаются точно также, как и "заряжаемые"! Возможно что у них та же химия... Пробовал батарейки разных фирм, степени разряда. Короче говоря, фирменные всякие Дюраселлы и Энержайзеры не заряжаются вообще, и даже могут потечь во время зарядки. А вот самые дикие и дешевые нонейм чаще всего заряжаются без проблем. Насчет емкости - конечно емкость полностью не восстанавливается, но для работы в беспроводной клаве,, мышке или пульте вполне хватает и достаточно надолго.  Но занимаюсь этим нечасто, просто когда лень ехать в магазин за очередной партией батареек.  А если есть возможность, то предпочитаю переделывать питание под литий. Очень сильно достает саморазряд всяких Ni-Cd, Ni-MH - разряжаются даже те, которые якобы должны долго держать заряд. Схему зарядки еще не срисовывал (лень было разбирать), но схема сложнее чем все что я видел в Интернете. Напряжение заряда примерно 1,7в. xlaa_tds.pdf
    • Я делаю ставку на контакты NC реле запуска и NO реле торможения. Тем более они такие хлипенькие.
    • Раз смогли срисовать схему "силы", то и решить проблему для вас вряд ли сложно будет... Проверьте емкость и ЭПС C-20мкФ и сопротивление контактов этих двух реле в on/off
×
×
  • Создать...