Ошибка Pentium FDIV - Pentium FDIV bug

Intel Pentium 66 МГц (sSpec = SX837) с ошибкой FDIV

В Ошибка Pentium FDIV это аппаратная ошибка влияя на блок с плавающей запятой (ФПУ) ранние процессоры Intel Pentium. Из-за ошибки процессор может возвращать неверные двоичные результаты с плавающей запятой при делении числа. Ошибка была обнаружена в 1994 году профессором Томасом Р. Найсли в Линчберг Колледж.[1] Intel объяснила ошибку отсутствием записей в таблице поиска, используемой схемой деления с плавающей запятой.[2]

Серьезность ошибки FDIV обсуждается. Хотя большинство пользователей встречается редко (Байт журнал оценил, что 1 из 9 миллиардов делений с плавающей запятой со случайными параметрами приведет к неточным результатам),[3] И недостаток, и первоначальный подход Intel к этому вопросу подверглись резкой критике со стороны технического сообщества.

В декабре 1994 г. напомнил бракованные процессоры. В январе 1995 года Intel объявила о «начислении налогов до налогообложения в размере 475 миллионов долларов из прибыли, якобы полной стоимости, связанной с заменой неисправных процессоров».[1][4] Это эквивалентно 743 миллионам долларов в 2019 году.[5]

Описание

В Суини, Робертсон и Точер (СТО) алгоритм деления используется на затронутых чипах Pentium. Он реализован как программируемая логическая матрица с 2048 ячейками, из которых 1066 ячеек должны были быть заполнены одним из пяти значений: –2, –1, 0, +1, +2. На глючных микросхемах отсутствовали пять ячеек, которые должны были содержать значение +2, вместо этого возвращалось 0.[3]

Хронология

Intel представила линейку процессоров Pentium в марте 1993 года.

Томас Найсли, профессор математики в Линчбургском колледже, написал код для перечисления простые числа, простые числа-близнецы, простые тройни, и первоклассные четверки. Приятно заметил некоторые несоответствия в расчетах 13 июня 1994 г., вскоре после добавления системы Pentium к своей группе компьютеров, но не смог устранить другие факторы (такие как ошибки программирования, материнская плата чипсеты и т. д.) до 19 октября 1994 г. 24 октября 1994 г. он сообщил о проблеме в Intel. По словам Найсли, его контактное лицо в Intel позже признало, что Intel знала об этой проблеме с мая 1994 года, когда недостаток был обнаружен Томом Кралевичем. Университет Пердью кооператив студент, работающий на Intel в Хиллсборо, штат Орегон, во время тестирования FPU для своего нового P6 ядро, впервые использованное в Pentium Pro.

30 октября 1994 г. Найсли разослал электронное письмо с описанием ошибки, обнаруженной им в модуле вычислений с плавающей запятой Pentium, различным контактам с запросом отчетов о проверке уязвимости на 486-DX4s, Пентиумы и Клоны Pentium.[1]

Этот недостаток в Pentium FPU был быстро подтвержден другими людьми в Интернет, и стал известен как ошибка Pentium FDIV (FDIV - это мнемоника ассемблера x86 за жточка ожидания division). Был обнаружен один пример, когда результат деления, возвращаемый Pentium, отличался примерно на 61 часть на миллион.[1]

История впервые появилась в прессе 7 ноября 1994 г. в статье в Electronic Engineering Times, "Intel исправляет сбой Pentium FPU" Александра Вулфа.[6]

История впоследствии была подхвачена CNN в сегменте, транслированном 21 ноября 1994 года.[1] Это сделало его широко известным.

Публично Intel признала недостаток операций с плавающей запятой, но заявила, что он несерьезный и не затронет большинство пользователей. Intel предложила заменить процессоры пользователям, которые смогут доказать, что они пострадали. Однако, хотя большинство независимых оценок обнаружили, что ошибка не имеет большого значения и не окажет существенного влияния на большинство пользователей, она вызвала большой общественный резонанс. Такие компании как IBM (чей IBM 5x86C микропроцессор конкурировал в то время с линейкой Intel Pentium) присоединился к осуждению.

