RISC-V - RISC-V

RISC-V
RISC-V-logo.svg
ДизайнерКалифорнийский университет в Беркли
Биты
  • 32
  • 64
  • 128
Введено2010
Версия
  • непривилегированный ISA 20191213,[1]
  • привилегированный ISA 20190608[2]
ДизайнRISC
ТипЗагрузить-магазин
КодированиеПеременная
РазветвлениеСравнить-и-перейти
Порядок байтовМаленький[1][3]
Размер страницы4 КБ
Расширения
  • M: Умножение
  • А: Атомный
  • F: Плавающая точка (32-битный)
  • D: FP Двойной (64-битный)
  • Q: FP Quad (128 бит)
  • C: Сжатые инструкции(16 бит)
  • А: Atomics - LR / SC & fetch-and-op
ОткрытьДа, и без лицензионных отчислений
Регистры
Общее назначение
  • 16
  • 32
(включая один всегда нулевой регистр)
Плавающая точка32 (необязательно)

RISC-V (произносится как «риск-пять»[1]:1) является открытый стандарт архитектура набора команд (ISA) на основе установленных компьютер с сокращенным набором команд (RISC) принципы. В отличие от большинства других проектов ISA, RISC-V ISA предоставляется в лицензии с открытым исходным кодом которые не требуют комиссии за использование. Ряд компаний предлагают или анонсировали оборудование RISC-V, доступны операционные системы с открытым исходным кодом с поддержкой RISC-V, а набор инструкций поддерживается в нескольких популярных программах. инструменты.

Примечательные особенности RISC-V ISA включают: архитектура загрузки и хранения, битовые комбинации для упрощения мультиплексоров в ЦП, IEEE 754 с плавающей запятой, архитектура нейтральна с точки зрения архитектуры и размещение наиболее значимых битов в фиксированном месте для ускорения расширение знака.[1]Набор инструкций разработан для широкого круга задач. Он имеет переменную ширину и расширяемый, поэтому всегда можно добавить больше битов кодирования. Он поддерживает три ширины слова: 32, 64 и 128 бит, а также множество подмножеств. Определения каждого подмножества незначительно различаются для трех значений ширины слова. Подмножества поддерживают небольшие встроенные системы, персональные компьютеры, суперкомпьютеры с векторными процессорами и в масштабе склада 19-дюймовая стойка -монтированный параллельные компьютеры.

Пространство набора инструкций для 128-битной растянутой версии ISA было зарезервировано, потому что 60-летний опыт работы в отрасли показал, что самой неисправимой ошибкой при разработке набора инструкций является нехватка памяти. адресное пространство. По состоянию на 2016 год128-битный ISA намеренно остается неопределенным, поскольку пока еще очень мало практического опыта работы с такими большими системами памяти.[1] Есть предложения реализовать инструкции переменной ширины длиной до 864 бит, что в 27 раз больше обычной длины.[1][4]

Проект стартовал в 2010 г. Калифорнийский университет в Беркли наряду со многими добровольцами, не связанными с университетом.[5] В отличие от других академических проектов, которые обычно оптимизируются только для простоты изложения, дизайнеры предполагали, что набор команд RISC-V можно будет использовать для практических компьютеров.

По состоянию на июнь 2019 года версия 2.2 пользовательского пространства ISA[1] и версия 1.11 привилегированной ISA[2] находятся замороженный, позволяя продолжить разработку программного и аппаратного обеспечения. ISA пользовательского пространства, теперь переименованная в Unprivileged ISA, была обновлена, ратифицирована и заморожена как версия 20191213.[6] Спецификация отладки доступна в виде черновика версии 0.13.2.[2]

Обоснование

Прототип процессора RISC-V, январь 2013 г.

Конструкция процессора требуется опыт проектирования в нескольких специальностях: электроника цифровая логика, компиляторы, и операционные системы. Чтобы покрыть расходы такой команды, коммерческие поставщики компьютерной техники, такие как ARM Holdings и MIPS Technologies обвинять роялти за использование их дизайнов, патенты и авторские права.[7][8][9] Они также часто требуют соглашения о неразглашении перед выпуском документов, в которых подробно описаны преимущества их проектов. Во многих случаях они никогда не описывают причины своего выбора дизайна.

RISC-V был начат с целью сделать практическую ISA с открытым исходным кодом, пригодную для использования в академических целях и в любом аппаратном или программном обеспечении без лицензионных отчислений.[1][10] Кроме того, обоснование каждой части проекта объясняется, по крайней мере, в общих чертах. Авторы RISC-V - ученые, имеющие значительный опыт в компьютерном дизайне. RISC-V ISA является прямым развитием серии академических проектов компьютерного дизайна. Частично он был создан для помощи таким проектам.[1][10]

Чтобы создать большое, непрерывное сообщество пользователей и, таким образом, накапливать проекты и программное обеспечение, разработчики RISC-V ISA планировали поддерживать широкий спектр практических применений: небольшие, быстрые и маломощные реализации в реальном мире,[1][11] без чрезмерной разработки для конкретного микроархитектура.[1][12][13][14] Необходимость в большой базе участников - одна из причин, по которой RISC-V был разработан для стольких целей.

Разработчики говорят, что набор инструкций является основным интерфейсом в компьютере, потому что он находится между оборудованием и программным обеспечением. Если бы хороший набор инструкций был открыт и доступен для всех, то он должен резко снизить стоимость программного обеспечения, разрешив гораздо большее повторное использование. Это также должно усилить конкуренцию между поставщиками оборудования, которые могут использовать больше ресурсов для проектирования и меньше - для поддержки программного обеспечения.[10]

Разработчики утверждают, что новые принципы в конструкции наборов команд становятся редкостью, поскольку наиболее успешные разработки последних сорока лет становятся все более похожими. Из тех, кто потерпел неудачу, большинство сделали это потому, что их спонсирующие компании потерпели неудачу в коммерческом плане, а не потому, что наборы инструкций были плохими технически. Таким образом, хорошо продуманный открытый набор инструкций, разработанный с использованием устоявшихся принципов, должен получить долгосрочную поддержку со стороны многих поставщиков.[10]

RISC-V также поддерживает академическое использование дизайнеров. Простота целочисленного подмножества позволяет студентам выполнять базовые упражнения. Целочисленное подмножество - это простой ISA, позволяющий программному обеспечению управлять исследовательскими машинами. ISA переменной длины позволяет выполнять расширения как для упражнений студентов, так и для исследований.[1] Разделенный набор привилегированных инструкций позволяет исследовать поддержку операционных систем без изменения компиляторов.[15] Открытая интеллектуальная собственность RISC-V позволяет публиковать, повторно использовать и изменять его проекты.[1]

История

Период, термин RISC датируется примерно 1980 годом.[16] До этого были некоторые знания, что более простые компьютеры могут быть эффективными, но принципы проектирования широко не описывались. Простые и эффективные компьютеры всегда вызывали академический интерес. Ученые создали набор инструкций RISC DLX для первого издания Компьютерная архитектура: количественный подход в 1990 г. Дэвид Паттерсон был автором, а позже ассистировал RISC-V. DLX был предназначен для использования в образовательных целях; ученые и любители реализовали его, используя программируемые вентильные матрицы, но это не имело коммерческого успеха. Процессоры ARM версий 2 и ранее имели общедоступный набор команд, и он по-прежнему поддерживается Коллекция компиляторов GNU (GCC), популярный бесплатно программное обеспечение компилятор. Три открытых источника ядра существуют для этой ISA, но они не были произведены.[17][18] OpenRISC ISA с открытым исходным кодом, основанная на DLX, со связанными конструкциями RISC. Он полностью поддерживается GCC и Linux реализаций, хотя у него мало коммерческих реализаций.

Крсте Асанович в Калифорнийском университете в Беркли нашел множество применений для компьютерной системы с открытым исходным кодом. В 2010 году он решил разработать и опубликовать один в «коротком трехмесячном проекте за лето». План состоял в том, чтобы помочь как академическим, так и промышленным пользователям.[10] Дэвид Паттерсон в Беркли тоже помогли. Первоначально он определил свойства Berkeley RISC,[16] а RISC-V - один из его длинной серии совместных исследовательских проектов RISC. На этом этапе студенты недорого предоставили начальное программное обеспечение, моделирование и проекты ЦП.[5]

Первый Raven1 представит ST28nm на BWRC в июне 2012 г.

Авторы RISC-V и их организация изначально предоставили документы ISA.[19] и несколько конструкций ЦП под Лицензии BSD, которые позволяют производным продуктам - таким как проекты микросхем RISC-V - быть либо открытыми и бесплатными, либо закрытыми и проприетарными. Сама спецификация ISA (то есть кодировка набора инструкций) была опубликована в 2011 году, все права защищены. Фактический текст технического отчета (выражение спецификации) позже был передан под лицензию Creative Commons, чтобы позволить его улучшать внешними участниками через RISC-V Foundation, а затем RISC-V International.

Полная история RISC-V опубликована на сайте RISC-V International.[20]

Фонд RISC-V и RISC-V International

