Эта статья включает список общих ссылок , но в ней отсутствуют соответствующие встроенные цитаты . ( Май 2021 г. ) |
В информатике термин bare machine (или bare metal ) относится к компьютеру, выполняющему инструкции непосредственно на логическом оборудовании без вмешательства операционной системы . Современные операционные системы прошли различные стадии развития, от элементарных до современных сложных, высокочувствительных систем, включающих множество служб. После разработки программируемых компьютеров (которые не требовали физических изменений для запуска различных программ), но до разработки операционных систем, последовательные инструкции выполнялись на компьютерном оборудовании напрямую с использованием машинного языка без какого-либо системного программного слоя. Этот подход называется «голым компьютером» — предшественником современных операционных систем. Сегодня он в основном применим к встроенным системам и прошивкам с критическими по времени требованиями к задержке, в то время как обычные программы запускаются системой выполнения, наложенной на операционную систему.
Для данного приложения в большинстве случаев реализация bare-metal будет работать быстрее, используя меньше памяти и, таким образом, будучи более энергоэффективной. Это связано с тем, что операционным системам, как и любой программе, требуется некоторое время выполнения и объем памяти для запуска, а они больше не нужны на bare-metal. Например, любая аппаратная функция, которая включает входы и выходы, напрямую доступна на bare-metal, тогда как та же функция, использующая ОС, должна направить вызов в подпрограмму, потребляя время выполнения и память. [1]
Для данного приложения программирование bare-metal требует больше усилий для правильной работы и является более сложным, поскольку службы, предоставляемые операционной системой и используемые приложением, должны быть повторно реализованы в соответствии с потребностями. Эти службы могут быть:
Отладка программы на «голом железе» затруднена по следующим причинам:
Программирование на голом железе обычно выполняется с использованием языка, близкого к аппаратному, например, Rust , C++ , C , языка ассемблера или даже для небольших объемов кода или очень новых процессоров — непосредственно машинного кода . [2] Все предыдущие проблемы неизбежно означают, что программы на голом железе очень редко являются переносимыми .
Ранние компьютеры, такие как PDP-11 , позволяли программистам загружать программу, представленную в машинном коде , в ОЗУ . Результирующее функционирование программы можно было контролировать с помощью лампочек , а вывод можно было получать с магнитной ленты , печатающих устройств или накопителей .
Программирование голой машины остается обычной практикой во встраиваемых системах , где микроконтроллеры или микропроцессоры часто загружаются непосредственно в монолитное, одноцелевое программное обеспечение, без загрузки отдельной операционной системы. Такое встраиваемое программное обеспечение может различаться по структуре, но простейшая форма может состоять из бесконечного основного цикла или «суперцикла», вызывающего подпрограммы, отвечающие за проверку входов, выполнение действий и запись выходов.
Подход к использованию голых машин проложил путь новым идеям, которые ускорили эволюцию разработки операционных систем .
Такой подход выявил необходимость в следующем:
Например, программы загружались в PDP-11 вручную, с помощью ряда тумблеров на передней панели устройства. Клавиатуры намного превосходят эти старинные устройства ввода, так как было бы намного быстрее набирать код или данные, чем использовать тумблеры для ввода их в машину. Позже клавиатуры стали стандартными почти для каждого компьютера, независимо от марки или цены.
Компьютерные мониторы также могут легко отображать вывод программы в удобной для пользователя манере. Например, нужно быть глубоко осведомленным о конкретном раннем компьютере и его системе отображения, состоящей из массива лампочек, чтобы хотя бы начать понимать состояние аппаратного обеспечения компьютера. Напротив, любой, кто умеет читать, должен быть в состоянии понять хорошо спроектированный пользовательский интерфейс в современной системе, не имея никаких знаний об аппаратном обеспечении компьютера, на котором выполняется программа.