20 декабря 1994 года Intel предложила заменить все неисправные процессоры Pentium на основании запроса в ответ на растущее давление общественности.[7] Хотя выяснилось, что лишь небольшая часть владельцев Pentium позаботилась о замене своих чипов, финансовые последствия для компании были значительными.[нужна цитата ] 17 января 1995 года Intel объявила о «начислении налогов до налогообложения в размере 475 миллионов долларов против прибыли, якобы общей стоимости, связанной с заменой неисправных процессоров».[1] Это эквивалентно 743 миллионам долларов в 2019 году.[5] Некоторые из дефектных чипов позже были превращены в брелоки от Intel.[8]

Статья 1995 г. в Наука описывает значение задач теории чисел для обнаружения компьютерных ошибок и дает математические основы и историю Постоянная Бруна, проблема, над которой Nicely работал, когда он обнаружил ошибку.[9]

Затронутые модели

Эта проблема возникает только на некоторых моделях оригинального процессора Pentium.[10] Ошибка существовала только в некоторых процессорах семейства Pentium с тактовой частотой менее 120 МГц.[10] На затронутых моделях утилита Intel Processor Frequency ID Utility проверяет наличие этой ошибки.

Ниже перечислены десять затронутых моделей процессоров. 39 S-спецификации этих процессоров не указаны на веб-странице поиска спецификаций процессоров Intel.

Pentium P5 800 нм 5 В
СемьяМодельШагаяСтеппинг ядраТактовая частотаФСБ скоростьS-spec
513B160 МГц60 МГцQ0352, Q0412, SX753
513B166 МГц66 МГцQ0353, Q0413, SX754
515C160 МГц60 МГцQ0466, SX835, SZ949
515C166 МГц66 МГцQ0467, SX837, SZ950
Pentium P54C 600 нм 3,3 В
СемьяМодельШагаяСтеппинг ядраТактовая частотаСкорость FSBS-spec
521B175 МГц50 МГцQ0601
521B190 МГц60 МГцQ0542, Q0613, Q0543, SX879, SX885, SX909, SX874
521B1100 МГц66 МГцQ0563, Q0587, Q0614, SX886, SX910
522B375 МГц50 МГцQ0606, SX951
522B390 МГц60 МГцQ0628, Q0611, Q0612, SX923, SX922, SX921, SX942, SX943, SX944, SZ951
522B3100 МГц66 МГцQ0677, SX960

Немного Intel 80486 OverDrive и Pentium Overdrive модели также, как известно, демонстрируют ошибку FDIV, а также Ошибка F00F.

Методы обнаружения

Универсальный

Наличие ошибки можно проверить вручную, выполнив следующие вычисления в любом приложении, которое использует собственные числа с плавающей запятой, включая Калькулятор Windows или же Майкрософт Эксель в Windows 95 /98.

Правильное значение:

При преобразовании в шестнадцатеричное значение, используемое процессором, 4,195,835 = 0x4005FB и 3,145,727 = 0x2FFFFF. «5» в 0x4005FB запускает ошибку в логике управления FPU. В результате значение, возвращаемое некорректным процессором Pentium в определенных ситуациях, является неверным с точностью до четырех цифр:[11][12]

Windows 95 или 98

Пользователи могут проверить, есть ли у их процессора проблема, используя Диспетчер устройств. В диспетчере устройств пользователи должны развернуть «Системные устройства», найти, затем щелкнуть «Цифровой процессор данных», затем нажать кнопку «Свойства». Когда появится новое окно «Свойства», щелкните вкладку «Настройки».
Если процессор нет есть проблема с FDIV, появится следующее сообщение:«Цифровой процессор данных вашего компьютера прошел все диагностические тесты и работает правильно»., В противном случае должно появиться следующее сообщение:«Числовой процессор в этом компьютере иногда может вычислять неточные результаты при делении больших чисел»

Затем в нижней части вкладки «Настройки» предлагаются варианты «Всегда использовать», «Использовать только в том случае, если [он] проходит всю диагностику» или «Никогда не использовать».[13]

