This message has two audiences: One the general CFFI group, and second the GSL maintainer.
This is using latest CCL and SBCL on 64-bit Windows 7, and MSYS2 running 64-bit MinGW and its GSL2.0 and 2.1.
Running GSL 2.0 and 2.1 under GSLL resulted in exception violations. I could eliminate them by specifying the length of an integer as 8 instead of 4 bytes.
My question has to do with the origin of this specification, since it is derived from CFFI and GSLL, not hard-coded.
Specifically, in GSLL, the following code in init/types.lisp:
(case (cffi:foreign-type-size :long)
(8 (push :int64 *features*))
(4 (push :int32 *features*)))
evaluates to 4, pushing :int32 into *features*. Here is some additional output of cffi:foreign-type-size on my machine:
GSL> (cffi:foreign-type-size :double)
8
GSL> (cffi:foreign-type-size :long)
4
GSL> (cffi:foreign-type-size :long-long)
8
GSL> (cffi:foreign-type-size :int)
4
This feature eventually makes its way to other code in GSLL. In the Linear Algebra module, the function make-permutation (in data/permutation.lisp) has this line:
(make-instance
'permutation
:element-type '(unsigned-byte #+int64 64 #+int32 32)
:dimensions (if (typep n 'permutation) (grid:dimensions n) (list n)))))
In my environment element type resulted in unsigned-byte 32.
When I hard-coded my features to :int64 (and unsigned-byte 64), all the exception errors disappeared.
I hope this gives enough background to fix this error (either in my setup, gsll, or cffi).
Thanks,
Mirko