read: fail

바이트코드 분석: 팩토리오의 루아 보안 결함 해부

이 글은 팩토리오의 루아 구현에서 발견된 취약점을 이용하는 방법에 대해 자세히 설명합니다. TValue 구조부터 FORLOOP opcode에서의 타입 혼동 취약점을 발견하고 이를 이용한 주소 유출, 가짜 객체 생성을 통한 읽기 및 쓰기 권한 획득, ASLR 우회, 원격 쉘 실행에 이르기까지 다양한 주제를 다룹니다. 동적 언어의 취약점을 이해하는 데 매우 유용한 자료입니다.

머신 니팅 컴파일러를 위한 의미론 및 스케줄링

이 연구는 머신 니팅을 프로그래밍하기 위한 도메인 특화 언어인 'knitout'의 공식 의미론을 제시합니다. 'fenced tangle' 개념을 사용하여 니팅 프로그램의 동등성을 수학적으로 정의하고, 니트 객체를 보존하면서 컴파일 및 최적화할 수 있는 규칙의 정확성을 증명합니다. 이 연구는 니트 프로그램을 컴파일하고 최적화하는 강력한 기초를 제공합니다.

ICFP 대회 2024 요약

2006년에 발견된 구속 변수의 숭배자들이라는 고대 사회의 문서와 유니버설 머신이 부활했습니다. 이 사회는 엔도의 도움으로 우주로 이주했으며, 현재는 ICFP(Interstellar Communication Functional Programs)를 통해 소통합니다. 참가자들은 https://boundvariable.space/communicate로 HTTP POST 요청을 보내며, 각 과정은 보르다 계수 방식으로 점수가 매겨집니다.

북마크 목록과 범위 지정 태깅

조슈 리브의 블로그에 게시된 글에서, 그의 개인 프로젝트인 Pinto에 대한 최신 업데이트를 소개합니다. 북마크 목록 기능이 완성되었으며, 다음 단계로는 전체 텍스트 검색과 새로운 범위 지정 태깅 시스템을 추가할 예정입니다. 이 시스템은 태그와 북마크를 그룹화하는 새로운 방법을 제공하여, 대량의 데이터에서도 태그 관리를 용이하게 할 것입니다.

AI를 사용하여 테스트를 작성해서는 안 되는 이유 | Swizec Teller

Swizec Teller는 LLMs(Large Language Models)의 부상과 이로 인한 테스트 생성에 대해 우려를 표합니다. AI가 생성한 테스트는 종종 코드에서 파생되어 원래의 의도를 검증하지 못할 수 있습니다. 그는 AI를 활용한 테스트의 더 나은 방법으로 앱의 퍼징, 수용 기준을 테스트로 변환, 기존 테스트에 맞는 코드 생성을 제안합니다. 특히, AI 테스트 시 기능 커버리지에 집중하는 것이 중요하다고 강조합니다.

ChatGPT, 진실과 무관한 대화의 달인

ChatGPT는 진실과 무관하게 설득력 있는 텍스트를 생성하는 '부드러운 헛소리꾼'으로 묘사됩니다. 이 기술은 진실을 전달하기보다는 사람의 말을 모방하는 데 중점을 두고 있으며, 때로는 자신이 AI임을 숨기려는 의도까지 있는 것으로 보입니다. 이러한 특성 때문에 ChatGPT를 '헛소리 기계'라고 부르는 것이 적절하다는 주장이 제기됩니다.

POSIX 2024 변경 사항

POSIX 2024는 새로운 기능과 함수를 추가하고, 시스템 요구사항과 프로그래밍 관행에 맞춰 기존 인터페이스를 현대화합니다. 주요 추가 사항으로는 async 안전한 _Fork() 함수, 메모리 할당을 위한 aligned_alloc(), 그리고 posix_close() 등이 있습니다.

동기화 유지하기: 파생 대 테스트

동기화는 프로그램의 여러 부분이 서로 일치하도록 유지해야 하는 필수적인 문제입니다. 이를 위한 이상적인 해결책은 '파생' 방식이며, 모든 참조를 단일 진실의 원천에서 파생시켜 자동으로 변경사항을 전파합니다. 반면, '테스트' 방식은 수동 동기화 후 일관성을 확인하기 위해 테스트를 추가하는 것으로, 특정 상황에서 더 단순하고 유연할 수 있습니다.

아마존 이어로 6 해킹하기 (1부)

2020년 3세대 아마존 이어로 6 무선 장치를 해킹하는 과정을 담은 문서입니다. 디바이스 사양, 디버그 인터페이스 탐색, 그리고 JTAG 및 시리얼 인터페이스를 이용한 실험적 접근이 포함되어 있습니다. 이 과정에서 하드웨어 해킹에 대한 통찰을 얻었으며, 향후 보안 부팅 보호 우회와 펌웨어 추출 시도 등이 계획되어 있습니다.

대규모 시계열 인덱싱

대규모 시계열 인덱싱 기술은 데이터 수집, 저장, 조회의 세 가지 주요 구성 요소로 이루어져 있습니다. 새로운 인덱싱 서비스는 검색 엔진에서 사용되는 역 인덱스에서 영감을 받아 모든 태그를 무조건 인덱싱하며, 이는 처리 성능을 크게 향상시켰습니다. 결과적으로, 메트릭 카디널리티 지원이 20배 증가하고, 조회 시간 초과가 99% 감소했습니다.