Windows NT, 2000, XP, сервер 2003

пентнт
Разработчики)Microsoft
изначальный выпуск30 мая 1995 г.; 25 лет назад (1995-05-30)
Операционная системаМайкрософт Виндоус
ТипКоманда
ЛицензияПроприетарный коммерческое программное обеспечение
Интернет сайтпентнт

Пользователи могут запускать пентнт команда включены с Windows NT 3.51, NT 4.0, 2000, XP, и Сервер 2003. Чтобы изменения вступили в силу, необходимо перезагрузить компьютер.[14] В пентнт Утилита устарела и не включена в текущие версии Windows.[15]

Командный синтаксис:

pentnt [-c] [-f] [-o]

  • -c - Включить условную эмуляцию
  • -f - Включить принудительную эмуляцию
  • - Отключить принудительную эмуляцию и повторно включить оборудование с плавающей запятой, если оно присутствует
  • /? - Показать справку

Смотрите также

Рекомендации

  1. ^ а б c d е ж Хорошо, Томас (19 августа 2011 г.). "Часто задаваемые вопросы о недостатках Pentium FDIV". trnicely.net. Архивировано из оригинал 18 июня 2019 г.. Получено 18 июня, 2019.
  2. ^ «Статистический анализ ошибки с плавающей запятой: информационный документ Intel» (PDF). Intel. 9 июля 2004 г. с. 9. Идентификатор решения CS-013007. Архивировано из оригинал (PDF) на 2016-04-06. Получено 5 апреля 2016.
  3. ^ а б Том Р. Халфхилл (март 1995 г.). «Ошибка в поисковой таблице создала печально известную ошибку в новейшем процессоре Intel». БАЙТ (Март 1995 г.). Архивировано из оригинал (– Академический поиск) 9 февраля 2006 г.. Получено 2006-12-19.
  4. ^ «1994 - Годовой отчет». Intel. 20 июня 2020. В архиве из оригинала 26 февраля 2017 г.. Получено 20 июн 2020.
  5. ^ а б Томас, Райланд; Уильямсон, Сэмюэл Х. (2020). "Каков тогда был ВВП США?". Оценка. Получено 22 сентября, 2020. Соединенные Штаты Дефлятор валового внутреннего продукта цифры следуют за Стоимость измерения серии.
  6. ^ Александр Вульф. «Intel исправляет сбой Pentium FPU».
  7. ^ «Intel применяет политику замены по запросу процессоров Pentium с ошибкой с плавающей запятой; будет взимать плату за четвертый квартал в счет прибыли». Деловой провод. 1994-12-20. Архивировано из оригинал на 2012-07-10. Получено 2006-12-24.
  8. ^ «Сколько инженеров нужно, чтобы заменить лампочку?». Вареные бобы. 20 апреля 2009 г. Архивировано с оригинал на 2010-02-03. Получено 10 ноября 2009.
  9. ^ Сипра, Барри Артур (1995-01-13). «Как теория чисел взяла верх над процессором Pentium». Наука. 267 (5195): 175. Дои:10.1126 / science.267.5195.175. PMID  17791336.
  10. ^ а б «Программа замены FDIV: часто задаваемые вопросы». Intel. 2009-03-20. Идентификатор решения CS-012748. Архивировано из оригинал на 2009-05-11. Получено 2009-11-10.
  11. ^ "Ошибка Pentium FDIV - Картинка". Институт политики и социальных исследований Канзасского университета. 1994-11-30. Получено 2010-11-03.
  12. ^ "MathTrek Иварса Петерсона: повторение ошибки Pentium". Математическая ассоциация Америки. Архивировано из оригинал 10 декабря 2008 г.
  13. ^ Слоба, Арье. «Устранение неполадок Windows 95: как определить неисправный математический сопроцессор». www.helpwithwindows.com. Получено 23 апреля, 2019.
  14. ^ "Пентнт". Microsoft TechNet. Microsoft. 11 сентября 2009 г.. Получено 23 апреля, 2019.
  15. ^ https://docs.microsoft.com/en-us/windows-server/administration/windows-commands/pentnt

внешняя ссылка