Коммерческим пользователям требуется, чтобы ISA была стабильной, прежде чем они смогут использовать ее в продукте, который может прослужить много лет. Для решения этой проблемы был создан фонд RISC-V Foundation для владения, обслуживания и публикации интеллектуальной собственности, связанной с определением RISC-V.[21] Первоначальные авторы и владельцы передали фонду свои права.[22]

В ноябре 2019 года фонд RISC-V объявил о переезде в Швейцария, ссылаясь на озабоченность по поводу торговых правил США.[23] По состоянию на март 2020 года организация получила название RISC-V International, швейцарская некоммерческая бизнес-ассоциация.[24]

По состоянию на 2019 год, RISC-V International свободно публикует документы, определяющие RISC-V, и разрешает неограниченное использование ISA для разработки программного и аппаратного обеспечения. Однако только члены RISC-V International могут голосовать за одобрение изменений, и только членские организации используют товарный знак логотип совместимости.[22]

Награды

  • 2017: Премия «Выбор аналитика» Linley Group за лучшую технологию (за набор инструкций)[25]

Дизайн

База и расширения ISA

RISC-V имеет модульную конструкцию, состоящую из альтернативных базовых частей с добавленными дополнительными расширениями. База ISA и ее расширения разрабатываются совместными усилиями промышленности, исследовательского сообщества и образовательных учреждений. База определяет инструкции (и их кодировку), поток управления, регистры (и их размеры), память и адресацию, логические (то есть целочисленные) манипуляции и вспомогательные функции. Только на базе можно реализовать упрощенный компьютер общего назначения с полной программной поддержкой, включая компилятор общего назначения.

Стандартные расширения предназначены для работы со всеми стандартными базами и друг с другом без конфликтов.

Многие компьютеры RISC-V могут реализовать компактное расширение для уменьшения энергопотребления, размера кода и использования памяти.[1] Есть также планы на будущее по поддержке гипервизоры и виртуализация.[15]

Вместе с расширением набора команд супервизора, S, RVGC определяет все инструкции, необходимые для удобной поддержки общего назначения. Операционная система.

База и расширения ISA (20191213)
ИмяОписаниеВерсияПоложение дел[а]
Основание
RVWMOСлабая память2.0Ратифицирован
RV32IБазовый набор целочисленных команд, 32-разрядный2.1Ратифицирован
RV32EБазовый набор целочисленных команд (встроенный), 32 бита, 16 регистров1.9Открыть
RV64IБазовый набор целочисленных команд, 64-разрядный2.1Ратифицирован
RV128IБазовый набор целочисленных инструкций, 128 бит1.7Открыть
Расширение
MСтандартное расширение для целочисленного умножения и деления2.0Ратифицирован
АСтандартное расширение для атомарных инструкций2.1Ратифицирован
FСтандартное расширение для чисел с плавающей запятой одинарной точности2.2Ратифицирован
DСтандартное расширение для чисел с плавающей запятой двойной точности2.2Ратифицирован
граммСокращение для базового набора целых чисел (I) и более высоких расширений (MAFD)Нет данныхНет данных
QСтандартное расширение для чисел с плавающей запятой четверной точности2.2Ратифицирован
LСтандартное расширение для десятичных чисел с плавающей запятой0.0Открыть
CСтандартное расширение для сжатых инструкций2.0Ратифицирован
BСтандартное расширение для обработки битов0.92Открыть
JСтандартное расширение для динамически переводимых языков0.0Открыть
ТСтандартное расширение для транзакционной памяти0.0Открыть
пСтандартное расширение для инструкций Packed-SIMD0.2Открыть
VСтандартное расширение для векторных операций0.9Открыть
NСтандартное расширение для прерываний на уровне пользователя1.1Открыть
ЧАССтандартное расширение для гипервизора0.4Открыть
ZiCSRРегистр управления и состояния (CSR)2.0Ратифицирован
ZifenceiИнструкция-Получение Забора2.0Ратифицирован
ЗамНесогласованные атомы0.1Открыть
ZtsoВсего заказов в магазине0.1Замороженный
  1. ^ Ожидается, что замороженные детали будут иметь свой окончательный набор функций и получат только разъяснения до ратификации.
32-битные форматы инструкций RISC-V
ФорматКусочек
313029282726252423222120191817161514131211109876543210
Зарегистрироваться / зарегистрироватьсяfunct7RS2RS1funct3rdкод операции
Немедленныйimm [11: 0]rs1funct3rdкод операции
Верхний немедленныйimm [31:12]rdкод операции
Магазинimm [11: 5]RS2rs1funct3imm [4: 0]код операции
Ответвляться[12]imm [10: 5]RS2rs1funct3imm [4: 1][11]код операции
Прыгать[20]imm [10: 1][11]imm [19:12]rdкод операции
  • код операции (7 бит): Частично указывает, какой из 6 типов форматы инструкций.
  • funct7 и funct3 (10 бит): Эти два поля дальше код операции укажите операцию, которую нужно выполнить.
  • rs1 (5 бит): Задает по индексу регистр, содержащий первый операнд (т. Е. Регистр источника).
  • rs2 (5 бит): Задает второй регистр операнда.
  • rd (5 бит): Задает регистр назначения, в который будет направлен результат вычисления.

Чтобы приручить сочетания функциональных возможностей, которые могут быть реализованы, определена номенклатура, определяющая их в главе 27 текущей утвержденной непривилегированной спецификации ISA. Сначала указывается база набора команд, кодировка для RISC-V, разрядность регистра и вариант; например, RV64I или RV32E. Затем следуют буквы, обозначающие реализованные расширения, в порядке, указанном в таблице выше. За каждой буквой может следовать старший, необязательно, за которым следует "p" и младший номер опции. Если дополнительный номер версии опущен, он по умолчанию равен 0, а если номер версии полностью опущен, он по умолчанию равен 1.0. Таким образом, RV64IMAFD может быть записан как RV64I1p0M1p0A1p0F1p0D1p0 или проще как RV64I1M1A1F1D1. Подчеркивание может использоваться между расширениями для удобства чтения, например RV32I2_M2_A2.

Базовые, расширенные целочисленные вычисления и вычисления с плавающей запятой, а также примитивы синхронизации для многоядерных вычислений, базовый и расширенный MAFD, считаются необходимыми для вычислений общего назначения и, таким образом, имеют сокращенное обозначение G.

Небольшой 32-битный компьютер для Встроенная система может быть RV32EC. Большой 64-битный компьютер может быть RV64GC; то есть сокращение для RV64IMAFDC.

С ростом количества расширений стандарт теперь предусматривает, что расширения должны именоваться одной буквой "Z", за которой следует буквенное имя и необязательный номер версии. Например, Zifencei называет расширение для получения инструкций. Zifencei2 и Zifencei2p0 называют версию 2.0 одинаковыми. Первая буква, следующая за «Z» по соглашению, указывает на наиболее тесно связанную категорию алфавитного расширения, IMAFDQLCBJTPVN. Таким образом, расширение Zam для смещенных атомных элементов относится к стандартному расширению "A". В отличие от односимвольных расширений, расширения Z должны быть разделены подчеркиванием, сгруппированы по категориям, а затем в алфавитном порядке внутри каждой категории. Например Zicsr Zifencei Zam.

Расширения, относящиеся к уровню привилегий супервизора, называются таким же образом с префиксом "S". Расширения, относящиеся к уровню гипервизора, называются с использованием префикса "H". Расширения машинного уровня имеют префикс из трех букв «Zxm». Расширения набора команд супервизора, гипервизора и машинного уровня названы в честь менее привилегированных расширений.

Разработчики RISC-V могут создавать свои собственные нестандартные расширения набора команд. Они соответствуют соглашению об именах "Z", но с префиксом "X". Их следует указывать после всех стандартных расширений, а если указано несколько нестандартных расширений, они должны быть перечислены в алфавитном порядке.

Наборы регистров

регистр
имя
Символический
имя
ОписаниеСохранено
32 целое число регистры
x0НульВсегда ноль
x1раОбратный адресЗвонящий
x2зрУказатель стекаCallee
x3GPГлобальный указатель
x4tpУказатель потока
x5t0Временный / альтернативный обратный адресЗвонящий
x6–7t1–2ВременныйЗвонящий
x8s0 / fpСохраненный указатель регистра / кадраCallee
x9s1Сохраненный реестрCallee
x10–11a0–1Аргумент функции / возвращаемое значениеЗвонящий
x12–17a2–7Аргумент функцииЗвонящий
x18–27s2–11Сохраненный реестрCallee
x28–31t3–6ВременныйЗвонящий
32 плавающая точка регистры расширения
f0–7ft0–7Временные библиотеки с плавающей запятойЗвонящий
f8–9fs0–1Сохраненные регистры с плавающей запятойCallee
f10–11fa0–1Аргументы с плавающей запятой / возвращаемые значенияЗвонящий
f12–17fa2–7Аргументы с плавающей точкойЗвонящий
f18–27fs2–11Сохраненные регистры с плавающей запятойCallee
f28–31ft8–11Временные библиотеки с плавающей точкойЗвонящий

RISC-V имеет 32 (или 16 во встроенном варианте) целое число регистров, и, когда реализовано расширение с плавающей запятой, отдельные 32 плавающая точка регистры. За исключением инструкций доступа к памяти, инструкции относятся только к регистрам.