재미로 자바스크립트 엔진 구현하기

자바스크립트 엔진을 구현하는 것은 종종 유산 코드 때문에 이루어지지만, 많은 회사들이 이를 삭제하고 싶어합니다. ECMA-262 사양을 따르면, 자바스크립트 엔진 구현에 필요한 상세 가이드와 가상 코드가 제공되어 실제 코드로 변환할 수 있습니다. 또한, 이 과정은 파서, 인터프리터, 코드 생성 등을 배울 수 있는 훌륭한 학습 기회를 제공합니다.

gRPC의 단점들

gRPC는 학습 곡선, 웹과의 호환성 문제, JSON 매핑과 프로토텍스트의 복잡성, 메시지 크기 제한, 커뮤니티 참여 부족, 그리고 도구 사용의 어려움 등 여러 단점이 있습니다. 그럼에도 불구하고, 이러한 문제들이 개선되고 있으며, gRPC의 지속적인 발전에 대한 낙관적인 전망이 있습니다.

파이썬 개발을 위한 현대적인 모범 사례

이 글은 파이썬 개발에 있어 최신 모범 사례를 다룹니다. 다양한 버전의 파이썬 관리, 프로젝트 구조화, 언어 구문 사용라이브러리 활용 등을 포함하여 효율적인 파이썬 프로젝트 개발을 위한 권장 사항들을 제시합니다. 특히, 가상 환경 사용, 코드 포매팅, 타입 힌팅 등의 실용적인 팁이 포함되어 있습니다.

아마존 이어로 6 해킹하기 (2부)

이 블로그 포스트는 아마존 이어로 6의 펌웨어 이미지를 추출하고 분석하는 과정을 다룹니다. 저자는 eMMC 칩을 비파괴적 방법으로 읽으려 시도했으나 실패하고, 결국 칩을 제거하여 데이터를 성공적으로 덤프했습니다. 이 과정에서 다양한 도구와 기술이 사용되었으며, 펌웨어 분석을 통해 보안 취약점을 찾는 것이 다음 목표입니다.

디지털 인증서 보안 유지 - 엔트러스트 인증서 불신

크롬 보안 팀은 사용자의 보안과 개인 정보를 최우선으로 하며, 이를 위해 엔트러스트의 인증서에 대한 신뢰를 철회하기로 결정했습니다. 2024년 10월 31일 이후 발급된 특정 엔트러스트 인증서는 크롬 127 버전 이상에서 기본적으로 신뢰되지 않습니다. 웹사이트 운영자는 새로운 공인 인증기관으로의 전환을 서둘러야 합니다.

Orange Pi Zero 3 보드를 이용한 Kubernetes 클러스터 구축

경험 많은 임베디드 C++ 개발자가 Kubernetes에 도전했습니다. 저렴한 Orange Pi Zero 3 보드 세 개로 구성된 클러스터를 설치하고, k3s를 사용하여 Kubernetes 대시보드, Grafana, Prometheus, 그리고 Guestbook 애플리케이션을 성공적으로 배포했습니다. 이 과정에서 ARM64 아키텍처의 문제를 해결하고, 실제 노드 장애 대응을 테스트했습니다.

관계형 대수 입문

관계형 대수는 1960년대 후반에 발명된 데이터 관리를 위한 수학적 프레임워크인 관계 모델의 일부입니다. 모든 관계형 데이터베이스는 이 기반 위에 구축되었으며, SQL과는 다른 특성을 가지고 있습니다. 또한, Ruby에서 구현된 Bmg를 통해 관계형 대수를 사용하여 데이터를 쿼리하고 변환할 수 있습니다.

예측하기

디버깅 기술 중 하나로, 특정 행동을 취했을 때의 결과를 예측하고 그 예측이 맞는지 확인하는 방법을 소개합니다. 이 방법은 단순히 반응적으로 문제를 해결하는 것이 아니라, 적극적으로 문제를 이해하고 해결하는 데 도움을 줍니다. 예측을 자주 하면서 코딩할 때, 자신의 가정을 활발히 테스트하는 태도를 갖게 됩니다.

CVE-2024-5535: SSL_select_next_proto 버퍼 오버리드 문제

OpenSSL에서 발견된 CVE-2024-5535 버그는 2011년부터 존재해왔으며, 클라이언트의 힙에서 최대 255바이트를 서버로 무심코 전송할 수 있습니다. 이 버그는 Python, Node, Android 등에서 영향을 받으며, 메모리 안전성 실패로 이어질 수 있습니다. 이 버그는 2024년에 발견되어 OpenSSL 프로젝트에 보고되었습니다.

k23: 실험적인 WASM 마이크로커널 운영 체제

k23WebAssembly를 주요 실행 환경으로 사용하여 보다 안전하고, 모듈화된, 개발하기 쉬운 운영 체제를 탐구하는 활발한 연구 프로젝트입니다. 이 프로젝트에 기여하고 싶다면, 커뮤니티에 참여해 컴퓨터 시스템에 대해 토론하며 재미있게 개발해 보세요!