디시인사이드 갤러리

갤러리 이슈박스, 최근방문 갤러리

갤러리 본문 영역

Ada, Rust의 0 오버헤드 C 바인딩

나르시갤로그로 이동합니다. 2025.11.24 15:30:26
조회 101 추천 0 댓글 2

주의:

LLM으로 작성한 글입니다. 글에 틀린 내용이 있을 수 있습니다.

제가 아직 Ada, Rust 관련 글의 내용을 검증할 수준이 못됩니다.


개요

이 문서는 Ada와 Rust에서 C 바인딩을 오버헤드 없이(Zero-Overhead) 구현하는 방법을 기술적으로 설명합니다. 여기서 “오버헤드 없음”이란 C 함수 호출과 동일한 수준에서 추가적인 런타임 변환, 복사, 마샬링이 발생하지 않고, 호출 규약과 데이터 레이아웃이 완전히 일치하는 상태를 의미합니다.


C ABI 기본 조건

  • 호출 규약(Call Convention): 함수는 C 호출 규약을 따라야 합니다.
  • 데이터 표현(Representation): 전달되는 타입은 크기, 정렬, 필드 순서, 패딩이 C와 동일해야 합니다.
  • 심볼 이름(Name Mangling): 내보내는 심볼은 C와 동일한 이름으로 유지해야 합니다.
  • 스택 언와인딩(Unwinding): 예외나 패닉은 언어 경계를 넘어가면 안 됩니다.
  • 정수/포인터 폭: 플랫폼 ABI(LP64, ILP32 등)에 맞춰야 합니다.

Ada: Zero-Overhead C 바인딩

함수 Import/Export

with Interfaces.C;

procedure Foo (X : Interfaces.C.int);
pragma Import (C, Foo, "foo");

function Bar (A, B : Interfaces.C.int) return Interfaces.C.int;
pragma Export (C, Bar, "bar");
  • pragma Import/Export (C, ...)를 사용하면 Ada 함수가 C ABI와 동일하게 호출됩니다.

구조체 레이아웃

type C_Context is record
   Dummy : Interfaces.C.int;
end record;
pragma Convention (C, C_Context);
  • pragma Convention (C, ...)로 구조체 레이아웃을 C와 동일하게 강제합니다.
  • 필요 시 for ... use record 표현절로 필드 오프셋을 명시할 수 있습니다.

비트마스크/집합 타입

type Event_Condition is (Input, Output, Hang_Up, Error);
for Event_Condition'Size use 8;

type Event_Conditions is set of Event_Condition;
for Event_Conditions'Size use 32;
pragma Convention (C, Event_Conditions);
  • Event_Conditions는 32비트로 강제되며, C의 uint32_t와 동일한 ABI를 가집니다.

콜백 (함수 포인터)

type Event_Callback is access procedure
  (FD        : Interfaces.C.int;
   Events    : Event_Conditions;
   User_Data : System.Address)
with Convention => C;
  • Convention => C를 붙이면 Ada의 access procedure가 C 함수 포인터와 ABI 일치합니다.

Rust: Zero-Overhead C 바인딩

함수 Import/Export

extern "C" {
    fn foo(x: i32);
}

#[no_mangle]
pub extern "C" fn bar(a: i32, b: i32) -> i32 {
    a + b
}
  • extern "C"로 호출 규약을 C와 동일하게 설정합니다.
  • #[no_mangle]로 심볼 이름을 그대로 유지합니다.

구조체 레이아웃

#[repr(C)]
pub struct CContext {
    pub dummy: i32,
}
  • #[repr(C)]로 구조체 레이아웃을 C와 동일하게 강제합니다.

비트마스크

bitflags::bitflags! {
    #[repr(C)]
    pub struct EventMask: u32 {
        const INPUT   = 0x01;
        const OUTPUT  = 0x02;
        const HANG_UP = 0x04;
        const ERROR   = 0x08;
    }
}
  • 내부적으로 u32이므로 C의 uint32_t와 동일합니다.

콜백 (함수 포인터)

pub type EventCallback =
    extern "C" fn(fd: i32, events: u32, user_data: *mut core::ffi::c_void);

extern "C" {
    fn 레지스터_cb(cb: EventCallback);
}
  • extern "C" fn은 C 함수 포인터와 ABI가 동일합니다.

데이터 타입 일치 조건

  • 정수: Ada는 Interfaces.C.*, Rust는 i32, u32 등 고정 폭 타입 사용.
  • 포인터: Ada는 System.Address, Rust는 *mut T / *const T.
  • 구조체: Ada pragma Convention (C), Rust #[repr(C)].
  • 열거형: Ada는 for Enum'Size use ..., Rust는 #[repr(u32)].
  • 집합/비트마스크: Ada는 for Set'Size use 32, Rust는 u32.