Первый целочисленный регистр - это нулевой регистр, а остальные - регистры общего назначения. Сохранение в нулевом регистре не имеет никакого эффекта, а чтение всегда дает 0. Использование нулевого регистра в качестве заполнителя упрощает набор инструкций.

переместить RX в Ry становится добавить r0 к rx и сохранить в ry.[1]

Регистры управления и состояния существуют, но программы пользовательского режима могут обращаться только к тем, которые используются для измерения производительности и управления с плавающей запятой.

Никаких инструкций по сохранению и восстановлению нескольких регистров не существует. Они считались ненужными, слишком сложными и, возможно, слишком медленными.[1]

Доступ к памяти

Как и многие проекты RISC, RISC-V является архитектура загрузки и хранения: инструкции адресуют только регистры, а инструкции загрузки и сохранения передаются в память и из памяти.

Большинство инструкций загрузки и сохранения включают 12-битное смещение и два идентификатора регистра. Один регистр - это базовый регистр. Другой регистр - это источник (для магазина) или назначения (для груза).

Смещение добавляется в базовый регистр, чтобы получить адрес. Формирование адреса в виде базового регистра плюс смещение позволяет отдельным инструкциям обращаться к структурам данных. Например, если базовый регистр указывает на вершину стека, отдельные инструкции могут обращаться к локальным переменным подпрограммы в стеке. Точно так же инструкции загрузки и сохранения могут обращаться к структуре в стиле записи или к отображенному в память устройству ввода-вывода. Использование постоянного нулевого регистра в качестве базового адреса позволяет отдельным инструкциям обращаться к памяти, близкой к нулевому адресу.[1]

Память адресуется как 8-битные байты, слова находятся в прямой порядок байтов порядок.[1] Слова, вплоть до размера регистра, могут быть доступны с помощью инструкций загрузки и сохранения.

Адреса памяти, к которой осуществляется доступ, не нужно выравнивать по ширине слова, но доступ к выровненным адресам может быть быстрее; например, простые ЦП могут реализовать невыровненный доступ с медленной программной эмуляцией, вызванной прерыванием сбоя выравнивания.[1]

Как и многие наборы инструкций RISC (и некоторые компьютер со сложной системой команд (CISC) наборы инструкций, такие как x86 и IBM System / 360 семейства), в RISC-V отсутствуют режимы адресации, которые осуществляют обратную запись в регистры. Например, он не увеличивается автоматически.[1]

RISC-V управляет системами памяти, которые разделяются между процессорами или потоки гарантируя, что поток выполнения всегда видит свои операции с памятью в запрограммированном порядке. Но между потоками и устройствами ввода-вывода RISC-V упрощен: он не гарантирует порядок операций с памятью, за исключением определенных инструкций, таких как изгородь.

А изгородь Инструкция гарантирует, что результаты предшествующих операций видны последующим операциям других потоков или устройств ввода-вывода. изгородь может гарантировать порядок комбинаций как операций ввода-вывода, так и операций ввода-вывода, отображаемых в памяти. Например. он может разделять операции чтения и записи в память, не влияя на операции ввода-вывода. Или, если система может управлять устройствами ввода-вывода параллельно с памятью, изгородь не заставляет их ждать друг друга. Один процессор с одним потоком может декодировать изгородь в качестве нет.

RISC-V имеет прямой порядок байтов, чтобы напоминать другие знакомые успешные компьютеры, например, x86. Это также снижает сложность ЦП и немного снижает затраты, поскольку он считывает слова всех размеров в одном и том же порядке. Например, набор команд RISC-V декодирует, начиная с байта инструкции с наименьшим адресом. Спецификация оставляет открытой возможность использования нестандартных систем с прямым порядком байтов или обратным порядком байтов.[1]

Некоторые процессоры RISC (например, MIPS, PowerPC, DLX и RISC-I Беркли) помещают 16 битов смещения в загрузки и запоминания. Они устанавливают старшие 16 бит загрузить верхнее слово инструкция. Это позволяет легко устанавливать значения верхнего полуслова без сдвига битов. Однако в большинстве случаев команда верхнего полуслова создает 32-битные константы, такие как адреса. RISC-V использует SPARC -подобная комбинация 12-битных смещений и 20-битных установить верхний инструкции. Меньшее 12-битное смещение помогает компактным 32-битным инструкциям загрузки и сохранения выбирать два из 32 регистров, но при этом иметь достаточно бит для поддержки кодирования инструкций переменной длины в RISC-V.[1]

Немедленно

RISC-V обрабатывает 32-битные константы и адреса с помощью инструкций, которые устанавливают старшие 20 бит 32-битного регистра. Загрузить верхний немедленный lui загружает 20 битов в биты с 31 по 12. Затем вторая инструкция, например добавить можно установить нижние 12 бит.

Этот метод расширен, чтобы разрешить позиционно-независимый код добавив инструкцию, Auipc который генерирует 20 старших адресных битов, добавляя смещение к счетчику программы и сохраняя результат в базовом регистре. Это позволяет программе генерировать 32-битные адреса, относящиеся к счетчику программы.

Базовый регистр часто может использоваться как есть с 12-битными смещениями загрузок и запоминаний. Если нужно, добавить может установить младшие 12 бит регистра. В 64-битных и 128-битных ISAlui и Auipc знак - расширить результат, чтобы получить больший адрес.[1]

Некоторые быстрые процессоры могут интерпретировать комбинации инструкций как отдельные сплавлен инструкции. lui или же Auipc могут быть хорошими кандидатами для слияния с добавить, грузы или магазины.

Вызов подпрограмм, переходы и переходы

Вызов подпрограммы RISC-V джал (переход и ссылка) помещает свой обратный адрес в регистр. Это быстрее во многих компьютерных конструкциях, потому что это экономит доступ к памяти по сравнению с системами, которые помещают адрес возврата непосредственно в стек в памяти. джал имеет 20-битное смещение со знаком (дополнение до 2). Смещение умножается на 2, затем добавляется к ПК для генерации относительного адреса 32-битной инструкции. Если результат не по 32-битному адресу (т. Е. Не делится на 4), ЦП может принудительно исключение.[1]

Процессоры RISC-V переходят к вычисленным адресам с помощью переход и ссылка-регистрация, jalr инструкция. jalr похоже на джал, но получает свой адрес назначения, добавляя 12-битное смещение к базовому регистру. (В отличие,джал добавляет к ПК большее 20-битное смещение.)

jalrБитовый формат подобен загрузке и хранению относительно регистров. Как они, jalr может использоваться с инструкциями, которые устанавливают старшие 20 бит базового регистра для создания 32-битных ветвей, либо к абсолютному адресу (используя lui) или относящегося к ПК (используя Auipc за позиционно-независимый код ). (Использование постоянного нулевого базового адреса позволяет вызывать одиночные инструкции по маленькому (смещение), фиксированному положительному или отрицательному адресу.)

RISC-V перерабатывает джал и jalr для получения безусловных 20-битных переходов относительно ПК и безусловных 12-битных переходов на основе регистров. Прыжки просто делают регистр связи 0, так что адрес возврата не сохраняется.[1]

RISC-V также перерабатывает jalr для возврата из подпрограммы: Для этого jalrбазовый регистр установлен как регистр связи, сохраненный джал или же jalr. jalrсмещение равно нулю, а регистр связи равен нулю, так что смещения нет и адрес возврата не сохраняется.

Как и во многих проектах RISC, в вызове подпрограммы компилятор RISC-V должен использовать отдельные инструкции для сохранения регистров в стек в начале, а затем восстанавливать их из стека при выходе. RISC-V не имеет сохранить несколько или же восстановить несколько зарегистрируйте инструкцию. Считалось, что это делает ЦП слишком сложным и, возможно, медленным.[26] Это может занять больше места для кода. Разработчики планировали уменьшить размер кода с помощью библиотечных подпрограмм для сохранения и восстановления регистров.[27]

RISC-V не имеет регистр кода состояния или же бит для переноски. Разработчики считали, что коды условий усложняют быстрые процессоры, вынуждая взаимодействовать между инструкциями на разных этапах выполнения. Этот выбор усложняет арифметику с множественной точностью. Кроме того, несколько числовых задач требуют больше энергии. Как результат, предикация (условное выполнение инструкций) не поддерживается. Разработчики утверждают, что очень быстрые, неупорядоченные конструкции ЦП все равно выполняют предсказание, выполняя ветвь сравнения и условный код параллельно, а затем отбрасывая эффекты неиспользуемого пути. Они также утверждают, что даже в более простых процессорах предсказание менее ценно, чем предсказание ветвления, что может предотвратить большинство задержек, связанных с условными переходами. Код без предиката больше, с большим количеством ветвей, но они также утверждают, что сжатый набор инструкций (например, набор RISC-V C) решает эту проблему в большинстве случаев.[1]

Вместо этого RISC-V имеет короткие ветви, которые выполняют сравнения: равно, не равно, меньше, без знака меньше, больше или равно и без знака больше или равно. Десять операций сравнения-ветвления реализованы всего с шестью инструкциями, путем изменения порядка операндов в ассемблер. Например, ветвь, если больше может быть сделано меньше, чем с обратным порядком операндов.[1]

