vendors/ is a third-party namespace (stb_image, kb_text_shape, etc.);
test fixtures don't belong there. The .c/.h companion files for the
Phase-0 FFI baselines now sit alongside the .sx that drives them in
examples/, with matching basenames:
examples/ffi-01-primitives.{sx,c,h} <- was vendors/ffi_primitives/
examples/ffi-02-small-struct.{sx,c,h} <- was vendors/ffi_structs/
examples/ffi-03-large-struct.{sx,c,h} <- was vendors/ffi_large_struct/
examples/ffi-04-fp-struct.{sx,c,h} <- was vendors/ffi_fp_struct/
examples/ffi-05-string-args.{sx,c,h} <- was vendors/ffi_strings/
examples/ffi-06-callback.{sx,c,h} <- was vendors/ffi_callback/
examples/101-ffi-medium-struct.{sx,c} <- was vendors/ffi_medium_struct/
`#source` / `#include` paths in the .sx files become bare filenames
(no prefix) since imports.zig's base_dir resolution finds them
relative to the importing .sx file's directory.
`library/vendors/sx_ffi_resolve_test/` stays put — that one's the
whole point: regression coverage for the stdlib-search branch of
the resolution chain, so it must live where ONLY that branch can
find it.
94/94 regression tests pass.
21 lines
993 B
C
21 lines
993 B
C
// Focused FP-aggregate (HFA) FFI baselines. Distinct from the int-aggregate
|
|
// register-coercion paths because all-float / all-double structs of ≤4 fields
|
|
// stay as struct values in LLVM and are passed/returned via the float
|
|
// register file (AAPCS64 v0..v3; SysV AMD64 xmm0..xmm7). This was the
|
|
// `UIEdgeInsets`-as-f32-vs-f64 landmine — pinned here so a future ABI rule
|
|
// change that wrecks the FP path fails this test directly.
|
|
//
|
|
// FQuad — 16 B, four float (small HFA; same slot as Vec4f)
|
|
// DQuad — 32 B, four double (UIEdgeInsets-shape HFA)
|
|
|
|
typedef struct { float a; float b; float c; float d; } FQuad;
|
|
typedef struct { double a; double b; double c; double d; } DQuad;
|
|
|
|
FQuad ffi_fquad_make (float a, float b, float c, float d);
|
|
FQuad ffi_fquad_reverse(FQuad v);
|
|
float ffi_fquad_sum (FQuad v);
|
|
|
|
DQuad ffi_dquad_make (double a, double b, double c, double d);
|
|
DQuad ffi_dquad_reverse(DQuad v);
|
|
double ffi_dquad_sum (DQuad v);
|