Легенда:
новое сообщение
закрытая нитка
новое сообщение
в закрытой нитке
старое сообщение
|
- Напоминаю, что масса вопросов по функционированию форума снимается после прочтения его описания.
- Новичкам также крайне полезно ознакомиться с данным документом.
|
ИМХО выпрямлять руки надо не программистам, а производителям процессоров 16.01.04 14:00 Число просмотров: 1449
Автор: amirul <Serge> Статус: The Elderman
|
> Ведущие производителя прпоцессоров собираются встроить > защиту от переполнения буфера (причина большинства "дырок" > в софте) непосредственно в чипы. Решение по меньшей мере > странное: на существующей архитектуре уже есть возможность > защищать сегменты памяти от записи и исполнения. В > частности, существует несколько вариантов патчей для > linux-систем, запрещающих от исполнения кода в стеке. Защитить от исполнения можно сегмент, а не страницу. Если учесть, что сегментная организация памяти так и остается невостребованной (она так и осталась элементом backward-compatibility). А при flat-организации защиту стека от исполнения можно обойти просто исполнив код по тому же адресу, но в другом сегменте.
Вполне возможно, что Intel и Co наконец-то поймут, что никому на фиг не нужны их сегменты и вставят в аттрибуты страниц еще один флаг - исполнение в странице. Это как раз и приведет к вышеописанному эффекту "защиты от переполнения буфера".
> Правда, после этого перестает работать ряд программ, но > может быть надо просто выпрямить руки программистам? :) Вопрос не раз обсуждался. Исполнимый стек - особенность Intel-архитектуры и программисты практически ни при чем :-)
|
<site updates>
|
В процессорах AMD и Intel появится антивирусная защита 16.01.04 08:05
Publisher: cybervlad <cybervlad> Статус: Elderman
|
В процессорах AMD и Intel появится антивирусная защита Compulenta http://www.compulenta.ru/2004/1/15/44430/
Ведущие производителя прпоцессоров собираются встроить защиту от переполнения буфера (причина большинства "дырок" в софте) непосредственно в чипы. Решение по меньшей мере странное: на существующей архитектуре уже есть возможность защищать сегменты памяти от записи и исполнения. В частности, существует несколько вариантов патчей для linux-систем, запрещающих от исполнения кода в стеке. Правда, после этого перестает работать ряд программ, но может быть надо просто выпрямить руки программистам? :)
Полный текст
|
|
Бред с "подменой тезиса", столь любимой нашим URIXом 17.01.04 07:14
Автор: Zef <Alloo Zef> Статус: Elderman
|
> Ведущие производителя прпоцессоров собираются встроить > защиту от переполнения буфера
> запрещающих от исполнения кода в стеке.
Дык, не от переполнения, а от исполнения кода в стеке...
А переполнение, как было, так и остается и прогу повалить через срыв стека можно. А вот, выполнить атакующий код - нельзя.
А от переполнения нужно защищаться на уровне компилеров, чтобы все размещаемые в стеке массивы программно контролировали переполнение. Или отказываться от размещения локальных переменных и аргументов в стеке.
|
| |
Да, ты прав, я невнимательно ньюсу прочитал. Но, с другой... 19.01.04 10:32
Автор: cybervlad <cybervlad> Статус: Elderman
|
> Дык, не от переполнения, а от исполнения кода в стеке... > А переполнение, как было, так и остается и прогу повалить > через срыв стека можно. А вот, выполнить атакующий код - > нельзя. Да, ты прав, я невнимательно ньюсу прочитал. Но, с другой стороны, чтобы выполнить код в стеке, надо сперва его туда запихать, что и делается с помощью переполнения.
> А от переполнения нужно защищаться на уровне компилеров, > чтобы все размещаемые в стеке массивы программно TurboPascal любимый - range check error :)
> контролировали переполнение. Или отказываться от размещения > локальных переменных и аргументов в стеке. Ага, и куда их совать?.
Скажем так: надо переходить на языки, которые "не дадут прострелить себе ногу". Всякие C/C++ - маст дай.
|
|
прорвалось таки с третьего раза :) 16.01.04 14:22
Автор: dl <Dmitry Leonov>
|
Я сознательно и сам не выкладывал эту новость почти неделю назад, и два раза не пропустил ее как предложенную, и все-таки прорвалась :) Есть ощущение, что в ней слишком много от маркетинга, нежели реальной пользы.
|
| |
дык стирай, пока не поздно ;) 16.01.04 14:55
Автор: cybervlad <cybervlad> Статус: Elderman
|
> Я сознательно и сам не выкладывал эту новость почти неделю > назад, и два раза не пропустил ее как предложенную, и > все-таки прорвалась :) Есть ощущение, что в ней слишком > много от маркетинга, нежели реальной пользы. Мне не сама новость понравилась, а подход к проблеме. ПРимерно как удалять гланды через анальное отверстие...
|
| | |
Как я уже писал 16.01.04 18:06
Автор: amirul <Serge> Статус: The Elderman
|
> Мне не сама новость понравилась, а подход к проблеме. > ПРимерно как удалять гланды через анальное отверстие... Текущая реализация защиты памяти от исполнения как раз и напоминает удаление гландов пер-ректум. Мне все таки кажется, что будет человеческое расширение IA: у страницы появится не только флаги Present и Read-Only, но и Execute (к слову, в тех же MC680x0 вообще нет сегментов - есть очень гибкая система страничной памяти). Уверен, что в большинство ОС-ей после этого придется вносить минимальные изменения (изменить флаги при создании стека и при расширении оного). А вот чтобы защитить стек при текущей организации - нужно делать весьма нетривильные вещи.
|
| | |
поздно, она уже в рассылку ушла :) 16.01.04 15:02
Автор: dl <Dmitry Leonov>
|
|
|
ИМХО выпрямлять руки надо не программистам, а производителям процессоров 16.01.04 14:00
Автор: amirul <Serge> Статус: The Elderman
|
> Ведущие производителя прпоцессоров собираются встроить > защиту от переполнения буфера (причина большинства "дырок" > в софте) непосредственно в чипы. Решение по меньшей мере > странное: на существующей архитектуре уже есть возможность > защищать сегменты памяти от записи и исполнения. В > частности, существует несколько вариантов патчей для > linux-систем, запрещающих от исполнения кода в стеке. Защитить от исполнения можно сегмент, а не страницу. Если учесть, что сегментная организация памяти так и остается невостребованной (она так и осталась элементом backward-compatibility). А при flat-организации защиту стека от исполнения можно обойти просто исполнив код по тому же адресу, но в другом сегменте.
Вполне возможно, что Intel и Co наконец-то поймут, что никому на фиг не нужны их сегменты и вставят в аттрибуты страниц еще один флаг - исполнение в странице. Это как раз и приведет к вышеописанному эффекту "защиты от переполнения буфера".
> Правда, после этого перестает работать ряд программ, но > может быть надо просто выпрямить руки программистам? :) Вопрос не раз обсуждался. Исполнимый стек - особенность Intel-архитектуры и программисты практически ни при чем :-)
|
|
мды.. 16.01.04 13:28
Автор: Killer{R} <Dmitry> Статус: Elderman
|
цитата статьи
"В данный момент современные процессоры выполняют все записанные в память при переполнении буфера программы. Теперь же благодаря Execution Protection, данные в буфере могут только считываться, а хранящиеся в нем программы выполняться не будут. Если выключить такой ПК, хакерская программа исчезнет, не причинив никакого вреда компьютеру. По крайней мере, так заявляет Джон Моррис, директор компании AMD по маркетингу."
Ну я понимаю что журналистам совсем необязательно знать все особенности архитектуры i386, но если такое сам директор AMD говорит.. Имхо не что иное как просто очередной маркетинговый ход. Потому что такая фича уже давно имеется в процессорах начиная с 386го.
|
|
|