Ветви сравнения имеют 12-битный диапазон со знаком и переходят относительно ПК.[1]

В отличие от некоторых архитектур RISC, RISC-V не включает слот задержки перехода, позиция после инструкции перехода, которая может быть заполнена инструкцией, которая выполняется независимо от того, выполняется переход или нет. В RISC-V отсутствует слот задержки ветвления, поскольку он усложняет многоцикловые ЦП, суперскалярные ЦП и длинные конвейеры. Динамический предикторы ветвления оказались достаточно успешными, чтобы снизить потребность в отложенных переходах.[1]

При первом столкновении с ветвью процессоры RISC-V должны предположить, что будет принято отрицательное относительное ветвление (т. Е. Бит знака смещения равен «1»).[1] Это предполагает, что обратная ветвь является циклом, и обеспечивает направление по умолчанию, чтобы простые конвейерные процессоры могли заполнить свой конвейер инструкций. Кроме этого, RISC-V не требует предсказание ветвления, но базовые реализации могут добавлять его. RV32I резервирует пространство инструкций «HINT», которое в настоящее время не содержит никаких подсказок по ветвям.[1]

Арифметические и логические наборы

RISC-V разделяет математику на минимальный набор целое число инструкции (установить я) с сложение, вычитание, сдвиг, побитовая логика и сравнения-ветки. Они могут имитировать большинство других наборов команд RISC-V с помощью программного обеспечения. (Атомарные инструкции являются заметным исключением.) RISC-V в настоящее время не имеет считать ведущий ноль и операции с битовым полем, обычно используемые для ускорения программного вычисления с плавающей запятой в чисто целочисленном процессоре.

Инструкции целочисленного умножения (набор M) включает знаковое и беззнаковое умножение и деление. Включены целочисленные умножения и деления двойной точности, а также умножения и деления, которые производят высокое слово результата. Документ ISA рекомендует разработчикам процессоров и компиляторов предохранитель стандартизированная последовательность команд умножения и деления на одну операцию, если это возможно.[1]

В плавающая точка инструкции (установить F) включает в себя арифметику одинарной точности, а также ветви сравнения, аналогичные целочисленной арифметике. Требуется дополнительный набор из 32 регистров с плавающей запятой. Они отделены от целочисленных регистров. Инструкции с плавающей запятой двойной точности (set D) обычно предполагают, что регистры с плавающей запятой являются 64-битными (т. е. двойной ширины), а F подмножество согласовано с D набор. 128-битный код ISA с плавающей запятой четырехкратной точности (Q) также определяется. Компьютеры RISC-V без операций с плавающей запятой могут использовать программную библиотеку с плавающей запятой.[1]

RISC-V не вызывает исключения по арифметическим ошибкам, в том числе переполнение, недополнение, субнормальное и делить на ноль. Вместо этого и целочисленная арифметика, и арифметика с плавающей запятой создают разумные значения по умолчанию и устанавливают биты состояния. Разделение на ноль может быть обнаружено по одной ветви после деления. Биты состояния могут быть проверены операционной системой или периодическим прерыванием.[1]

Атомарные операции с памятью

RISC-V поддерживает компьютеры, которые разделяют память между несколькими процессорами и потоки. Стандартная модель согласованности памяти RISC-V согласованность выпуска. То есть грузы и склады, как правило, могут быть переупорядочены, но некоторые грузы могут быть обозначены как приобретать операции, которые должны предшествовать более позднему доступу к памяти, и некоторые хранилища могут быть обозначены как релиз операции, которые должны следовать за более ранними обращениями к памяти.[1]

Базовый набор команд включает минимальную поддержку в виде изгородь инструкция для принудительного упорядочивания памяти. Хотя этого достаточно (забор r, rw обеспечивает приобретать и забор RW, W обеспечивает релиз), комбинированные операции могут быть более эффективными.[1]

Расширение операций с атомарной памятью поддерживает два типа операций с атомарной памятью для согласованности выпуска. Во-первых, он обеспечивает общее назначение зарезервировано для загрузки lr и магазин-условный sc инструкции. lr выполняет загрузку и пытается зарезервировать этот адрес для своего потока. Более поздний магазин-условный sc на зарезервированный адрес будет выполняться только в том случае, если резервирование не будет нарушено промежуточным магазином из другого источника. В случае успешного сохранения в регистр помещается ноль. Если это не удалось, ненулевое значение указывает на то, что программе необходимо повторить операцию. В любом случае бронирование снимается.[1]

Вторая группа атомарных инструкций выполняет читать-изменять-писать последовательности: загрузка (которая, возможно, является загрузкой-получением) в регистр назначения, затем операция между загруженным значением и исходным регистром, затем сохранение результата (которое, возможно, может быть сохранением-выпуском). Создание дополнительных барьеров памяти позволяет комбинировать операции. Дополнительные операции включены приобретать и релиз биты, которые присутствуют в каждой атомарной инструкции. RISC-V определяет девять возможных операций: своп (напрямую использовать значение исходного регистра); Добавить; побитовое и, или, и исключающее-ИЛИ; и подписанный и беззнаковый минимум и максимум.[1]

Дизайн системы может оптимизировать эти комбинированные операции более чем lr и sc. Например, если регистр назначения для свопа имеет постоянный ноль, загрузка может быть пропущена. Если сохраненное значение не изменилось с момента загрузки, сохранение можно пропустить.[1]

В IBM System / 370 и его преемники, включая z / Архитектура, и x86, оба реализуют сравнивать и менять местами (cas) инструкция, которая проверяет и условно обновляет ячейку в памяти: если ячейка содержит ожидаемое старое значение, cas заменяет его заданным новым значением; Затем он возвращает указание, внесено ли изменение. Однако простая инструкция типа загрузки обычно выполняется перед cas чтобы получить старое значение. Классическая проблема заключается в том, что если поток читает (загружает) значение А, вычисляет новое значение C, а затем использует (cas) заменить А с C, у него нет способа узнать, заменила ли одновременная активность в другом потоке А с другим значением B а затем восстановил А между. В некоторых алгоритмах (например, в которых значения в памяти являются указателями на динамически выделяемые блоки) это Проблема ABA может привести к неверным результатам. В наиболее распространенном решении используется двойной шириной cas инструкция для обновления как указателя, так и соседнего счетчика; К сожалению, такая инструкция требует специального формата инструкции для указания нескольких регистров, выполняет несколько операций чтения и записи и может иметь сложную работу шины.[1]

В lr/sc альтернатива более эффективна. Обычно для этого требуется только одна загрузка памяти, и желательно минимизировать медленные операции с памятью. Это также точно: он контролирует все обращения к ячейке памяти, а не просто обеспечивает битовый шаблон. Однако в отличие от cas, это может разрешить лайвлок, в котором два или более потока неоднократно приводят к сбою инструкций друг друга. RISC-V гарантирует продвижение вперед (без живой блокировки), если код следует правилам по времени и последовательности инструкций: 1) Он должен использовать только я подмножество. 2) Чтобы предотвратить повторяющиеся промахи в кэше, код (включая цикл повтора) должен занимать не более 16 последовательных инструкций. 3) Он не должен включать никаких системных инструкций или инструкций по ограждению, или взятых обратных ветвей между lr и sc. 4) Обратный переход к циклу повтора должен соответствовать исходной последовательности.[1]

В спецификации приведены примеры того, как использовать это подмножество для блокировки структуры данных.[1]

Сжатое подмножество

Стандарт RISC-V ISA определяет, что все инструкции 32-битные. Это делает реализацию особенно простой, но, как и другие процессоры RISC с такой кодировкой инструкций, приводит к большему размеру кода, чем в других наборах инструкций.[1][26]Чтобы компенсировать это, RISC-V 32-битный инструкции на самом деле 30 бит; Взаимодействие с другими людьми34 из код операции пространство зарезервировано для необязательного (но рекомендуемого) переменной длины сжатый набор команд, RVC, который включает 16-битные инструкции. Подобно ARM Thumb и MIPS16, сжатые инструкции являются просто псевдонимами для подмножества более крупных инструкций. В отличие от ARM Thumb или сжатого набора MIPS, пространство было зарезервировано с самого начала, поэтому отдельного режима работы нет. Стандартные и сжатые инструкции могут свободно смешиваться.[1][26] (письмо C)[27]

Поскольку (подобно Thumb-1 и MIPS16) сжатые инструкции представляют собой просто альтернативные кодировки (псевдонимы) для выбранного подмножества более крупных инструкций, сжатие может быть реализовано в ассемблере, и компилятору не обязательно даже знать об этом.

Опытный образец РВК прошел испытания в 2011 году.[26] Код прототипа был на 20% меньше, чем x86 ПК и MIPS сжатый код и на 2% больше, чем РУКА Большой палец-2 код.[26] Это также существенно сократило как необходимую кэш-память, так и предполагаемое энергопотребление системы памяти.[26]

