vak: (Default)
[personal profile] vak
Оказывается, Гугл уже несколько лет развивает собственную процессорную архитектуру, которая называется 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. Вот как выглядит язык ассемблера:
$ 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
Но не всё так безнадёжно. На гитхабе я обнаружил исходники симулятора архитектуры Lanai: https://github.com/TrueBitProject/lanai
This account has disabled anonymous posting.
If you don't have an account you can create one now.
HTML doesn't work in the subject.
More info about formatting

If you are unable to use this captcha for any reason, please contact us by email at support@dreamwidth.org