V8이 JIT 컴파일러에서 Sea of Nodes를 버리고 CFG로 돌아가는 이유
V8 팀이 JavaScript와 WebAssembly 최적화 컴파일러 Turbofan에서 Sea of Nodes 기반 중간 표현을 줄이고, CFG 기반 Turboshaft와 Maglev로 이동 중이라고 설명했다. 이론적으로는 자유로운 스케줄링이 장점이지만, 실제 JavaScript에서는 효과·제어 체인 관리가 너무 복잡하고 컴파일 시간이 느려져 실용성이 떨어졌다는 결론이다.
- 1
V8의 JavaScript 백엔드는 이미 Turboshaft로 대체됐고 WebAssembly도 전체 파이프라인에서 Turboshaft를 사용함
- 2
Sea of Nodes는 값 의존성만 남겨 연산을 자유롭게 배치할 수 있지만, JavaScript에서는 부작용과 타입 체크 때문에 대부분 노드가 다시 제약을 받음
- 3
V8 팀은 새 CFG 기반 Load Elimination이 기존 방식보다 최대 190배 빠른 벤치마크를 확인함
- 4
Sea of Nodes는 L1 데이터 캐시 미스가 평균 3배, 일부 단계에서는 최대 7배 많았고 컴파일 시간도 손해를 봄
이 글은 ‘멋진 컴파일러 이론’이 대형 프로덕션 런타임에서 항상 이기는 건 아니라는 사례다. 특히 JIT에서는 최종 실행 속도만큼 컴파일 속도, 디버깅 난이도, 최적화 구현 비용이 다 같이 제품 품질이 된다.
관련 기사
Go에서 Rust로 옮길 때 진짜로 바뀌는 것들
이 글은 Go 백엔드 서비스를 Rust로 옮길 때 속도보다 컴파일 타임 보장, 런타임 트레이드오프, 개발자 경험이 더 중요하다고 설명한다. nil 패닉, 데이터 레이스, 에러 처리, 제네릭, 비동기 모델, 마이그레이션 전략까지 실무 관점에서 Go와 Rust를 길게 비교한다.
Python 3.15에서 헤드라인은 못 탔지만 꽤 쓸만한 기능들
Python 3.15에는 lazy imports나 Tachyon profiler 같은 큰 기능 말고도 실무에서 바로 체감될 만한 작은 개선들이 들어가. TaskGroup 취소, 컨텍스트 매니저 데코레이터 개선, 스레드 안전 이터레이터처럼 평소 애매하게 불편했던 지점들이 꽤 깔끔해졌어.
심평원, DUR부터 의료영상 심사까지 클라우드로 갈아엎는다
심평원이 정보시스템 클라우드 전환과 함께 병·의원 업무에 직접 닿는 DUR, 의료영상 AI 심사, 요양급여내역 조회 시스템을 고도화한다. 핵심은 설치형 프로그램 중심이던 연계를 웹과 API 기반으로 넓히고, 진료·청구 과정에서 실시간 확인과 자동 판독을 강화하는 쪽이다.
윈도우 에러 코드 7번 ‘ERROR_ARENA_TRASHED’는 어디서 왔을까
ERROR_ARENA_TRASHED는 Win32에서 실제로 쓰이는 현대적 에러라기보다 MS-DOS 시절 메모리 관리 구조에서 넘어온 잔재야. MS-DOS가 메모리 블록 앞의 arena 시그니처를 훑다가 예상한 값이 아니면 ‘arena가 망가졌다’고 보고 이 에러를 냈다는 이야기야.
C/C++ 컴파일러의 느슨한 메모리 동시성 버그를 자동으로 잡는 박사논문
C와 C++ 컴파일러에서 relaxed memory 동시성 버그를 찾는 자동 테스트 프레임워크를 다룬 박사논문이 공개됐어. Téléchat, Atomic-mixer 같은 도구로 소스 수준 동작과 컴파일된 프로그램 동작을 비교하고, LLVM과 GCC 툴체인에서 실제 버그를 찾아낸 내용이 핵심이야.
댓글
댓글
댓글을 불러오는 중...