Исследователь намеревался уменьшить двоичный размер кода для небольших компьютеров, особенно Встраиваемый компьютер системы. Прототип включал 33 наиболее часто используемых инструкции, перекодированных в компактные 16-битные форматы с использованием кодов операций, ранее зарезервированных для сжатого набора.[26] Сжатие производилось в ассемблер, без изменений в компиляторе. Сжатые инструкции пропускали поля, которые часто равны нулю, использовали небольшие непосредственные значения или используемые подмножества (16 или 8) регистров. добавить очень распространен и часто сжимается.[26]

Большая разница в размере по сравнению с набором Thumb для ARM возникла из-за того, что RISC-V и прототип не имеют инструкций по сохранению и восстановлению нескольких регистров. Вместо этого компилятор сгенерировал обычные инструкции для доступа к стеку. Затем прототип RVC-ассемблера часто преобразовывал их в сжатые формы, которые были вдвое меньше. However, this still took more code space than the ARM instructions that save and restore multiple registers. The researcher proposed to modify the compiler to call library routines to save and restore registers. These routines would tend to remain in a code cache and thus run fast, though probably not as fast as a save-multiple instruction.[26]

Standard RVC requires occasional use of 32-bit instructions. Several nonstandard RVC proposals are complete, requiring no 32-bit instructions, and are said to have higher densities than standard RVC.[28][29] Another proposal builds on these, and claims to use less coding range as well.[30]

Embedded subset

An instruction set for the smallest встроенный CPUs (set E) is reduced in other ways: Only 16 of the 32 integer registers are supported. Floating-point instructions should not be supported (the specification forbids it as uneconomical), so a floating-point software library must be used.[1] The compressed set C Рекомендовано. The privileged instruction set supports only machine mode, user mode and memory schemes that use base-and-bound address relocation.[15]

Discussion has occurred for a microcontroller profile for RISC-V, to ease development of deeply встроенные системы. It centers on faster, simple C-language support for interrupts, simplified security modes and a simplified POSIX application binary interface.[31]

Correspondents have also proposed smaller, non-standard, 16-bit RV16E ISAs: Several serious proposals would use the 16-bit C instructions with 8 × 16-bit registers.[29][28] An April fools' joke proposed a very practical arrangement: Utilize 16 × 16-bit integer registers, with the standard EIMC ISAs (including 32-bit instructions.) The joke was to propose переключение банка, when a 32-bit CPU would be clearly superior with the larger address space.[32]

Privileged instruction set

RISC-V's ISA includes a separate privileged instruction set specification. По состоянию на август 2019 г., version 1.11 is ratified by RISC-V International.[2][15]

Version 1.11 of the specification supports several types of computer systems:

  1. Systems that have only machine mode, perhaps for встроенные системы,
  2. Systems with both machine mode (for the руководитель ) and user-mode to implement operating systems that run the ядро in a privileged mode.
  3. Systems with machine-mode, гипервизоры, multiple supervisors, and user-modes under each supervisor.

These correspond roughly to systems with up to four кольца of privilege and security, at most: machine, hypervisor, supervisor and user. Each layer also is expected to have a thin layer of standardized supporting software that communicates to a more-privileged layer, or hardware.[15]

The overall plan for this ISA is to make the hypervisor mode ортогональный to the user and supervisor modes.[33] The basic feature is a configuration bit that either permits supervisor-level code to access hypervisor registers, or causes an interrupt on accesses. This bit lets supervisor mode directly handle the hardware needed by a hypervisor. This simplifies a type 2 hypervisor, hosted by an operating system. This is a popular mode to run warehouse-scale computers. To support type 1, unhosted hypervisors, the bit can cause these accesses to interrupt to a hypervisor. The bit simplifies nesting of hypervisors, in which a hypervisor runs under a hypervisor. It's also said to simplify supervisor code by letting the kernel use its own hypervisor features with its own kernel code. As a result, the hypervisor form of the ISA supports five modes: machine, supervisor, user, supervisor-under-hypervisor and user-under-hypervisor.

The privileged instruction set specification explicitly defines аппаратное обеспечение потоки, или же олени. Multiple hardware threads are a common practice in more-capable computers. When one thread is stalled, waiting for memory, others can often proceed. Hardware threads can help make better use of the large number of registers and execution units in fast out-of-order CPUs. Finally, hardware threads can be a simple, powerful way to handle прерывает: No saving or restoring of registers is required, simply executing a different hardware thread. However, the only hardware thread required in a RISC-V computer is thread zero.[15]

The existing control and status register definitions support RISC-V's error and memory exceptions, and a small number of interrupts. For systems with more interrupts, the specification also defines an interrupt controller. Interrupts always start at the highest-privileged machine level, and the control registers of each level have explicit пересылка bits to route interrupts to less-privileged code. For example, the hypervisor need not include software that executes on each interrupt to forward an interrupt to an operating system. Instead, on set-up, it can set bits to forward the interrupt.[15]

Several memory systems are supported in the specification. Physical-only is suited to the simplest встроенные системы. Также есть три UNIX -стиль виртуальная память systems for memory cached in mass-storage systems. The virtual memory systems have three sizes, with addresses sized 32, 39 and 48 bits. All virtual memory systems support 4 KiB pages, multilevel page-table trees and use very similar algorithms to walk the page table trees. All are designed for either hardware or software page-table walking. To optionally reduce the cost of page table walks, super-sized pages may be leaf pages in higher levels of a system's page table tree. SV32 has a two-layer page table tree and supports 4 MiB superpages. SV39 has a three level page table, and supports 2 MiB superpages and 1 GiB gigapages. SV48 is required to support SV39. It also has a 4-level page table and supports 2 MiB superpages, 1 GiB gigapages, and 512 GiB terapages. Superpages are aligned on the page boundaries for the next-lowest size of page.[15]

Bit manipulation

An unapproved bit-manipulation (B) ISA for RISC-V was under review in January 2020.[требуется разъяснение ] Done well, a bit-manipulation subset can aid cryptographic, graphic, and mathematical operations. The criteria for inclusion documented in the draft were compliance with RV5 philosophies and ISA formats, substantial improvements in code density or speed (i.e., at least a 3-for-1 reduction in instructions), and substantial real-world applications, including preexisting compiler support. Version 0.92 includes[34] instructions to count leading zeros, count one bits, perform logic operations with complement, pack two words in one register, take the min or max, sign-extend, single-bit operations, shift ones, rotates, a generalized bit-reverse and shuffle, or-combines, bit-field place and extract, carry-less multiply, CRC instructions, bit-matrix operations (RV64 only), conditional mix, conditional move, funnel shifts, and unsigned address calculations.

Packed SIMD

Packed-SIMD instructions are widely used by commercial CPUs to inexpensively accelerate multimedia and other цифровая обработка сигналов.[1] For simple, cost-reduced RISC-V systems, the base ISA's specification proposed to use the floating-point registers' bits to perform parallel single instruction, multiple data (SIMD ) sub-word arithmetic.

In 2017 a vendor published a more detailed proposal to the mailing list, and this can be cited as version 0.1.[35] По состоянию на 2019 год, the efficiency of this proposed ISA varies from 2x to 5x a base CPU for a variety of DSP codecs.[36] The proposal lacked instruction formats and a license assignment to RISC-V International, but it was reviewed by the mailing list.[35] Some unpopular parts of this proposal were that it added a condition code, the first in a RISC-V design, linked adjacent registers (also a first), and has a loop counter that could be difficult to implement in some microarchitectures.

A previous, well-regarded implementation for a 64-bit CPU was PA-RISC's multimedia instructions: Расширения мультимедийного ускорения. It increased the CPU's performance on digital signal processing tasks by 48-fold or more, enabling practical real-time video codecs в 1995 г.[37][38] Besides its native 64-bit math, the PA-RISC MAX2 CPU could do arithmetic on four 16-bit subwords at once, with several overflow methods. It also could move subwords to different positions. PA-RISC's MAX2 was intentionally simplified. It lacked support for 8-bit or 32-bit subwords. The 16-bit subword size was chosen to support most digital signal processing tasks. These instructions were inexpensive to design and build.

Vector set

The proposed vector-processing instruction set may make the packed SIMD set obsolete. The designers hope to have enough flexibility that a CPU can implement vector instructions in a standard processor's registers. This would enable minimal implementations with similar performance to a multimedia ISA, as above. However, a true vector coprocessor could execute the same code with higher performance.[39]

As of 29 June 2015, the vector-processing proposal is a conservative, flexible design of a general-purpose mixed-precision векторный процессор, suitable to execute вычислить ядра. Code would port easily to CPUs with differing vector lengths, ideally without recompiling.[39]

In contrast, short-vector SIMD extensions are less convenient. These are used in x86, РУКА и PA-RISC. In these, a change in word-width forces a change to the instruction set to expand the vector registers (in the case of x86, from 64-bit MMX registers to 128-bit Потоковые расширения SIMD (SSE), to 256-bit Расширенные векторные расширения (AVX), and AVX-512 ). The result is a growing instruction set, and a need to port working code to the new instructions.

In the RISC-V vector ISA, rather than fix the vector length in the architecture, an instruction (setvl) is available which takes a requested size and sets the vector length to the minimum of the hardware limit and the requested size. So, the RISC-V proposal is more like a Cray 's long-vector design or ARM's Scalable Vector Extension. That is, each vector in up to 32 vectors is the same length.[39]

