-
Notifications
You must be signed in to change notification settings - Fork 986
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
add ftype-scheme-object-pointer
and related foreign-pointer extensions
#897
base: main
Are you sure you want to change the base?
Conversation
This change helps close a gap between the Chez Scheme and Racket FFIs. It builds on the |
An ftype pointer to a Scheme object is useful to communicate the address of an bytevector or flvector (like `object->reference-address`) in the same places that ftype pointers can be used. There's a key difference between using these new pointers and constructing a pointer with the result of `object->reference-address`: GC cooperation with a Scheme-object pointer ensures that the address does not go stale. Instead, the address is extracted just after moving into a context where a collection cannot occur (e.g., a foreign call without `__collect_safe`). With Scheme-object pointers as a way to unify GCable and foreign references through the ftype interface, some further additions give the ftype layer flexiblity similar to the lower-level `foreign-ref` API, which extracts data from a reference without a declared/checked foreign representation. The `ftype-any-ref` and `ftype-any-set!` forms cover pointer access and update, and `ftype-pointer` is allowed as a ftype-name for a generic pointer type. In addition, `type-scheme-object-pointer` works as an ftype-name for a pointer to a GCable object. In the case of an `(& <ftype>)` argument or result, `(& <ftype> ftype-pointer)` can be used to accept/allocate a generic pointer record instead of a <ftype>-specific pointer record, and similarly `(& <ftype> ftype-scheme-object-pointer)`. The key changes are fairly modest, but there are many additional changes just to expand plumbing. The most tedious change is that the internal `$make-record-type` function has a new argument that can turn on GC cooperation for Scheme-object ftype pointers. Most of the rest is about making foreign-call pointer arguments and results distinguish a predicate for argument checking from the rtd used to create pointer objects.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Just a quick sweep for typos so far.
In the commit message:
- "address of an bytevector" -> "address of a bytevector"
- "
type-scheme-object-pointer
works as" -> "ftype-scheme-object-pointer
works as"
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This is a pretty big set of changes, and I've skimmed a bit to go through it.
Generally, I think this makes sense. From a practical perspective, it seems like this is specifically useful for referencing into bytevector
and flvector
, with any other type requiring some knowledge of the internal representation consistent with the object->reference-address
.
#f | ||
#t)]) | ||
(make-compile-time-value | ||
(lambda (which) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Nit. Indentation looks off here.
An ftype pointer to a Scheme object is useful to communicate the address of an bytevector or flvector (like
object->reference-address
) in the same places that ftype pointers can be used. There's a key difference between using these new pointers and constructing a pointer with the result ofobject->reference-address
: GC cooperation with a Scheme-object pointer ensures that the address does not go stale. Instead, the address is extracted just after moving into a context where a collection cannot occur (e.g., a foreign call without__collect_safe
).With Scheme-object pointers as a way to unify GCable and foreign references through the ftype interface, some further additions give the ftype layer flexiblity similar to the lower-level
foreign-ref
API, which extracts data from a reference without a declared/checked foreign representation. Theftype-any-ref
andftype-any-set!
forms cover pointer access and update, andftype-pointer
is allowed as a ftype-name for a generic pointer type. In addition,type-scheme-object-pointer
works as an ftype-name for a pointer to a GCable object. In the case of an(& <ftype>)
argument or result,(& <ftype> ftype-pointer)
can be used to accept/allocate a generic pointer record instead of a -specific pointer record, and similarly(& <ftype> ftype-scheme-object-pointer)
.The key changes are fairly modest, but there are many additional changes just to expand plumbing. The most tedious change is that the internal
$make-record-type
function has a new argument that can turn on GC cooperation for Scheme-object ftype pointers. Most of the rest is about making foreign-call pointer arguments and results distinguish a predicate for argument checking from the rtd used to create pointer objects.