Битовые маски #1. Разработка компиляторов / LLVM backend для RISC-V / Kotlin компилятор

  Рет қаралды 7,285

Истовый Инженер

Истовый Инженер

Күн бұрын

Пікірлер
@IshuckShow
@IshuckShow Жыл бұрын
Еее, респект за контент, бэкенд в массы!
@ultimate_engineer
@ultimate_engineer Жыл бұрын
Спасибо! Скоро будет второй выпуск ;)
@Max__O_o
@Max__O_o Жыл бұрын
Спасибо! Было было интересно.
@ultimate_engineer
@ultimate_engineer Жыл бұрын
Спасибо, нам очень приятно!
@ГеннадийФомин-л3й
@ГеннадийФомин-л3й Жыл бұрын
Тоже занимаюсь компиляторами, только не для LLVM, а для виртуальной машины (исполнитель запросов колоночной базы, что-то отдаленно напоминающее интерпретатор SQLite). В свое время случайно узнал про SSA из какой-то статьи - для меня это было настолько неожиданное открытие, что я две недели переписывал генерацию кода в эту форму. Оказалось - мега удобная штука. Я бы послушал про оптимизации, основанные на IR. С dead code и удалением дубликатов - понятно, какие еще оптимизации применяются и как они работают, как определяется момент завершения цикла оптимизации?
@ultimate_engineer
@ultimate_engineer Жыл бұрын
Спасибо за вопрос! SSA - широко известная форма, хотя и не все компиляторы её используют, но она действительно упрощает часть оптимизаций. Про оптимизации, выполняющиеся в middle-end компиляторов можно почитать в классических книгах, помимо широко известного Dragon book, можно еще посоветовать Engineering: A Compiler www.amazon.com/Engineering-Compiler-Keith-Cooper/dp/012088478X (Modern Compiler Design link.springer.com/book/10.1007/978-1-4614-4699-6 еще например). Также можно посмотреть на документацию LLVM с описанием базовых оптимизирующих проходов, которые в нем есть llvm.org/docs/Passes.html#transform-passes. Завершение каждой оптимизации - очень индивидуальный вопрос, построенный часто на различных эвристиках, поверенных на определенном наборе бенчмарков. Это может быть завершение поиска всех подходящих для данной оптимизации случаев, использование различных thresholdов, анализ того насколько разрослось CFG и т.д. Тема оптимизаций очень обширная, и хотя мы ещё, конечно, будем разговаривать про компиляторы, но покрыть всё детально невозможно в таком формате, поэтому если есть заинтересованность, рекомендуем почитать литературу и посмотреть на код LLVM/GCC и других компиляторов (большинство open-source).
@vladimiro3059
@vladimiro3059 Жыл бұрын
Том Круз в с++😂😂😂
@skobkinru
@skobkinru Жыл бұрын
Подкаст не нашёлся через AntennaPod. Его нет на подкаст-платформах?
@ultimate_engineer
@ultimate_engineer Жыл бұрын
Наш подкаст Битовые маски уже доступен на большинстве площадок: bitmask.mave.digital/
@skobkinru
@skobkinru Жыл бұрын
@@ultimate_engineer Благодарю. Вот теперь он нашёлся через AntennaPod. Подписался, послушаем. Спасибо!
@DGT67
@DGT67 Жыл бұрын
в каком месте на данный момент находится передовая мысль разработчиков архитектуры? кто займет вершину надолго в ближайшем будущем ? ренессанс cisc возможен?)
@DmitryPetrov
@DmitryPetrov Жыл бұрын
Кто займёт вершину - это вопрос не технический, а скорее экономический и политический. RISC-V может сильно потеснить тот же ARM, но если это случится, то, скорее всего, не потому, что он такой замечательный с архитектурной точки зрения. Сейчас грань между RISC и CISC довольно сильно размыта. CISC-процессоры внутри имеют RISC-подобные конвейеры, исполняющие микрооперации. RISC-процессоры получают "сложные" инструкции (пример: векторые инструкции в RISC-V), переменную длину команд с особенностями кодирования (примеры из RISC-V: RVC, крипто-расширения) и прочие фичи, которые скорее похожи на CISC. Когда-то память микрокода была важна, и это деление было важным. Сейчас скорее важны кеши, параллелизм уровня инструкций и предсказание переходов.
@z140140
@z140140 Жыл бұрын
пока похоже что apple, amd и intel будут делать перескакивать друг через друга снова как в 90-х. и ещё в этот клуб пытается попасть arm, а может будут и другие претенденты
@IshuckShow
@IshuckShow Жыл бұрын
Правда для бэкендеров они слишком много улыбаются, как-то не натурально получается
@ultimate_engineer
@ultimate_engineer Жыл бұрын
Дмитрий просто только что после отпуска - зарядил коллег своим отдохнувшим видом :)
Tuna 🍣 ​⁠@patrickzeinali ​⁠@ChefRush
00:48
albert_cancook
Рет қаралды 148 МЛН
Sigma Kid Mistake #funny #sigma
00:17
CRAZY GREAPA
Рет қаралды 30 МЛН
UFC 310 : Рахмонов VS Мачадо Гэрри
05:00
Setanta Sports UFC
Рет қаралды 1,2 МЛН
LLVM и GCC / Register allocation / IT-образование в вузах (часть 1)
57:44
Многослойные печатные платы
1:20:47
Истовый Инженер
Рет қаралды 4,3 М.
Tuna 🍣 ​⁠@patrickzeinali ​⁠@ChefRush
00:48
albert_cancook
Рет қаралды 148 МЛН