The application specifies the total vector width it requires, and the processor determines the vector length it can provide with available on-chip resources. This takes the form of an instruction (vsetcfg) with four immediate operands, specifying the number of vector registers of each available width needed. The total must be no more than the addressable limit of 32, but may be less if the application does not require them all. The vector length is limited by the available on-chip storage divided by the number of bytes of storage needed for each entry. (Added hardware limits may also exist, which in turn may permit SIMD-style implementations.)[39]

Outside of vector loops, the application can zero the number of requested vector registers, saving the operating system the work of preserving them on переключатели контекста.[39]

The vector length is not only architecturally variable, but designed to vary at run time also. To achieve this flexibility, the instruction set is likely to use variable-width data paths and variable-type operations using polymorphic overloading.[39] The plan is that these can reduce the size and complexity of the ISA and compiler.[39]

Recent experimental vector processors with variable-width data paths also show profitable increases in operations per: second (speed), area (lower cost), and watt (longer battery life).[40]

Unlike a typical modern графический процессор, there are no plans to provide special hardware to support branch predication. Instead, lower cost compiler-based predication will be used.[39][41]

External debug system

There is a preliminary specification for RISC-V's hardware-assisted отладчик. The debugger will use a transport system such as Joint Test Action Group (JTAG ) or Universal Serial Bus (USB ) to access debug registers. A standard hardware debug interface may support either a standardized abstract interface или же instruction feeding.[42][43]

As of January 2017, the exact form of the абстрактный интерфейс remains undefined, but proposals include a memory mapped system with standardized addresses for the registers of debug devices or a command register and a data register accessible to the communication system.[42] Correspondents claim that similar systems are used by Freescale с интерфейс фонового режима отладки (BDM) for some CPUs, РУКА, OpenRISC, и Аэрофлекс с ЛЕОН.[42]

В instruction feeding, the CPU will process a debug exception to execute individual instructions written to a register. This may be supplemented with a data-passing register and a module to directly access the memory. Instruction feeding lets the debugger access the computer exactly as software would. It also minimizes changes in the CPU, and adapts to many types of CPU. This was said to be especially apt for RISC-V because it is designed explicitly for many types of computers. The data-passing register allows a debugger to write a data-movement loop to RAM, and then execute the loop to move data into or out of the computer at a speed near the maximum speed of the debug system's data channel.[42] Correspondents say that similar systems are used by MIPS Technologies MIPS, Intel Quark, Tensilica с Xtensa, и для Freescale Питание ISA CPUs' интерфейс фонового режима отладки (BDM).[42]

A vendor proposed a hardware trace subsystem for standardization, donated a conforming design, and initiated a review.[44][45] The proposal is for a hardware module that can trace code execution on most RV5 CPUs. To reduce the data rate, and permit simpler or less-expensive paths for the trace data, the proposal does not generate trace data that could be calculated from a binary image of the code. It sends only data that indicates "uninferrable" paths through the program, such as which conditional branches are taken. To reduce the data rates, branches that can be calculated, such as unconditional branches, are not traced. The proposed interface between the module and the control unit is a logic signal for each uninferrable type of instruction. Addresses and other data are to be provided in a specialized bus attached to appropriate data sources in a CPU. The data structure sent to an external trace unit is a series of short messages with the needed data. The details of the data channel are intentionally not described in the proposal, because several are likely to make sense.

Реализации

The RISC-V organization maintains a list of RISC-V CPU and SoC implementations.[46]

Существующий

Existing proprietary implementations include:

  • Alibaba Group, in July 2019 announced the 2.5 GHz 16-core 64-bit (RV64GCV) XuanTie 910 вышел из строя процессор[47]
  • Andes Technology Corporation, a founding member of RISC-V International[48] which joined the consortium in 2016, released its first two RISC-V cores in 2017. The cores, the N25 and NX25, come with complete design ecosystems and a number of RISC-V partners. Andes is actively driving the development of RISC-V ecosystem and expects to release several new RISC-V products in 2018.
  • CloudBEAR is a processor IP company that develops its own RISC-V cores for a range of applications.[49]
  • Codasip and UltraSoC have developed fully supported intellectual property for RISC-V embedded SOCs that combine Codasip's RISC-V cores and other IP with UltraSoC's debug, optimization and analytics.[50]
  • Cortus, a founding platinum member of the RISC-V foundation, has a number of RISC-V implementations and a complete IDE/toolchain/debug eco-system which it offers for free as part of its SoC design business.
  • GigaDevice has a series of MCUs based on RISC-V (RV32IMAC, GD32V series),[51] with one of them used on the Longan Nano board produced by a Chinese electronic company Sipeed.[52]
  • GreenWaves Technologies announced the availability of GAP8, a 32-bit 1 controller plus 8 compute cores, 32-bit SoC (RV32IMC) and developer board in February 2018. Their GAPuino GAP8 development board started shipping in May 2018.[53][54][55]
  • IAR Systems released the first version of IAR Embedded Workbench for RISC-V, which supports RV32 32-bit RISC-V cores and extensions in the first version. Future releases will include 64-bit support and support for the smaller RV32E base instruction set, as well as functional safety certification and security solutions.
  • Instant SoC RISC-V cores from FPGA Cores. System On Chip, including RISC-V cores, defined by C++.
  • Micro Magic Inc. announced the world's fastest 64-bit RISC-V core achieving 5GHz and 13,000 CoreMarks on October 2020.
  • SEGGER added support for RISC-V cores to their debug probe J-Link,[56] their integrated development environment Embedded Studio,[57] and their RTOS embOS and embedded software.[58]
  • SiFive, a company established specifically for developing RISC-V hardware, has processor models released in 2017.[59][60] These include a quad-core, 64-bit (RV64GC) система на чипе (SoC) capable of running general-purpose operating systems such as Linux.[61]
  • Syntacore,[62] a founding member of RISC-V International and one of the first commercial RISC-V IP vendors, develops and licenses family of RISC-V IP since 2015. As of 2018, product line includes eight 32- and 64-bit cores, including open-source SCR1 MCU core (RV32I/E[MC]).[63] First commercial SoCs, based on the Syntacore IP were demonstrated in 2016.[64]
  • UltraSOC proposed a standard trace system and donated an implementation.
  • Western Digital, in December 2018 announced an RV32IMC core called SweRV. The SweRV features an in-order 2-way superscalar and nine-stage pipeline design. WD plans to use SweRV based processors in their flash controllers and SSDs, and released it as open-source to third parties in January 2019.[65][66][67]
  • Эспрессиф[68] added a RISC-V ULP coprocessor to their ESP32-S2 microcontroller.[69]
  • As of 2020, Indian defence and strategic sector started using 64-bit RISC-V based 100-350 MHz Risecreek processor developed by Индийский технологический институт Мадрас (IIT-Madras) and fabricated by Intel with 22nm FinFET technology under Shakti Microprocessor программа.[70][71]

В развитии

Открытый исходный код

There are many open-sourced RISC-V CPU designs, including:

  • The Berkeley CPUs. These are implemented in a unique hardware design language, Долото, and some are named for famous train engines:
    • 64-bit Rocket.[85] Rocket may suit compact, low-power intermediate computers such as personal devices. Названный для Стивенсона Ракета.
    • В 64-битный Berkeley Out of Order Machine (BOOM).[86] The Berkeley Out-of-Order Machine (BOOM) is a synthesizable and parameterizable open source RV64GC RISC-V core written in the Chisel hardware construction language. BOOM uses much of the infrastructure created for Rocket, and may be usable for personal, supercomputer, and warehouse-scale computers.
    • Пять 32-битный Sodor CPU designs from Berkeley,[87] designed for student projects.[88] Содор is the fictional island of trains in childrens' stories about Томас Паровозик.
  • picorv32 by Claire Wolf,[89] a 32-bit microcontroller unit (MCU) class RV32IMC implementation in Verilog.
  • scr1 from Syntacore,[90]a 32-bit microcontroller unit (MCU) class RV32IMC implementation in Verilog.
  • PULPino (Riscy and Zero-Riscy) from ETH Zürich / University of Bologna.[91] В ядра in PULPino implement a simple RV32IMC ISA for microcontrollers (Zero-Riscy) or a more powerful RV32IMFC ISA with custom DSP extensions for embedded signal processing.

Программного обеспечения

A normal problem for a new instruction set is a lack of CPU designs and software. Both issues limit its usability and reduce adoption.[10]

The design software includes a design compiler, Долото[92], which can reduce the designs to Verilog for use in devices. The website includes verification data for testing core implementations.

Available RISC-V software tools include a Коллекция компиляторов GNU (GCC) toolchain (with GDB, the debugger), an LLVM toolchain, the OVPsim simulator (and library of RISC-V Fast Processor Models), the Spike simulator, and a simulator in QEMU (RV32GC/RV64GC).

