| РАССЫЛКИ ПОРТАЛА RFPRO.RU Лучшие эксперты в разделе | Номер выпуска: | 1803 | | Дата выхода: | 22.02.2022, 15:45 | | Администратор рассылки: | Зенченко Константин Николаевич (Старший модератор) | | Подписчиков / экспертов: | 11 / 25 | | Вопросов / ответов: | 1 / 1 | Консультация # 202174: Уважаемые эксперты! Пожалуйста, ответьте на вопрос: Цитата из книги Калашникова по ассемблеру: не следует забывать о таком понятии, как переполнение стека. Мы знаем, что после загрузки COM-программы в память, ss равен сегменту, куда загрузилась программа, а sp = 0FFFEh. Код программы начинается с адреса 100h (org 100h)....
Консультация # 202174: Уважаемые эксперты! Пожалуйста, ответьте на вопрос: Цитата из книги Калашникова по ассемблеру:
не следует забывать о таком понятии, как переполнение стека. Мы знаем, что после загрузки COM-программы в память, ss равен сегменту, куда загрузилась программа, а sp = 0FFFEh. Код программы начинается с адреса 100h (org 100h). Вершина стека — конец сегмента. Если наша программа занимает, скажем, 2000h байт, то можем установить sp в 2200h. В этом случае мы отводим 100h (именно сто) байт для стека (т. к. программа загружается в память по адресу 100h (org 100h), то к 2000h нужно прибавить 100h). Стек, как вы помните, рас- тет снизу вверх. Если мы переполним стек (например, поместим более 100h данных), то затрется часть нашей программы снизу.
Не понимаю здесь ошибка или я неправильно понимаю написанное? 2000h байт это размер программы или сегмент памяти, в который загружается программа. Если сегмент, то не по нимаю почему sp не устанавливается в 2300h (то есть 100h на код, 100h на стек), ведь код начинается 2000h + 100h = 2100h. Стек начинается с 2200h, то есть он сразу начнет затирать код программы (если конечно код и стек не уместятся в эти 100h). Дата отправки: 17.02.2022, 15:17 Вопрос задал: simonovaleksey (Посетитель) Всего ответов: 1 Страница онлайн-консультации » Консультирует Kdsfofwe21 (3-й класс): 0000h 0100h начало сегмента кода 2100h конец сегмента код 2102h конец стека 21xxh стек 2200h вершина стека, сюда указывает SP, когда пушим SP уменьшается на размер, который зависит от разрядности. То есть каждый PUSH приближает к адресу 2100h, и далее продолжая пушить заходить в сегмент кода.
Оценить выпуск | Задать вопрос экспертам главная страница | стать участником | получить консультацию техническая поддержка Дорогой читатель! Команда портала RFPRO.RU благодарит Вас за то, что Вы пользуетесь нашими услугами. Вы только что прочли очередной выпуск рассылки. Мы старались. Пожалуйста, оцените его. Если совет помог Вам, если Вам понравился ответ, Вы можете поблагодарить автора - для этого в каждом ответе есть специальные ссылки. Вы можете оставить отзыв о работе портале. Нам очень важно знать Ваше мнение. Вы можете поближе познакомиться с жизнью портала, посетив наш форум, почитав журнал, который издают наши эксперты. Если у Вас есть желание помочь людям, поделиться своими знаниями, Вы можете зарегистрироваться экспертом. Заходите - у нас интересно! МЫ РАБОТАЕМ ДЛЯ ВАС! |
Комментариев нет:
Отправить комментарий