Оказывается, Гугл уже несколько лет развивает собственную процессорную архитектуру, которая называется Lanai. Про неё стало известно пять лет назад, когда Гугл добавил её реализацию в компилятор Clang:
"LLVM Patches Confirm Google Has Its Own In-House Processor"
Подробности архитектуры Гугл не раскрывает, и доступный хардвер не обещает. Чуть больше подробностей можно найти в статье:
"Google crafts custom networking CPU with parallel computing links"
Вроде как 32-битный процессор с 32 регистрами общего назначения. Утверждается, что идея процессора навеяна книгой:
"Parallel Computer Architecture. A Hardware / Software Approach"
В компиляторе Clang имеется поддержка этой архитектуры, если задать флажок --target=lanai. Вот как выглядит язык ассемблера:
"LLVM Patches Confirm Google Has Its Own In-House Processor"
Подробности архитектуры Гугл не раскрывает, и доступный хардвер не обещает. Чуть больше подробностей можно найти в статье:
"Google crafts custom networking CPU with parallel computing links"
Вроде как 32-битный процессор с 32 регистрами общего назначения. Утверждается, что идея процессора навеяна книгой:
"Parallel Computer Architecture. A Hardware / Software Approach"
В компиляторе Clang имеется поддержка этой архитектуры, если задать флажок --target=lanai. Вот как выглядит язык ассемблера:
Но не всё так безнадёжно. На гитхабе я обнаружил исходники симулятора архитектуры Lanai: https://github.com/TrueBitProject/lanai$ cat hello.c
int main()
{
return 0;
}
$ clang --target=lanai -S -O hello.c
$ cat hello.s
.text
.file "hello.c"
.globl main ! -- Begin function main
.p2align 2
.type main,@function
main: ! @main
! %bb.0:
st %fp, [--%sp]
add %sp, 0x8, %fp
sub %sp, 0x8, %sp
or %r0, 0x0, %rv
ld -4[%fp], %pc ! return
add %fp, 0x0, %sp
ld -8[%fp], %fp
.Lfunc_end0:
.size main, .Lfunc_end0-main
! -- End function
.ident "clang version 10.0.0-4ubuntu1 "
.section ".note.GNU-stack","",@progbits
.addrsig