Operating system support exists for the Linux ядро FreeBSD, и NetBSD, but the supervisor-mode instructions were unstandardized prior to June 2019,[15] so this support is provisional. The preliminary FreeBSD port to the RISC-V architecture was upstreamed in February 2016, and shipped in FreeBSD 11.0.[93][75] Порты Debian[94] и Fedora[95] are stabilizing (both only support 64-bit RISC-V, with no plans to support 32-bit version). Порт Das U-Boot существуют.[96] UEFI Spec v2.7 has defined the RISC-V binding and a TianoCore port has been done by HPE инженеры[97] and is expected to be upstreamed. There is a preliminary port of the seL4 microkernel.[98][99] Hex Five released the first Secure IoT Stack for RISC-V with FreeRTOS поддерживать.[100] Также xv6, a modern reimplementation of Sixth Edition Unix в ANSI C used for pedagogical purposes in Массачусетский технологический институт, was ported. Pharos RTOS has been ported to 64-bit RISC-V[101] (including time and memory protection). Также см Сравнение операционных систем реального времени.

A simulator exists to run a RISC-V Linux system on a веб-браузер с помощью JavaScript.[102][103][104]

The educational simulator WepSIM[105][106] implements (microprogrammed) a subset of RISC-V instructions (RV32I + M) and allows the execution of subroutines in assembly. Moreover, it is possible to add more RISC-V instructions (by microprogramming these instructions) and test the impact of its implementation. The WepSIM simulator can be used from a Web browser and facilitates learning various aspects of how a CPU works (microprogramming, interruptions, system calls, etc.) using RISC-V assembly.