예외 처리 및 안전성

  • Ada 예외와 Rust 패닉은 C로 넘어가면 안 됩니다.
  • Ada에서는 예외를 잡아 에러 코드로 변환, Rust에서는 catch_unwind 사용.
  • 메모리 관리와 버퍼는 언어 경계에서 직접 전달하며, 소유권은 한쪽 언어에서만 책임집니다.

검증 방법

  • 크기/정렬 확인: Ada Type'Size, Rust std::mem::size_of::<T>().
  • 심볼 확인: nm, objdump, readelf로 확인.
  • 성능 검증: 마이크로벤치마크로 변환/복사 코드가 없는지 확인.

요약

Ada와 Rust 모두 다음 조건을 만족하면 C와 오버헤드 없는 바인딩을 구현할 수 있습니다:

  • C 호출 규약(pragma Import/Export (C) / extern "C")
  • C 호환 레이아웃(pragma Convention (C) / #[repr(C)])
  • 고정 폭 정수 및 포인터 타입 사용
  • 예외/패닉 언와인딩 금지
  • 심볼 이름 unmangled 유지

이렇게 하면 Ada와 Rust에서 작성한 코드가 C와 동일한 ABI를 가지며, 변환 계층 없이 직접 호출 가능합니다.


주의:

LLM으로 작성한 글입니다. 글에 틀린 내용이 있을 수 있습니다.

제가 아직 Ada, Rust 관련 글의 내용을 검증할 수준이 못됩니다.

추천 비추천

0

고정닉 0

0

댓글 영역

전체 댓글 0
본문 보기

하단 갤러리 리스트 영역

왼쪽 컨텐츠 영역

갤러리 리스트 영역

갤러리 리스트
번호 제목 글쓴이 작성일 조회 추천
설문 뛰어난 운동 신경으로 남자와 싸워도 이길 것 같은 여자 스타는? 운영자 25/11/24 - -
AD 따뜻한 겨울나기! 방한용품 SALE 운영자 25/11/27 - -
2905241 업비트 어떻게 해킹당한거냐 [2] 사람낚는어부갤로그로 이동합니다. 11.28 107 0
2905240 러스트 러스트 러스트 러스트 러스트 러스트 프갤러(221.149) 11.28 52 0
2905239 ❤✨☀⭐⚡☘⛩☃나님 시작합니당☃⛩☘⚡⭐☀✨❤ ♥멘헤라냥덩♥갤로그로 이동합니다. 11.28 54 0
2905238 내 컴터 상태가 이럴듯..ㅇㅅㅇ [2] 헤르 미온느갤로그로 이동합니다. 11.28 74 0
2905236 다들 이정도 정신문제는 가지지 않나 ㅇㅇ(39.7) 11.28 64 0
2905234 작년 이맘때 폭설 ㅇㅅㅇ [1] 헤르 미온느갤로그로 이동합니다. 11.28 57 0
2905231 태연 ㅇㅅㅇ 헤르 미온느갤로그로 이동합니다. 11.28 49 0
2905230 하루 한 번 헤르미온느 찬양 헤르 미온느갤로그로 이동합니다. 11.28 52 0
2905227 그레셤의 법칙이 더닝크루거에 선행한다 [29] chironpractor갤로그로 이동합니다. 11.28 112 0
2905224 맨날 뭐 망하라는 소리만 하면서 왜 자기가 애국자인척을 하지 ㅇㅇ갤로그로 이동합니다. 11.28 45 0
2905221 인지과학조져라 손발이시립디다갤로그로 이동합니다. 11.28 57 0
2905219 김영회 동국대 향가연구실장 "양주동 박사 향가 해독법 틀렸다" 발명도둑잡기(39.7) 11.28 44 0
2905218 일본 '만엽집' 대가 "일본은 아름다운 평화를 지향해야 한다" 발명도둑잡기(39.7) 11.28 40 0
2905217 양쪽 얘기 듣자는게 왜 역사왜곡임? [5] chironpractor갤로그로 이동합니다. 11.28 105 2
2905216 박원순 자ㅡ살 맞는지가 의문 [1] 발명도둑잡기(39.7) 11.28 61 0
2905215 스위스는 매달 전국민이 우편투표로 직접민주정치 발명도둑잡기(39.7) 11.28 42 0
2905214 ❤✨☀⭐⚡☘⛩☃나님 시작합니당☃⛩☘⚡⭐☀✨❤ ♥멘헤라냥덩♥갤로그로 이동합니다. 11.28 36 0
2905212 죽어가는 국민의힘 되살리는 기초의회 ‘2인 선거구’, 더 늘어나나 발명도둑잡기(39.7) 11.28 51 0
2905211 재명이 존나 찐따같네;; 카메라 보이니까 왕따 아닌척 발악;; [5] ♥멘헤라냥덩♥갤로그로 이동합니다. 11.28 77 0
2905210 진보당, 무주택자·세입자·청년의 ‘감당 가능한 주거’ 7대 정책 제안 [1] 발명도둑잡기(39.7) 11.28 55 0
2905208 경력기술서쓰는데 궁금한거 있음 [7] 프갤러(58.76) 11.28 90 0
2905207 미국 음반 시장 순위 조작을 위한 사재기 있나 발명도둑잡기(39.7) 11.28 129 0
2905203 <하우스 오브 다이너마이트> 인기래서 생각나는 예전 글 발명도둑잡기(39.7) 11.28 43 0
2905200 오늘의 소설, 영화 실마리: 초코파이 재판과 노조원 이야기 발명도둑잡기(39.7) 11.28 44 0
2905195 이익 배분 게임과 지능의 상관관계 [1] 발명도둑잡기(39.7) 11.28 83 0
2905193 넷마블 해킹 SQL 인젝션 추정 [1] ㅇㅇ(175.197) 11.28 92 0
2905191 넥스트 N.EX.T-Dear America 무삭제 발명도둑잡기(39.7) 11.28 43 0
2905190 아니 잼미니 미친년 지맘대로 배포 해버리네 ㅋㅋ 프갤러(218.236) 11.28 66 0
2905187 슈베르트-마왕 발명도둑잡기(39.7) 11.28 35 0
2905186 제리케이-마왕 발명도둑잡기(39.7) 11.28 35 0
2905185 요즘 어셈으로 짤 일이 많아서 그런가 [1] 루도그담당(58.233) 11.28 73 0
2905184 수이 블루비드 다녀옴 [1] 따당갤로그로 이동합니다. 11.28 70 0
2905181 나님 콧대가 그렇게 이뽀..? 따당갤로그로 이동합니다. 11.28 90 0
2905179 독도 간접 언급한 中, 포털사이트·AI도 “독도는 한국 땅” 발명도둑잡기(39.7) 11.28 45 0
2905178 페이커닮은 개발자 찾습니다 [2] 프갤러(106.101) 11.28 100 0
2905177 언리얼 메뉴얼 진짜 거지같네 [4] 프갤러(114.205) 11.28 83 0
2905175 개발하냐고 글 쓸 시간도 없고 ㅁㅌ겠네 ㅠㅠ [4] 나르시갤로그로 이동합니다. 11.27 61 0
2905174 세계최초의 최상위 수준 C API 래핑 설계 패턴인가? 나르시갤로그로 이동합니다. 11.27 73 0
2905173 N-Arity 제네릭 래퍼 + 중앙 집중식 예외 매퍼' 아키텍처 나르시갤로그로 이동합니다. 11.27 41 0
2905172 Clair 라이브러리: 예외 처리 C 바인딩 아키텍처 [1] 나르시갤로그로 이동합니다. 11.27 84 0
2905171 옛날에 nuri.net이 뭐였더라 발명도둑잡기(39.7) 11.27 48 0
2905170 중국 딥시크가 미국 AI 압살하는중 ㄷㄷ [4] ㅇㅇ갤로그로 이동합니다. 11.27 104 0
2905169 ‘성폭력 발언’ 이준석 불송치에…“막말 자유권은 없다” 반발 봇물 발명도둑잡기(39.7) 11.27 57 0
2905168 민주당, '2인선거구로 쪼개기'에 합세한다면 내란본당 국민의힘 부활 발명도둑잡기(39.7) 11.27 54 0
2905167 뭔가 소화가 잘 안된느낌 [2] ♥멘헤라냥덩♥갤로그로 이동합니다. 11.27 80 0
2905166 [애니뉴스] YxD Labs - 유튜브 링크 공유 ㅇㅇ(121.172) 11.27 44 0
2905165 MS 엣지브라우저 msn에 중요 노출되는 극우 황색지들 발명도둑잡기(39.7) 11.27 42 0
2905164 이세돌이 바둑 은퇴한거 이제 실감난다 [1] 프갤러(110.70) 11.27 70 0
2905163 컴퓨터로 일하는데 싸구려컴 쓰는 이유가 뭐임? [5] 에이도비갤로그로 이동합니다. 11.27 93 0
2905162 핫딜 놓쳐서 월급 10% 날림 실화? 프갤러(117.111) 11.27 73 0
갤러리 내부 검색
제목+내용게시물 정렬 옵션

오른쪽 컨텐츠 영역

실시간 베스트

1/8

디시미디어

디시이슈

1/2