The alignment calculation of external enums is wrong, it should be

FFIExternalEnumerationType >> externalTypeAlignment
        ^ self representationType externalTypeAlignment

It only manifests for 32bit platforms on Windows  since that's the only one 
with a pointer alignment (which superclass FFIExternalReferenceType returns) of 
8, not 4 (which is the same alignment as the correct FFIUInt alignment)

Cheers,
Henry


> On 09 Jul 2016, at 12:08 , Merwan Ouddane <merwanoudd...@gmail.com> wrote:
> 
> Yes I did.
> 
> Have you tried on windows ?
> 
> Merwan
> 
> On 08/07/2016 21:20, Esteban Lorenzano wrote:
>> it works fine for me:
>> 
>> Struct>>b
>>      "This method was automatically generated"
>>      ^Enum fromInteger: (handle unsignedLongAt: 5)
>> 
>> Struct>>b: anObject
>>      "This method was automatically generated"
>>      handle unsignedLongAt: 5 put: anObject value
>> 
>> Struct>>c
>>      "This method was automatically generated"
>>      ^Enum fromInteger: (handle unsignedLongAt: 9)
>> 
>> Struct>>c: anObject
>>      "This method was automatically generated"
>>      handle unsignedLongAt: 9 put: anObject value
>> 
>> question: did you initialise the Enum? before generating fields?
>> 
>> Esteban
>> 
>>> On 08 Jul 2016, at 20:42, Merwan Ouddane <merwanoudd...@gmail.com 
>>> <mailto:merwanoudd...@gmail.com>> wrote:
>>> 
>>> Struct >> fieldsDesc
>>>     ^#( void* a;
>>>     Enum b;
>>>     Enum c;
>>>     )
>>> 
>>> Enum >> enumDecl
>>>     ^ #( TEST 1 )
>>> 
>>> I joined a .st with the struct and the enum, the package name is FFITest.
>>> 
>>> Merwan
>>> 
>>> On 08/07/2016 20:14, Esteban Lorenzano wrote:
>>>> that still does not helps… show me the code!
>>>> 
>>>> Esteban
>>>> 
>>>>> On 08 Jul 2016, at 20:09, Merwan Ouddane <merwanoudd...@gmail.com 
>>>>> <mailto:merwanoudd...@gmail.com>> wrote:
>>>>> 
>>>>> Sorry not unsigned longs but enumerations
>>>>> 
>>>>> On Fri, Jul 8, 2016 at 10:09 AM, Esteban Lorenzano <esteba...@gmail.com 
>>>>> <mailto:esteba...@gmail.com>> wrote:
>>>>> how do you declare this?
>>>>> 
>>>>>> On 08 Jul 2016, at 10:01, Merwan Ouddane <merwanoudd...@gmail.com 
>>>>>> <mailto:merwanoudd...@gmail.com>> wrote:
>>>>>> 
>>>>>> I spoke too fast ^^'
>>>>>> 
>>>>>> struct Test {
>>>>>>   void * ptr;
>>>>>>   insigned long i;
>>>>>>   insigned long j;
>>>>>> }
>>>>>> 
>>>>>> Real size is 12, UFFI counts 24
>>>>>> 
>>>>>> Merwan
>>>>>> 
>>>>>> 
>>>>>> Le 7 juil. 2016 10:02, "Merwan Ouddane" <merwanoudd...@gmail.com 
>>>>>> <mailto:merwanoudd...@gmail.com>> a écrit :
>>>>>> Now it is working, thank you :)
>>>>>> 
>>>>>> On Thu, Jul 7, 2016 at 8:42 AM, Esteban Lorenzano <esteba...@gmail.com 
>>>>>> <mailto:esteba...@gmail.com>> wrote:
>>>>>> Hi,
>>>>>> 
>>>>>> > On 07 Jul 2016, at 01:54, Ben Coman <b...@openinworld.com 
>>>>>> > <mailto:b...@openinworld.com>> wrote:
>>>>>> >
>>>>>> > On Thu, Jul 7, 2016 at 12:58 AM, Merwan Ouddane 
>>>>>> > <merwanoudd...@gmail.com <mailto:merwanoudd...@gmail.com>> wrote:
>>>>>> >> PS: for the first example, the alignment is not respected, the vec3
>>>>>> >> structure is starting at 9 but uffi is fetching it at 5
>>>>>> >
>>>>>> > Hi Esteban,
>>>>>> >
>>>>>> > Is it possible to get a feature or a recipe to output the sizeof or
>>>>>> > offset of fields in types as understood by the Image, and the same
>>>>>> > from a C side - that could be used as the standard first step in
>>>>>> > troubleshooting these kinds of issues ?
>>>>>> 
>>>>>> FFIExternalType class>>sizeOf: ?
>>>>>> 
>>>>>> but that does not works for complex type sizes (like FFIExternalArray).
>>>>>> 
>>>>>> I don’t know what the problem is here, because in my test (attached) it 
>>>>>> seems to be working fine.
>>>>>> maybe problem is on how the Vec3 array is created, it should be 
>>>>>> something like this:
>>>>>> 
>>>>>> Vec3 class>>iinitialize
>>>>>>         self
>>>>>>                 type: (FFIExternalType resolveType: 'double')
>>>>>>                 size: 3
>>>>>> 
>>>>>> (is like that because FFITypeArray is more designed to be used creating 
>>>>>> anonymous types than concretes, but well… )
>>>>>> 
>>>>>> in any case, it seems to be working for me.
>>>>>> 
>>>>>> Now, about the use…
>>>>>> 
>>>>>> doing this:
>>>>>> 
>>>>>> p := Position new.
>>>>>> p v1 at: 1 put: 42.0.
>>>>>> p v1 at: 1. “will print 0.0"
>>>>>> 
>>>>>> why? because it works making a copy (maybe it should work passing a 
>>>>>> segment, as nested structs work, but this is how it works now).
>>>>>> 
>>>>>> What should work (at doesn’t) in this case is this:
>>>>>> 
>>>>>> v := Vector3 new.
>>>>>> p := Position new.
>>>>>> v at: 1 put: 42.0.
>>>>>> p v1: v.
>>>>>> p v1 at: 1. “will print 42.0"
>>>>>> 
>>>>>> it does not work because I made a mistake in field generation that I 
>>>>>> already fixed… so you will need to update UFFI (and regenerate field 
>>>>>> accessors) ;)
>>>>>> 
>>>>>> also… I will provide a fix to make first case work… just later because 
>>>>>> now I’m going to my french lessons :)
>>>>>> 
>>>>>> Esteban
>>>>>> 
>>>>>> ps: for future reference, a description of: install this, run that, is a 
>>>>>> lot easier to understand the problem (is a case of “show me the code!”) 
>>>>>> :P
>>>>>> 
>>>>>> 
>>>>>> 
>>>>>> 
>>>>>> >
>>>>>> > cheers -ben
>>>>>> >
>>>>>> >>
>>>>>> >>
>>>>>> >> On 06/07/2016 17:55, Merwan Ouddane wrote:
>>>>>> >>
>>>>>> >> Another test:
>>>>>> >> I replaced double by integer, for visibility...
>>>>>> >> typedef struct vec3 {
>>>>>> >>     int data[3];
>>>>>> >> } vec3;
>>>>>> >>
>>>>>> >> add a second vec3 to position:
>>>>>> >>
>>>>>> >> typedef struct position {
>>>>>> >>     int i;
>>>>>> >>     vec3 vec;
>>>>>> >>     vec3 vec2;
>>>>>> >> } position;
>>>>>> >>
>>>>>> >> Now in pharo:
>>>>>> >> Position >> fieldsDesc
>>>>>> >> "self rebuildFieldAccessors"
>>>>>> >>    ^ #(
>>>>>> >>    int i;
>>>>>> >>    Vec3 vec;
>>>>>> >>    Vec3 vec2;
>>>>>> >> )
>>>>>> >>
>>>>>> >> The size returned for each stucture is 16 instead of 12 that because 
>>>>>> >> of the
>>>>>> >> "8 byte alignment"
>>>>>> >>
>>>>>> >> Meaning that the "position" structure is corrupted.
>>>>>> >>
>>>>>> >> With this function:
>>>>>> >>
>>>>>> >>
>>>>>> >> extern "C" void DLL_EXPORT fillStruct(position *position)
>>>>>> >> {
>>>>>> >>    position -> i = 19;
>>>>>> >>    (position -> vec).data[0] = 1;
>>>>>> >>    (position -> vec).data[1] = 2;
>>>>>> >>    (position -> vec).data[2] = 3;
>>>>>> >>    (position -> vec2).data[0] = 1;
>>>>>> >>    (position -> vec2).data[1] = 2;
>>>>>> >>    (position -> vec2).data[2] = 3;
>>>>>> >> }
>>>>>> >>
>>>>>> >> We will get:
>>>>>> >> position i == 19
>>>>>> >> position vec at: 1 == 1
>>>>>> >> position vec2 at: 1 == 2
>>>>>> >>
>>>>>> >>
>>>>>> >> On Tue, Jul 5, 2016 at 3:12 PM, Ronie Salgado <ronies...@gmail.com 
>>>>>> >> <mailto:ronies...@gmail.com>> wrote:
>>>>>> >>>
>>>>>> >>> I compiled the DLL using Visual Studio 2015 Community Edition. Later 
>>>>>> >>> I
>>>>>> >>> will check with mingw.
>>>>>> >>>
>>>>>> >>> 2016-07-05 14:58 GMT+02:00 Merwan Ouddane <merwanoudd...@gmail.com 
>>>>>> >>> <mailto:merwanoudd...@gmail.com>>:
>>>>>> >>>>
>>>>>> >>>> Using codeblocks, mine are:
>>>>>> >>>>
>>>>>> >>>> mingw32-g++.exe -m32 -DBUILD_DLL -c main.cpp -o obj\Release\main.o
>>>>>> >>>> mingw32-g++.exe -shared -Wl,--output-def=bin\Release\libTest.def
>>>>>> >>>> -Wl,--out-implib=bin\Release\libTest.a -Wl,--dll  
>>>>>> >>>> obj\Release\main.o  -o
>>>>>> >>>> bin\Release\Test.dll -s -m32
>>>>>> >>>>
>>>>>> >>>>
>>>>>> >>>> On Tue, Jul 5, 2016 at 2:52 PM, Merwan Ouddane 
>>>>>> >>>> <merwanoudd...@gmail.com <mailto:merwanoudd...@gmail.com>>
>>>>>> >>>> wrote:
>>>>>> >>>>>
>>>>>> >>>>> I am not moving from another plateform :/
>>>>>> >>>>>
>>>>>> >>>>> I tried it in pharo 6 and I it didn't work either.
>>>>>> >>>>>
>>>>>> >>>>> It could be my dll. What is your compilation line for the dll ?
>>>>>> >>>>>
>>>>>> >>>>> Thanks you,
>>>>>> >>>>> Merwan
>>>>>> >>>>>
>>>>>> >>>>> On Tue, Jul 5, 2016 at 2:14 PM, Ronie Salgado <ronies...@gmail.com 
>>>>>> >>>>> <mailto:ronies...@gmail.com>>
>>>>>> >>>>> wrote:
>>>>>> >>>>>>
>>>>>> >>>>>> Hi Merwan,
>>>>>> >>>>>>
>>>>>> >>>>>> I tested this on Pharo 6 and it is working in Windows. However, 
>>>>>> >>>>>> in 32
>>>>>> >>>>>> bits Window doubles have an 8 byte alignment, unlike Linux where 
>>>>>> >>>>>> they have a
>>>>>> >>>>>> 4 byte alignment.
>>>>>> >>>>>>
>>>>>> >>>>>> Can you try doing the following before performing the ffi call in
>>>>>> >>>>>> Windows, if you are moving an image from Linux or OS X:
>>>>>> >>>>>>
>>>>>> >>>>>> Vec3 rebuildFieldAccessors.
>>>>>> >>>>>> Position rebuildFieldAccessors.
>>>>>> >>>>>>
>>>>>> >>>>>> Best regards,
>>>>>> >>>>>> Ronie
>>>>>> >>>>>>
>>>>>> >>>>>> 2016-07-05 11:11 GMT+02:00 Merwan Ouddane 
>>>>>> >>>>>> <merwanoudd...@gmail.com <mailto:merwanoudd...@gmail.com>>:
>>>>>> >>>>>>>
>>>>>> >>>>>>> Hi,
>>>>>> >>>>>>>
>>>>>> >>>>>>> I have an issue whith nested structures.
>>>>>> >>>>>>>
>>>>>> >>>>>>> I made some "dummy" structures in c:
>>>>>> >>>>>>>
>>>>>> >>>>>>>
>>>>>> >>>>>>> typedef struct vec3 {
>>>>>> >>>>>>>     double data[3];
>>>>>> >>>>>>> } vec3;
>>>>>> >>>>>>>
>>>>>> >>>>>>> typedef struct position {
>>>>>> >>>>>>>     int i;
>>>>>> >>>>>>>     vec3 vec;
>>>>>> >>>>>>> } position;
>>>>>> >>>>>>>
>>>>>> >>>>>>> And a "dummy" function to fill it:
>>>>>> >>>>>>> void fillStruct(position *position)
>>>>>> >>>>>>> {
>>>>>> >>>>>>>    position -> i = 19;
>>>>>> >>>>>>>    (position -> vec).data[0] = 1;
>>>>>> >>>>>>>    (position -> vec).data[1] = 2;
>>>>>> >>>>>>>    (position -> vec).data[2] = 3;
>>>>>> >>>>>>> }
>>>>>> >>>>>>>
>>>>>> >>>>>>> But I can't make the nested structure work.
>>>>>> >>>>>>> The "i" is correctly set to 19 but I have values that doesn't 
>>>>>> >>>>>>> make any
>>>>>> >>>>>>> sense in the vec3 structure.
>>>>>> >>>>>>>
>>>>>> >>>>>>> In Pharo
>>>>>> >>>>>>> I declared the Double3 type for the array inside Vec3:
>>>>>> >>>>>>> Double3 := FFITypeArray ofType: 'double' size: 3
>>>>>> >>>>>>>
>>>>>> >>>>>>> Vec3>>fieldsDesc
>>>>>> >>>>>>>    ^ #(
>>>>>> >>>>>>>    Double3 v;
>>>>>> >>>>>>> )
>>>>>> >>>>>>>
>>>>>> >>>>>>> And the position:
>>>>>> >>>>>>> Position>>fieldsDesc
>>>>>> >>>>>>>    ^ #(
>>>>>> >>>>>>>    int i;
>>>>>> >>>>>>>    Vec3 vec;
>>>>>> >>>>>>> )
>>>>>> >>>>>>>
>>>>>> >>>>>>> The ffi call:
>>>>>> >>>>>>> ^ self ffiCall: #(void fillStruct(Position *position)) module:
>>>>>> >>>>>>> 'Test.dll'
>>>>>> >>>>>>>
>>>>>> >>>>>>> Sorry for the long / messy mail :p
>>>>>> >>>>>>>
>>>>>> >>>>>>> Any clues ?
>>>>>> >>>>>>>
>>>>>> >>>>>>> Cheers,
>>>>>> >>>>>>> Merwan
>>>>>> >>>>>>
>>>>>> >>>>>>
>>>>>> >>>>>
>>>>>> >>>>
>>>>>> >>>
>>>>>> >>
>>>>>> >>
>>>>>> >
>>>>>> 
>>>>>> 
>>>>>> 
>>>>> 
>>>>> 
>>>> 
>>> 
>>> <FFITest.st <http://ffitest.st/>>
>> 
> 

Attachment: signature.asc
Description: Message signed with OpenPGP using GPGMail

Reply via email to