QEMU supports running (using двоичная трансляция ) 32- and 64-bit RISC-V systems (i.e. Linux) with a number of emulated or virtualized devices (serial, parallel, USB, network, storage, real time clock, watchdog, audio), as well as running RISC-V Linux binaries (translating syscalls to the host kernel). It does support multi-core emulation (SMP).[107]

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

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

  1. ^ а б c d е ж грамм час я j k л м п о п q р s т ты v ш Икс у z аа ab ac объявление ае аф аг ах ай эй ак аль являюсь ан ао ap водный ар в качестве в Waterman, Andrew; Asanović, Krste. "The RISC-V Instruction Set Manual, Volume I: Base User-Level ISA version 2.2". Калифорнийский университет в Беркли. EECS-2016-118. Получено 25 мая 2017.
  2. ^ а б c d "Privileged ISA Specification". RISC-V International.
  3. ^ Big and bi-endianness supported as extensions
  4. ^ Wolf, Clifford. "Alternative proposal for instruction length encoding". Cliffords Subversion Servier. Clifford Wolf. Получено 20 октября 2019.
  5. ^ а б «Авторы». riscv.org. Регенты Калифорнийского университета. Получено 25 августа 2014.
  6. ^ Waterman, Andrew; Asanović, Krste. "The RISC-V Instruction Set Manual, Volume I: Unprivileged ISA version 20191213" (PDF). RISC-V International. Получено 27 августа 2020.
  7. ^ Demerjian, Chuck (7 August 2013). "A long look at how ARM licenses chips: Part 1". SemiAccurate.
  8. ^ Demerjian, Chuck (8 August 2013). "How ARM licenses its IP for production: Part 2". SemiAccurate.
  9. ^ "Wave Computing Closes Its MIPS Open Initiative with Immediate Effect, Zero Warning". 15 ноября 2019.
  10. ^ а б c d е ж Asanović, Krste. "Instruction Sets Should be Free" (PDF). U.C. Berkeley Technical Reports. Регенты Калифорнийского университета. Получено 15 ноября 2016.
  11. ^ "Rocket Core Generator". RISC-V. Регенты Калифорнийского университета. Получено 1 октября 2014.
  12. ^ Celio, Christopher; Love, Eric. "ucb-bar/riscv-sodor". GitHub Inc. Регенты Калифорнийского университета. Получено 12 февраля 2015.
  13. ^ а б "SHAKTI Processor Program". Индийский технологический институт Мадрас. Получено 3 сентября 2019.
  14. ^ Celio, Christopher. "CS 152 Laboratory Exercise 3" (PDF). Калифорнийский университет в Беркли. Регенты Калифорнийского университета. Получено 12 февраля 2015.
  15. ^ а б c d е ж грамм час я Waterman, Andrew; Lee, Yunsup; Avizienas, Rimas; Patterson, David; Asanović, Krste. "Draft Privileged ISA Specification 1.9". RISC-V. RISC-V International. Получено 30 августа 2016.
  16. ^ а б Паттерсон, Дэвид А.; Ditzel, David R. (October 1980). "The Case for the Reduced Instruction Set Computer". Новости компьютерной архитектуры ACM SIGARCH. 8 (6): 25. Дои:10.1145/641914.641917.
  17. ^ "Amber ARM-compatible core". OpenCores. Получено 26 августа 2014.
  18. ^ "ARM4U". OpenCores. OpenCores. Получено 26 августа 2014.
  19. ^ Asanović, Krste. "The RISC-V Instruction Set Manual, Volume I: Base User-Level ISA" (PDF). U.C. Berkeley Technical Reports. Регенты Калифорнийского университета. Получено 13 мая 2011.
  20. ^ "RISC-V History". Получено 19 ноября 2019.
  21. ^ "A new blueprint for microprocessors challenges the industry's giants". Экономист. 3 октября 2019. ISSN  0013-0613. Получено 10 ноября 2019.
  22. ^ а б "RISC-V Foundation". Фонд RISC-V. Получено 15 марта 2019.
  23. ^ "U.S.-based chip-tech group moving to Switzerland over trade curb fears". Рейтер. 26 ноября 2019 г.. Получено 26 ноября 2019.
  24. ^ "RISC-V History - RISC-V International". RISC-V International. Получено 14 мая 2020.
  25. ^ "The Linley Group Announces Winners of Annual Analysts' Choice Awards" (Пресс-релиз). The Linley Group. 12 января 2017 г.. Получено 21 января 2018.
  26. ^ а б c d е ж грамм час я Waterman, Andrew (13 May 2011). Improving Energy Efficiency and Reducing Code Size with RISC-V Compressed. U.C. Berkeley: Regents of the University of California. п. 32. Получено 25 августа 2014.
  27. ^ а б Waterman, Andrew; и другие. "The RISC-V Compressed Instruction Set Manual Version 1.9 (draft)" (PDF). RISC-V. Получено 18 июля 2016.
  28. ^ а б Brussee, Rogier. "A Complete 16-bit RVC". Группы Google. Фонд RISC-V. Получено 18 июля 2019.
  29. ^ а б Brussee, Rogier. "Proposal: Xcondensed, [a] ... Compact ... 16 bit standalone G-ISA". RISC-V ISA Mail Server. Группы Google. Получено 10 ноября 2016.
  30. ^ Phung, Xan. "Improved Xcondensed". Группы Google. Фонд RISC-V. Получено 18 июля 2019.
  31. ^ Ionescu, Liviu. "The RISC-V Microcontroller Profile". Github. Получено 5 апреля 2018.
  32. ^ Barros, Cesar. "Proposal: RV16E". RISC-V ISA Developers (Список рассылки). Получено 2 апреля 2018.
  33. ^ Bonzini, Paolo; Waterman, Andrew. "Proposal for Virtualization without H mode". RISC-V ISA Developers (Список рассылки). Получено 24 февраля 2017.
  34. ^ Wolf, Clifford. "riscv-bitmanip" (PDF). GitHub. Фонд RISC-V. Получено 13 января 2020.
  35. ^ а б "Instruction Summary for a "P" ISA Proposal". Группы Google. ANDES Technologies. Получено 13 января 2020.
  36. ^ Andes Technology. "Comprehensive RISC-V Solutions" (PDF). RISC-V Content. Фонд RISC-V. Получено 13 января 2020.
  37. ^ Lee, Ruby; Huck, Jerry (25 February 1996). "64-bit and Multimedia Extensions in the PA-RISC 2.0 Architecture". Proceedings of Compcon 96: 152–160. Дои:10.1109/CMPCON.1996.501762. ISBN  0-8186-7414-8.
  38. ^ Lee, Ruby B. (Апрель 1995 г.). "Accelerating Multimedia with Enhanced Microprocessors" (PDF). IEEE Micro. 15 (2): 22–32. CiteSeerX  10.1.1.74.1688. Дои:10.1109/40.372347. Получено 21 сентября 2014.
  39. ^ а б c d е ж грамм час Schmidt, Colin; Ou, Albert; Lee, Yunsup; Asanović, Krste. "RISC-V Vector Extension Proposal" (PDF). RISC-V. Регенты Калифорнийского университета. Получено 14 марта 2016.
  40. ^ Ou, Albert; Нгуен, Куан; Lee, Yunsup; Asanović, Krste. "A Case for MVPs: Mixed-Precision Vector Processors" (PDF). UC Berkeley EECS. Регенты Калифорнийского университета. Получено 14 марта 2016.
  41. ^ Lee, Yunsup; Grover, Vinod; Krashinsky, Ronny; Stephenson, Mark; Keckler, Stephen W.; Asanović, Krste. "Exploring the Design Space of SPMD Divergence Management on Data-Parallel Architectures" (PDF). Berkeley's EECS Site. Регенты Калифорнийского университета. Получено 14 марта 2016.
  42. ^ а б c d е Bradbury, Alex; Wallentowitz, Stefan. "RISC-V Run Control Debug". Гугл документы. Фонд RISC-V. Получено 20 января 2017.
  43. ^ Newsome, Tim. "RISC-V Debug Group > poll results". Google Groups, RISC-V Debug Group. Фонд RISC-V. Получено 20 января 2017.
  44. ^ McGooganus. "riscv-trace-spec". GitHub. Получено 13 января 2020.
  45. ^ Dahad, Nitin. "UltraSoC Tackles RISC-V Support Challenge by Donating Trace Encoder". EE Times. Aspencore. Получено 13 января 2020.
  46. ^ «Обзор ядер RISC-V и SoC». RISC-V. 25 сентября 2019 г.. Получено 5 октября 2019.
  47. ^ "China's Alibaba is making a 16-core, 2.5 GHz RISC-V processor". www.techspot.com. Получено 30 июля 2019.
  48. ^ "Andes Technology". RISC-V International. Получено 10 июля 2018.
  49. ^ "CloudBEAR". Получено 16 октября 2018.
  50. ^ Manners, David (23 November 2016). "Codasip and UltraSoC Combine on RISC-V". Еженедельник электроники. Metropolis International Group, Ltd. Получено 23 ноября 2016.
  51. ^ "GigaDevice Unveils The GD32V Series With RISC-V Core in a Brand New 32-bit General Purpose Microcontroller". www.gigadevice.com. Получено 29 августа 2019.
  52. ^ "Sipeed Longan Nano - RISC-V GD32VF103CBT6 Development Board". www.seeedstudio.com. Получено 29 августа 2019.
  53. ^ "GreenWaves GAP8 is a Low Power RISC-V IoT Processor Optimized for Artificial Intelligence Applications". CNXSoft: Embedded Systems News. 27 февраля 2018 г.. Получено 4 марта 2018.
  54. ^ Yoshida, Junko (26 February 2018). "AI Comes to Sensing Devices". EE Times. Получено 10 июля 2018.
  55. ^ "GreenWaves Technologies Announces Availability of GAP8 Software Development Kit and GAPuino Development Board" (Пресс-релиз). 22 мая 2018.
  56. ^ "SEGGER Adds Support for SiFive's Coreplex IP to Its Industry Leading J-Link Debug Probe". Получено 19 сентября 2017.
  57. ^ "PR: SEGGER Embedded Studio supports RISC-V architecture". Получено 23 ноября 2017.
  58. ^ "PR: SEGGER presents RTOS, stacks, middleware for RISC-V". Получено 8 декабря 2017.
  59. ^ "HiFive1". SiFive. Получено 10 июля 2018.
  60. ^ SiFive. "Hi-Five1: Open-source Arduino-Compatible Development Kit". Предложение толпы. Получено 2 декабря 2016.
  61. ^ "FU540 SoC CPU". SiFive. Получено 24 октября 2018.
  62. ^ "Syntacore". Получено 11 декабря 2018.
  63. ^ "SCR1, open-source RISC-V core". Получено 11 декабря 2018.
  64. ^ "RISC-V workshop proceedings". 11 декабря 2016 г.. Получено 11 декабря 2018.
  65. ^ Шилов, Антон. "Western Digital Reveals SweRV RISC-V Core, Cache Coherency over Ethernet Initiative". www.anandtech.com. Получено 23 мая 2019.
  66. ^ "Western Digital Releases SweRV RISC-V Core Source Code". AB Open. 28 января 2019. В архиве from the original on 21 May 2019.
  67. ^ Cores-SweRV на GitHub
  68. ^ "Espressif". Получено 9 июн 2020.
  69. ^ "ESP32-S2" (PDF). Получено 9 июн 2020.
  70. ^ Desikan, Shubashree (6 August 2018). "IIT-Madras powers up a desi chip". Индуистский. ISSN  0971-751X. Получено 25 сентября 2020.
  71. ^ а б "Meet India's Atmanirbhar Microprocessor chip 'Moushik', meant for IoT devices". WION. Получено 25 сентября 2020.
  72. ^ Ashenden, Peter (9 November 2016). "Re: [isa-dev] RISC V ISA for embedded systems". Разработчики RISC-V ISA (Список рассылки). Получено 10 ноября 2016. В ASTC (www.astc-design.com) у нас есть реализация RV32EC в качестве синтезируемого IP-ядра, предназначенного для небольших встроенных приложений, таких как интеллектуальные датчики и IoT.
  73. ^ «C-DAC объявляет о выпуске Tech Conclave 2019». Таймс оф Индия. Получено 12 апреля 2019.
  74. ^ «Процессор НОЭЛ-В». Кобэм Гайслер. Получено 14 января 2020.
  75. ^ а б «FreeBSD Foundation: первоначальный перенос архитектуры FreeBSD RISC-V». 4 февраля 2016 г.
  76. ^ «Эсперанто выходит из скрытого режима, нацелен на ИИ с 4096 ядерным 7-нм монстром RISC-V». wikichip.org. Январь 2018. Получено 2 января 2018.
  77. ^ "Проект PULPino GitHub". GitHub. Получено 2 февраля 2018.
  78. ^ «ПУЛП Платформа». Платформа PULP. Получено 2 февраля 2018.
  79. ^ «Ускоренный поток». Европейская инициатива переработчиков (EPI). Получено 22 февраля 2020.
  80. ^ Редмонд, Калиста (20 августа 2019 г.). «Как European Processor Initiative использует RISC-V для будущего суперкомпьютеров». Международные новости RISC-V. RISC-V International.
  81. ^ «Проект процессора с открытым исходным кодом IIT Madras». Быстрый ввод-вывод. ИИТ Мадрас. Получено 13 сентября 2014.
  82. ^ "сайт lowRISC". Получено 10 мая 2015.
  83. ^ Се, Джо (июль 2016 г.). История оценки NVIDIA RISC V. 4-й семинар RISC-V. YouTube.
  84. ^ Андрей Фрумусану (30 октября 2019). «SiFive анонсирует первое ядро ​​процессора RISC-V OoO: процессор IP серии U8». Анандтех.
  85. ^ Асанович, Крсте; и другие. "ракета-чип". GitHub. RISC-V International. Получено 11 ноября 2016.
  86. ^ Селио, Кристофер. "Рискв-бум". GitHub. Регенты Калифорнийского университета. Получено 29 марта 2020.
  87. ^ Селио, Кристофер. "Рискв-содор". GitHub. Регенты Калифорнийского университета. Получено 11 ноября 2016.
  88. ^ Селио, Крис. "ucb-bar / riscv-sodor". github. Регенты Калифорнийского университета. Получено 25 октября 2019.
  89. ^ Волк, Клэр. "picorv32". GitHub. Получено 27 февраля 2020.
  90. ^ "scr1". GitHub. Syntacore. Получено 13 января 2020.
  91. ^ Трабер, Андреас; и другие. «PULP: параллельное сверхнизкое энергопотребление». ETH Zurich, Болонский университет. Получено 5 августа 2016.
  92. ^ "Chisel: создание оборудования на встроенном языке Scala". Калифорнийский университет в Беркли. Регенты Калифорнийского университета. Получено 12 февраля 2015.
  93. ^ "riscv - FreeBSD Wiki". wiki.freebsd.org.
  94. ^ Монтезело, Мануэль. "Порт Debian GNU / Linux для RISC-V 64". Группы Google. Получено 19 июля 2018.
  95. ^ «Архитектура / РИНЦ-В». Fedora вики. Красная шляпа. Получено 26 сентября 2016.
  96. ^ Бегари, Падмарао. «Доступен порт U-Boot на 32-битной RISC-V». Группы Google. Microsemi. Получено 15 февраля 2017.
  97. ^ RiscVEdk2 на GitHub
  98. ^ Алматарий, Хешам. «РИСК-В, сел4». seL4 Документация. Организация Содружества научных и промышленных исследований (CSIRO). Получено 13 июля 2018.
  99. ^ Алматарий, Хешам. "хешамельматары". GitHub. Получено 13 июля 2018.
  100. ^ «MultiZone Secure IoT Stack, первый защищенный IoT-стек для RISC-V». Hex Five Безопасность. Hex Five Security, Inc. 22 февраля 2019 г.. Получено 3 марта 2019.
  101. ^ "Фарос". SourceForge. Получено 1 апреля 2020.
  102. ^ «ANGEL - это симулятор Javascript RISC-V ISA (RV64), который запускает riscv-linux с BusyBox». RISCV.org. Архивировано из оригинал 11 ноября 2018 г.. Получено 17 января 2019.
  103. ^ Ли, Юнсуп (5 марта 2014 г.). "Загрузите RISC-V Linux в свой веб-браузер!". RISC-V International. Получено 4 сентября 2020.
  104. ^ "АНГЕЛ - РИСК-В". riscv.org.s3-website-us-west-1.amazonaws.com. Получено 4 сентября 2020.
  105. ^ WepSIM с примером RISC-V_im: https://acaldero.github.io/wepsim/ws_dist/wepsim-classic.html?mode=ep&example=36&simulator=assembly:registers¬ify=false
  106. ^ Исходный код WepSIM в GitHub: https://github.com/wepsim/wepsim
  107. ^ «Документация / Платформы / RISCV - QEMU». wiki.qemu.org. Получено 7 мая 2020.

дальнейшее чтение

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