ffi 1.11.2 → 1.13.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (212) hide show
  1. checksums.yaml +4 -4
  2. data/.appveyor.yml +3 -0
  3. data/.github/workflows/ci.yml +64 -0
  4. data/.travis.yml +21 -5
  5. data/CHANGELOG.md +64 -0
  6. data/Gemfile +6 -4
  7. data/README.md +10 -1
  8. data/Rakefile +24 -43
  9. data/ext/ffi_c/AbstractMemory.c +5 -9
  10. data/ext/ffi_c/Buffer.c +2 -2
  11. data/ext/ffi_c/Call.c +1 -11
  12. data/ext/ffi_c/ClosurePool.c +11 -14
  13. data/ext/ffi_c/DynamicLibrary.c +1 -1
  14. data/ext/ffi_c/Function.c +9 -24
  15. data/ext/ffi_c/FunctionInfo.c +1 -2
  16. data/ext/ffi_c/LongDouble.c +5 -3
  17. data/ext/ffi_c/LongDouble.h +0 -4
  18. data/ext/ffi_c/MemoryPointer.c +1 -1
  19. data/ext/ffi_c/MethodHandle.c +18 -24
  20. data/ext/ffi_c/MethodHandle.h +3 -2
  21. data/ext/ffi_c/Platform.c +1 -0
  22. data/ext/ffi_c/Pointer.c +1 -1
  23. data/ext/ffi_c/Struct.c +47 -51
  24. data/ext/ffi_c/Struct.h +12 -6
  25. data/ext/ffi_c/StructLayout.c +20 -14
  26. data/ext/ffi_c/Thread.c +0 -3
  27. data/ext/ffi_c/Thread.h +0 -3
  28. data/ext/ffi_c/Types.c +1 -1
  29. data/ext/ffi_c/compat.h +4 -0
  30. data/ext/ffi_c/extconf.rb +13 -16
  31. data/ext/ffi_c/libffi/.travis.yml +32 -12
  32. data/ext/ffi_c/libffi/.travis/bfin-sim.exp +58 -0
  33. data/ext/ffi_c/libffi/.travis/build-cross-in-container.sh +14 -0
  34. data/ext/ffi_c/libffi/.travis/build-in-container.sh +2 -12
  35. data/ext/ffi_c/libffi/.travis/build.sh +62 -30
  36. data/ext/ffi_c/libffi/.travis/install.sh +65 -37
  37. data/ext/ffi_c/libffi/.travis/m32r-sim.exp +58 -0
  38. data/ext/ffi_c/libffi/.travis/or1k-sim.exp +58 -0
  39. data/ext/ffi_c/libffi/.travis/powerpc-eabisim.exp +58 -0
  40. data/ext/ffi_c/libffi/.travis/site.exp +10 -1
  41. data/ext/ffi_c/libffi/.travis/wine-sim.exp +55 -0
  42. data/ext/ffi_c/libffi/{ChangeLog.libffi-3.1 → ChangeLog.old} +1407 -0
  43. data/ext/ffi_c/libffi/LICENSE +1 -1
  44. data/ext/ffi_c/libffi/Makefile.am +6 -4
  45. data/ext/ffi_c/libffi/README.md +18 -6
  46. data/ext/ffi_c/libffi/configure.ac +26 -10
  47. data/ext/ffi_c/libffi/configure.host +5 -2
  48. data/ext/ffi_c/libffi/generate-darwin-source-and-headers.py +1 -3
  49. data/ext/ffi_c/libffi/include/ffi.h.in +15 -7
  50. data/ext/ffi_c/libffi/libffi.map.in +8 -12
  51. data/ext/ffi_c/libffi/libffi.xcodeproj/project.pbxproj +2 -48
  52. data/ext/ffi_c/libffi/libtool-version +1 -1
  53. data/ext/ffi_c/libffi/m4/ax_append_flag.m4 +5 -26
  54. data/ext/ffi_c/libffi/m4/ax_check_compile_flag.m4 +5 -26
  55. data/ext/ffi_c/libffi/m4/ax_compiler_vendor.m4 +2 -1
  56. data/ext/ffi_c/libffi/m4/ax_configure_args.m4 +5 -26
  57. data/ext/ffi_c/libffi/m4/ax_gcc_archflag.m4 +7 -3
  58. data/ext/ffi_c/libffi/src/aarch64/ffi.c +6 -0
  59. data/ext/ffi_c/libffi/src/aarch64/sysv.S +13 -2
  60. data/ext/ffi_c/libffi/src/closures.c +20 -6
  61. data/ext/ffi_c/libffi/src/mips/o32.S +2 -0
  62. data/ext/ffi_c/libffi/src/pa/ffi.c +46 -91
  63. data/ext/ffi_c/libffi/src/pa/ffitarget.h +1 -6
  64. data/ext/ffi_c/libffi/src/pa/hpux32.S +4 -2
  65. data/ext/ffi_c/libffi/src/pa/linux.S +4 -2
  66. data/ext/ffi_c/libffi/src/powerpc/ffi.c +3 -2
  67. data/ext/ffi_c/libffi/src/powerpc/ffi_linux64.c +154 -8
  68. data/ext/ffi_c/libffi/src/powerpc/ffi_powerpc.h +18 -7
  69. data/ext/ffi_c/libffi/src/powerpc/ffitarget.h +10 -4
  70. data/ext/ffi_c/libffi/src/powerpc/linux64.S +83 -28
  71. data/ext/ffi_c/libffi/src/powerpc/linux64_closure.S +67 -3
  72. data/ext/ffi_c/libffi/src/powerpc/sysv.S +5 -7
  73. data/ext/ffi_c/libffi/src/x86/ffi.c +7 -4
  74. data/ext/ffi_c/libffi/src/x86/ffi64.c +10 -8
  75. data/ext/ffi_c/libffi/src/x86/ffitarget.h +15 -2
  76. data/ext/ffi_c/libffi/src/x86/ffiw64.c +10 -8
  77. data/ext/ffi_c/libffi/src/x86/sysv.S +13 -4
  78. data/ext/ffi_c/libffi/src/x86/unix64.S +58 -2
  79. data/ext/ffi_c/libffi/src/x86/win64.S +4 -1
  80. data/ext/ffi_c/libffi/testsuite/Makefile.am +78 -75
  81. data/ext/ffi_c/libffi/testsuite/lib/libffi.exp +1 -18
  82. data/ext/ffi_c/libffi/testsuite/libffi.bhaible/bhaible.exp +7 -2
  83. data/ext/ffi_c/libffi/testsuite/libffi.bhaible/test-call.c +1 -1
  84. data/ext/ffi_c/libffi/testsuite/libffi.bhaible/test-callback.c +1 -1
  85. data/ext/ffi_c/libffi/testsuite/libffi.call/call.exp +12 -1
  86. data/ext/ffi_c/libffi/testsuite/libffi.closures/closure.exp +67 -0
  87. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/closure_fn0.c +0 -0
  88. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/closure_fn1.c +0 -0
  89. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/closure_fn2.c +0 -0
  90. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/closure_fn3.c +0 -0
  91. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/closure_fn4.c +0 -0
  92. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/closure_fn5.c +0 -0
  93. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/closure_fn6.c +0 -0
  94. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/closure_loc_fn0.c +0 -0
  95. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/closure_simple.c +0 -0
  96. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_12byte.c +0 -0
  97. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_16byte.c +0 -0
  98. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_18byte.c +0 -0
  99. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_19byte.c +0 -0
  100. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_1_1byte.c +0 -0
  101. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_20byte.c +0 -0
  102. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_20byte1.c +0 -0
  103. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_24byte.c +0 -0
  104. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_2byte.c +0 -0
  105. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_3_1byte.c +0 -0
  106. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_3byte1.c +0 -0
  107. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_3byte2.c +0 -0
  108. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_3float.c +0 -0
  109. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_4_1byte.c +0 -0
  110. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_4byte.c +0 -0
  111. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_5_1_byte.c +0 -0
  112. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_5byte.c +0 -0
  113. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_64byte.c +0 -0
  114. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_6_1_byte.c +0 -0
  115. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_6byte.c +0 -0
  116. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_7_1_byte.c +0 -0
  117. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_7byte.c +0 -0
  118. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_8byte.c +0 -0
  119. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_9byte1.c +0 -0
  120. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_9byte2.c +0 -0
  121. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_double.c +0 -0
  122. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_float.c +0 -0
  123. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_longdouble.c +0 -0
  124. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_longdouble_split.c +0 -0
  125. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_longdouble_split2.c +0 -0
  126. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_pointer.c +0 -0
  127. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_sint16.c +0 -0
  128. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_sint32.c +0 -0
  129. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_sint64.c +0 -0
  130. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_uint16.c +0 -0
  131. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_uint32.c +0 -0
  132. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_align_uint64.c +0 -0
  133. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_dbls_struct.c +0 -0
  134. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_double.c +0 -0
  135. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_double_va.c +0 -0
  136. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_float.c +0 -0
  137. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_longdouble.c +0 -0
  138. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_longdouble_va.c +0 -0
  139. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_many_mixed_args.c +0 -0
  140. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_many_mixed_float_double.c +0 -0
  141. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_multi_schar.c +0 -0
  142. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_multi_sshort.c +0 -0
  143. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_multi_sshortchar.c +0 -0
  144. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_multi_uchar.c +0 -0
  145. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_multi_ushort.c +0 -0
  146. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_multi_ushortchar.c +0 -0
  147. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_pointer.c +0 -0
  148. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_pointer_stack.c +0 -0
  149. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_schar.c +0 -0
  150. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_sint.c +0 -0
  151. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_sshort.c +0 -0
  152. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_struct_va1.c +0 -0
  153. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_uchar.c +0 -0
  154. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_uchar_va.c +0 -0
  155. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_uint.c +0 -0
  156. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_uint_va.c +0 -0
  157. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_ulong_va.c +0 -0
  158. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_ulonglong.c +0 -0
  159. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_ushort.c +0 -0
  160. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/cls_ushort_va.c +0 -0
  161. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/err_bad_abi.c +0 -0
  162. data/ext/ffi_c/libffi/testsuite/libffi.closures/ffitest.h +138 -0
  163. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/huge_struct.c +1 -1
  164. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct.c +0 -0
  165. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct1.c +0 -0
  166. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct10.c +0 -0
  167. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct11.c +0 -0
  168. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct2.c +0 -0
  169. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct3.c +0 -0
  170. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct4.c +0 -0
  171. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct5.c +0 -0
  172. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct6.c +0 -0
  173. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct7.c +0 -0
  174. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct8.c +0 -0
  175. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/nested_struct9.c +0 -0
  176. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/problem1.c +0 -0
  177. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/stret_large.c +0 -0
  178. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/stret_large2.c +0 -0
  179. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/stret_medium.c +0 -0
  180. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/stret_medium2.c +0 -0
  181. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/testclosure.c +0 -0
  182. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/unwindtest.cc +0 -0
  183. data/ext/ffi_c/libffi/testsuite/{libffi.call → libffi.closures}/unwindtest_ffi_call.cc +0 -0
  184. data/ffi.gemspec +3 -3
  185. data/lib/ffi.rb +10 -2
  186. data/lib/ffi/ffi.rb +1 -0
  187. data/lib/ffi/library.rb +5 -1
  188. data/lib/ffi/platform.rb +2 -2
  189. data/lib/ffi/platform/arm-linux/types.conf +32 -4
  190. data/lib/ffi/platform/i386-windows/types.conf +26 -79
  191. data/lib/ffi/platform/powerpc-linux/types.conf +32 -2
  192. data/lib/ffi/platform/powerpc-openbsd/types.conf +156 -0
  193. data/lib/ffi/platform/sparcv9-openbsd/types.conf +156 -0
  194. data/lib/ffi/platform/x86_64-darwin/types.conf +4 -0
  195. data/lib/ffi/platform/x86_64-linux/types.conf +21 -0
  196. data/lib/ffi/platform/x86_64-windows/types.conf +10 -78
  197. data/lib/ffi/pointer.rb +19 -12
  198. data/lib/ffi/struct.rb +10 -5
  199. data/lib/ffi/tools/types_generator.rb +2 -0
  200. data/lib/ffi/version.rb +1 -1
  201. data/samples/getlogin.rb +1 -1
  202. data/samples/getpid.rb +1 -1
  203. data/samples/gettimeofday.rb +8 -8
  204. data/samples/hello.rb +2 -1
  205. data/samples/inotify.rb +1 -1
  206. data/samples/pty.rb +1 -2
  207. data/samples/qsort.rb +0 -1
  208. metadata +116 -110
  209. data/ext/ffi_c/libffi/ChangeLog.libffi +0 -584
  210. data/ext/ffi_c/libffi/ChangeLog.libgcj +0 -40
  211. data/ext/ffi_c/libffi/ChangeLog.v1 +0 -764
  212. data/samples/sample_helper.rb +0 -6
@@ -1,4 +1,4 @@
1
- libffi - Copyright (c) 1996-2019 Anthony Green, Red Hat, Inc and others.
1
+ libffi - Copyright (c) 1996-2020 Anthony Green, Red Hat, Inc and others.
2
2
  See source files for details.
3
3
 
4
4
  Permission is hereby granted, free of charge, to any person obtaining
@@ -14,15 +14,14 @@ if BUILD_DOCS
14
14
  SUBDIRS += doc
15
15
  endif
16
16
 
17
- EXTRA_DIST = LICENSE ChangeLog.v1 ChangeLog.libgcj \
18
- ChangeLog.libffi ChangeLog.libffi-3.1 \
17
+ EXTRA_DIST = LICENSE ChangeLog.old \
19
18
  m4/libtool.m4 m4/lt~obsolete.m4 \
20
19
  m4/ltoptions.m4 m4/ltsugar.m4 m4/ltversion.m4 \
21
20
  m4/ltversion.m4 src/debug.c msvcc.sh \
22
21
  generate-darwin-source-and-headers.py \
23
22
  libffi.xcodeproj/project.pbxproj \
24
23
  libtool-ldflags libtool-version configure.host README.md \
25
- libffi.map.in LICENSE-BUILDTOOLS msvc_build make_sunver.pl
24
+ libffi.map.in LICENSE-BUILDTOOLS msvc_build make_sunver.pl
26
25
 
27
26
  # local.exp is generated by configure
28
27
  DISTCLEANFILES = local.exp
@@ -145,7 +144,8 @@ endif
145
144
  libffi_version_info = -version-info `grep -v '^\#' $(srcdir)/libtool-version`
146
145
 
147
146
  libffi.map: $(top_srcdir)/libffi.map.in
148
- $(COMPILE) -D$(TARGET) -E -x assembler-with-cpp -o $@ $<
147
+ $(COMPILE) -D$(TARGET) -DGENERATE_LIBFFI_MAP \
148
+ -E -x assembler-with-cpp -o $@ $<
149
149
 
150
150
  libffi_la_LDFLAGS = -no-undefined $(libffi_version_info) $(libffi_version_script) $(LTLDFLAGS) $(AM_LTLDFLAGS)
151
151
  libffi_la_DEPENDENCIES = $(libffi_la_LIBADD) $(libffi_version_dep)
@@ -154,5 +154,7 @@ AM_CPPFLAGS = -I. -I$(top_srcdir)/include -Iinclude -I$(top_srcdir)/src
154
154
  AM_CCASFLAGS = $(AM_CPPFLAGS)
155
155
 
156
156
  dist-hook:
157
+ d=`(cd $(distdir); pwd)`; (cd doc; make pdf; cp *.pdf $$d/doc)
157
158
  if [ -d $(top_srcdir)/.git ] ; then (cd $(top_srcdir); git log --no-decorate) ; else echo 'See git log for history.' ; fi > $(distdir)/ChangeLog
158
159
  s=`awk '/was released on/{ print NR; exit}' $(top_srcdir)/README.md`; tail -n +$$(($$s-1)) $(top_srcdir)/README.md > $(distdir)/README.md
160
+
@@ -4,7 +4,7 @@ Status
4
4
  [![Build Status](https://travis-ci.org/libffi/libffi.svg?branch=master)](https://travis-ci.org/libffi/libffi)
5
5
  [![Build status](https://ci.appveyor.com/api/projects/status/8lko9vagbx4w2kxq?svg=true)](https://ci.appveyor.com/project/atgreen/libffi)
6
6
 
7
- libffi-3.3-rc2 was released on November 2, 2019. Check the libffi web
7
+ libffi-3.4 was released on TBD. Check the libffi web
8
8
  page for updates: <URL:http://sourceware.org/libffi/>.
9
9
 
10
10
 
@@ -101,7 +101,6 @@ tested:
101
101
  | X86 | Interix | GCC |
102
102
  | X86 | kFreeBSD | GCC |
103
103
  | X86 | Linux | GCC |
104
- | X86 | Mac OSX | GCC |
105
104
  | X86 | OpenBSD | GCC |
106
105
  | X86 | OS/2 | GCC |
107
106
  | X86 | Solaris | GCC |
@@ -197,14 +196,23 @@ History
197
196
 
198
197
  See the git log for details at http://github.com/libffi/libffi.
199
198
 
200
- 3.3 TBD
199
+ 3.4 TBD
200
+ Add support for Intel Control-flow Enforcement Technology (CET).
201
+ Add support for ARM Pointer Authentication (PA).
202
+ Fix 32-bit PPC regression.
203
+ Fix MIPS soft-float problem.
204
+
205
+ 3.3 Nov-23-19
201
206
  Add RISC-V support.
202
207
  New API in support of GO closures.
208
+ Add IEEE754 binary128 long double support for 64-bit Power
203
209
  Default to Microsoft's 64 bit long double ABI with Visual C++.
204
210
  GNU compiler uses 80 bits (128 in memory) FFI_GNUW64 ABI.
205
- Many new tests cases and bug fixes.
206
- Add windows on arm64 (WOA) support.
207
- Add Windows 32-bit arm support.
211
+ Add Windows on ARM64 (WOA) support.
212
+ Add Windows 32-bit ARM support.
213
+ Raw java (gcj) API deprecated.
214
+ Add pre-built PDF documentation to source distribution.
215
+ Many new test cases and bug fixes.
208
216
 
209
217
  3.2.1 Nov-12-14
210
218
  Build fix for non-iOS AArch64 targets.
@@ -421,7 +429,9 @@ developers:
421
429
 
422
430
  aarch64 Marcus Shawcroft, James Greenhalgh
423
431
  alpha Richard Henderson
432
+ arc Hackers at Synopsis
424
433
  arm Raffaele Sena
434
+ avr32 Bradley Smith
425
435
  blackfin Alexandre Keunecke I. de Mendonca
426
436
  cris Simon Posnjak, Hans-Peter Nilsson
427
437
  frv Anthony Green
@@ -429,6 +439,7 @@ developers:
429
439
  m32r Kazuhiro Inaoka
430
440
  m68k Andreas Schwab
431
441
  m88k Miod Vallat
442
+ metag Hackers at Imagination Technologies
432
443
  microblaze Nathan Rossi
433
444
  mips Anthony Green, Casey Marshall
434
445
  mips64 David Daney
@@ -439,6 +450,7 @@ developers:
439
450
  powerpc Geoffrey Keating, Andreas Tobler,
440
451
  David Edelsohn, John Hornkvist
441
452
  powerpc64 Jakub Jelinek
453
+ riscv Michael Knyszek, Andrew Waterman, Stef O'Rear
442
454
  s390 Gerhard Tonn, Ulrich Weigand
443
455
  sh Kaz Kojima
444
456
  sh64 Kaz Kojima
@@ -2,7 +2,7 @@ dnl Process this with autoconf to create configure
2
2
 
3
3
  AC_PREREQ(2.68)
4
4
 
5
- AC_INIT([libffi], [3.3-rc2], [http://github.com/libffi/libffi/issues])
5
+ AC_INIT([libffi], [3.3], [http://github.com/libffi/libffi/issues])
6
6
  AC_CONFIG_HEADERS([fficonfig.h])
7
7
 
8
8
  AC_CANONICAL_SYSTEM
@@ -176,6 +176,28 @@ case "$TARGET" in
176
176
  ;;
177
177
  esac
178
178
 
179
+ AC_CACHE_CHECK([whether compiler supports pointer authentication],
180
+ libffi_cv_as_ptrauth, [
181
+ libffi_cv_as_ptrauth=unknown
182
+ AC_TRY_COMPILE(,[
183
+ #ifdef __clang__
184
+ # if __has_feature(ptrauth_calls)
185
+ # define HAVE_PTRAUTH 1
186
+ # endif
187
+ #endif
188
+
189
+ #ifndef HAVE_PTRAUTH
190
+ # error Pointer authentication not supported
191
+ #endif
192
+ ],
193
+ [libffi_cv_as_ptrauth=yes],
194
+ [libffi_cv_as_ptrauth=no])
195
+ ])
196
+ if test "x$libffi_cv_as_ptrauth" = xyes; then
197
+ AC_DEFINE(HAVE_PTRAUTH, 1,
198
+ [Define if your compiler supports pointer authentication.])
199
+ fi
200
+
179
201
  # On PaX enable kernels that have MPROTECT enable we can't use PROT_EXEC.
180
202
  AC_ARG_ENABLE(pax_emutramp,
181
203
  [ --enable-pax_emutramp enable pax emulated trampolines, for we can't use PROT_EXEC],
@@ -240,17 +262,11 @@ fi
240
262
  if test "x$GCC" = "xyes"; then
241
263
  AC_CACHE_CHECK([whether .eh_frame section should be read-only],
242
264
  libffi_cv_ro_eh_frame, [
243
- libffi_cv_ro_eh_frame=no
265
+ libffi_cv_ro_eh_frame=yes
244
266
  echo 'extern void foo (void); void bar (void) { foo (); foo (); }' > conftest.c
245
267
  if $CC $CFLAGS -c -fpic -fexceptions -o conftest.o conftest.c > /dev/null 2>&1; then
246
- objdump -h conftest.o > conftest.dump 2>&1
247
- libffi_eh_frame_line=`grep -n eh_frame conftest.dump | cut -d: -f 1`
248
- if test "x$libffi_eh_frame_line" != "x"; then
249
- libffi_test_line=`expr $libffi_eh_frame_line + 1`p
250
- sed -n $libffi_test_line conftest.dump > conftest.line
251
- if grep READONLY conftest.line > /dev/null; then
252
- libffi_cv_ro_eh_frame=yes
253
- fi
268
+ if readelf -WS conftest.o | grep -q -n 'eh_frame .* WA'; then
269
+ libffi_cv_ro_eh_frame=no
254
270
  fi
255
271
  fi
256
272
  rm -f conftest.*
@@ -74,7 +74,7 @@ case "${host}" in
74
74
  TARGET=X86_FREEBSD; TARGETDIR=x86
75
75
  ;;
76
76
 
77
- i?86-*-cygwin* | i?86-*-mingw* | i?86-*-os2* | i?86-*-interix* \
77
+ i?86-*-cygwin* | i?86-*-mingw* | i?86-*-win* | i?86-*-os2* | i?86-*-interix* \
78
78
  | x86_64-*-cygwin* | x86_64-*-mingw* | x86_64-*-win* )
79
79
  TARGETDIR=x86
80
80
  if test $ac_cv_sizeof_size_t = 4; then
@@ -178,7 +178,7 @@ case "${host}" in
178
178
  SOURCES="ffi.c sysv.S"
179
179
  ;;
180
180
 
181
- or1k*-linux*)
181
+ or1k*-*-*)
182
182
  TARGET=OR1K; TARGETDIR=or1k
183
183
  SOURCES="ffi.c sysv.S"
184
184
  ;;
@@ -190,6 +190,9 @@ case "${host}" in
190
190
  powerpc-*-amigaos*)
191
191
  TARGET=POWERPC; TARGETDIR=powerpc
192
192
  ;;
193
+ powerpc-*-eabi*)
194
+ TARGET=POWERPC; TARGETDIR=powerpc
195
+ ;;
193
196
  powerpc-*-beos*)
194
197
  TARGET=POWERPC; TARGETDIR=powerpc
195
198
  ;;
@@ -143,7 +143,7 @@ def build_target(platform, platform_headers):
143
143
  mkdir_p(build_dir)
144
144
  env = dict(CC=xcrun_cmd('clang'),
145
145
  LD=xcrun_cmd('ld'),
146
- CFLAGS='%s' % (platform.version_min))
146
+ CFLAGS='%s -fembed-bitcode' % (platform.version_min))
147
147
  working_dir = os.getcwd()
148
148
  try:
149
149
  os.chdir(build_dir)
@@ -173,7 +173,6 @@ def generate_source_and_headers(generate_osx=True, generate_ios=True):
173
173
  copy_src_platform_files(device_platform)
174
174
  copy_src_platform_files(device64_platform)
175
175
  if generate_osx:
176
- copy_src_platform_files(desktop32_platform)
177
176
  copy_src_platform_files(desktop64_platform)
178
177
 
179
178
  platform_headers = collections.defaultdict(set)
@@ -184,7 +183,6 @@ def generate_source_and_headers(generate_osx=True, generate_ios=True):
184
183
  build_target(device_platform, platform_headers)
185
184
  build_target(device64_platform, platform_headers)
186
185
  if generate_osx:
187
- build_target(desktop32_platform, platform_headers)
188
186
  build_target(desktop64_platform, platform_headers)
189
187
 
190
188
  mkdir_p('darwin_common/include')
@@ -1,5 +1,5 @@
1
1
  /* -----------------------------------------------------------------*-C-*-
2
- libffi @VERSION@ - Copyright (c) 2011, 2014 Anthony Green
2
+ libffi @VERSION@ - Copyright (c) 2011, 2014, 2019 Anthony Green
3
3
  - Copyright (c) 1996-2003, 2007, 2008 Red Hat, Inc.
4
4
 
5
5
  Permission is hereby granted, free of charge, to any person
@@ -288,15 +288,15 @@ FFI_API
288
288
  void ffi_java_raw_call (ffi_cif *cif,
289
289
  void (*fn)(void),
290
290
  void *rvalue,
291
- ffi_java_raw *avalue);
291
+ ffi_java_raw *avalue) __attribute__((deprecated));
292
292
  #endif
293
293
 
294
294
  FFI_API
295
- void ffi_java_ptrarray_to_raw (ffi_cif *cif, void **args, ffi_java_raw *raw);
295
+ void ffi_java_ptrarray_to_raw (ffi_cif *cif, void **args, ffi_java_raw *raw) __attribute__((deprecated));
296
296
  FFI_API
297
- void ffi_java_raw_to_ptrarray (ffi_cif *cif, ffi_java_raw *raw, void **args);
297
+ void ffi_java_raw_to_ptrarray (ffi_cif *cif, ffi_java_raw *raw, void **args) __attribute__((deprecated));
298
298
  FFI_API
299
- size_t ffi_java_raw_size (ffi_cif *cif);
299
+ size_t ffi_java_raw_size (ffi_cif *cif) __attribute__((deprecated));
300
300
 
301
301
  /* ---- Definitions for closures ----------------------------------------- */
302
302
 
@@ -330,6 +330,14 @@ typedef struct {
330
330
  FFI_API void *ffi_closure_alloc (size_t size, void **code);
331
331
  FFI_API void ffi_closure_free (void *);
332
332
 
333
+ #if defined(PA_LINUX) || defined(PA_HPUX)
334
+ #define FFI_CLOSURE_PTR(X) ((void *)((unsigned int)(X) | 2))
335
+ #define FFI_RESTORE_PTR(X) ((void *)((unsigned int)(X) & ~3))
336
+ #else
337
+ #define FFI_CLOSURE_PTR(X) (X)
338
+ #define FFI_RESTORE_PTR(X) (X)
339
+ #endif
340
+
333
341
  FFI_API ffi_status
334
342
  ffi_prep_closure (ffi_closure*,
335
343
  ffi_cif *,
@@ -421,14 +429,14 @@ FFI_API ffi_status
421
429
  ffi_prep_java_raw_closure (ffi_java_raw_closure*,
422
430
  ffi_cif *cif,
423
431
  void (*fun)(ffi_cif*,void*,ffi_java_raw*,void*),
424
- void *user_data);
432
+ void *user_data) __attribute__((deprecated));
425
433
 
426
434
  FFI_API ffi_status
427
435
  ffi_prep_java_raw_closure_loc (ffi_java_raw_closure*,
428
436
  ffi_cif *cif,
429
437
  void (*fun)(ffi_cif*,void*,ffi_java_raw*,void*),
430
438
  void *user_data,
431
- void *codeloc);
439
+ void *codeloc) __attribute__((deprecated));
432
440
  #endif
433
441
 
434
442
  #endif /* FFI_CLOSURES */
@@ -6,7 +6,7 @@
6
6
  /* These version numbers correspond to the libtool-version abi numbers,
7
7
  not to the libffi release numbers. */
8
8
 
9
- LIBFFI_BASE_7.0 {
9
+ LIBFFI_BASE_8.0 {
10
10
  global:
11
11
  /* Exported data variables. */
12
12
  ffi_type_void;
@@ -38,27 +38,23 @@ LIBFFI_BASE_7.0 {
38
38
  ffi_java_raw_to_ptrarray;
39
39
  ffi_java_raw_size;
40
40
 
41
+ ffi_get_struct_offsets;
41
42
  local:
42
43
  *;
43
44
  };
44
45
 
45
- LIBFFI_BASE_7.1 {
46
- global:
47
- ffi_get_struct_offsets;
48
- } LIBFFI_BASE_7.0;
49
-
50
46
  #ifdef FFI_TARGET_HAS_COMPLEX_TYPE
51
- LIBFFI_COMPLEX_7.0 {
47
+ LIBFFI_COMPLEX_8.0 {
52
48
  global:
53
49
  /* Exported data variables. */
54
50
  ffi_type_complex_float;
55
51
  ffi_type_complex_double;
56
52
  ffi_type_complex_longdouble;
57
- } LIBFFI_BASE_7.0;
53
+ } LIBFFI_BASE_8.0;
58
54
  #endif
59
55
 
60
56
  #if FFI_CLOSURES
61
- LIBFFI_CLOSURE_7.0 {
57
+ LIBFFI_CLOSURE_8.0 {
62
58
  global:
63
59
  ffi_closure_alloc;
64
60
  ffi_closure_free;
@@ -68,13 +64,13 @@ LIBFFI_CLOSURE_7.0 {
68
64
  ffi_prep_raw_closure_loc;
69
65
  ffi_prep_java_raw_closure;
70
66
  ffi_prep_java_raw_closure_loc;
71
- } LIBFFI_BASE_7.0;
67
+ } LIBFFI_BASE_8.0;
72
68
  #endif
73
69
 
74
70
  #if FFI_GO_CLOSURES
75
- LIBFFI_GO_CLOSURE_7.0 {
71
+ LIBFFI_GO_CLOSURE_8.0 {
76
72
  global:
77
73
  ffi_call_go;
78
74
  ffi_prep_go_closure;
79
- } LIBFFI_CLOSURE_7.0;
75
+ } LIBFFI_CLOSURE_8.0;
80
76
  #endif
@@ -9,7 +9,6 @@
9
9
  /* Begin PBXBuildFile section */
10
10
  43B5D3F81D35473200D1E1FD /* ffiw64_x86_64.c in Sources */ = {isa = PBXBuildFile; fileRef = 43B5D3F71D35473200D1E1FD /* ffiw64_x86_64.c */; };
11
11
  43B5D3FA1D3547CE00D1E1FD /* win64_x86_64.S in Sources */ = {isa = PBXBuildFile; fileRef = 43B5D3F91D3547CE00D1E1FD /* win64_x86_64.S */; };
12
- 43E9A5C71D352C1500926A8F /* sysv_i386.S in Sources */ = {isa = PBXBuildFile; fileRef = 43E9A5C51D352C1500926A8F /* sysv_i386.S */; };
13
12
  43E9A5C81D352C1500926A8F /* unix64_x86_64.S in Sources */ = {isa = PBXBuildFile; fileRef = 43E9A5C61D352C1500926A8F /* unix64_x86_64.S */; };
14
13
  DBFA714A187F1D8600A76262 /* ffi.h in Headers */ = {isa = PBXBuildFile; fileRef = DBFA713E187F1D8600A76262 /* ffi.h */; };
15
14
  DBFA714B187F1D8600A76262 /* ffi_common.h in Headers */ = {isa = PBXBuildFile; fileRef = DBFA713F187F1D8600A76262 /* ffi_common.h */; };
@@ -28,26 +27,18 @@
28
27
  DBFA7179187F1D9B00A76262 /* ffi_armv7.c in Sources */ = {isa = PBXBuildFile; fileRef = DBFA716F187F1D9B00A76262 /* ffi_armv7.c */; };
29
28
  DBFA717A187F1D9B00A76262 /* sysv_armv7.S in Sources */ = {isa = PBXBuildFile; fileRef = DBFA7170187F1D9B00A76262 /* sysv_armv7.S */; };
30
29
  DBFA717E187F1D9B00A76262 /* ffi64_x86_64.c in Sources */ = {isa = PBXBuildFile; fileRef = DBFA7175187F1D9B00A76262 /* ffi64_x86_64.c */; };
31
- DBFA717F187F1D9B00A76262 /* ffi_i386.c in Sources */ = {isa = PBXBuildFile; fileRef = DBFA7176187F1D9B00A76262 /* ffi_i386.c */; };
32
- DBFA718E187F1DA100A76262 /* ffi_i386.h in Headers */ = {isa = PBXBuildFile; fileRef = DBFA7182187F1DA100A76262 /* ffi_i386.h */; };
33
30
  DBFA718F187F1DA100A76262 /* ffi_x86_64.h in Headers */ = {isa = PBXBuildFile; fileRef = DBFA7183187F1DA100A76262 /* ffi_x86_64.h */; };
34
- DBFA7190187F1DA100A76262 /* fficonfig_i386.h in Headers */ = {isa = PBXBuildFile; fileRef = DBFA7184187F1DA100A76262 /* fficonfig_i386.h */; };
35
31
  DBFA7191187F1DA100A76262 /* fficonfig_x86_64.h in Headers */ = {isa = PBXBuildFile; fileRef = DBFA7185187F1DA100A76262 /* fficonfig_x86_64.h */; };
36
- DBFA7192187F1DA100A76262 /* ffitarget_i386.h in Headers */ = {isa = PBXBuildFile; fileRef = DBFA7186187F1DA100A76262 /* ffitarget_i386.h */; };
37
32
  DBFA7193187F1DA100A76262 /* ffitarget_x86_64.h in Headers */ = {isa = PBXBuildFile; fileRef = DBFA7187187F1DA100A76262 /* ffitarget_x86_64.h */; };
38
33
  DBFA7194187F1DA100A76262 /* unix64_x86_64.S in Sources */ = {isa = PBXBuildFile; fileRef = DBFA718A187F1DA100A76262 /* unix64_x86_64.S */; };
39
- DBFA7195187F1DA100A76262 /* sysv_i386.S in Sources */ = {isa = PBXBuildFile; fileRef = DBFA718B187F1DA100A76262 /* sysv_i386.S */; };
40
34
  DBFA7196187F1DA100A76262 /* ffi64_x86_64.c in Sources */ = {isa = PBXBuildFile; fileRef = DBFA718C187F1DA100A76262 /* ffi64_x86_64.c */; };
41
- DBFA7197187F1DA100A76262 /* ffi_i386.c in Sources */ = {isa = PBXBuildFile; fileRef = DBFA718D187F1DA100A76262 /* ffi_i386.c */; };
42
35
  FDB52FB31F6144FA00AA92E6 /* unix64_x86_64.S in Sources */ = {isa = PBXBuildFile; fileRef = 43E9A5C61D352C1500926A8F /* unix64_x86_64.S */; };
43
- FDB52FB41F6144FA00AA92E6 /* sysv_i386.S in Sources */ = {isa = PBXBuildFile; fileRef = 43E9A5C51D352C1500926A8F /* sysv_i386.S */; };
44
36
  FDB52FB51F6144FA00AA92E6 /* ffi64_x86_64.c in Sources */ = {isa = PBXBuildFile; fileRef = DBFA7175187F1D9B00A76262 /* ffi64_x86_64.c */; };
45
37
  FDB52FB61F6144FA00AA92E6 /* ffi_armv7.c in Sources */ = {isa = PBXBuildFile; fileRef = DBFA716F187F1D9B00A76262 /* ffi_armv7.c */; };
46
38
  FDB52FB71F6144FA00AA92E6 /* closures.c in Sources */ = {isa = PBXBuildFile; fileRef = DBFA7143187F1D8600A76262 /* closures.c */; };
47
39
  FDB52FB81F6144FA00AA92E6 /* sysv_armv7.S in Sources */ = {isa = PBXBuildFile; fileRef = DBFA7170187F1D9B00A76262 /* sysv_armv7.S */; };
48
40
  FDB52FB91F6144FA00AA92E6 /* ffiw64_x86_64.c in Sources */ = {isa = PBXBuildFile; fileRef = 43B5D3F71D35473200D1E1FD /* ffiw64_x86_64.c */; };
49
41
  FDB52FBA1F6144FA00AA92E6 /* prep_cif.c in Sources */ = {isa = PBXBuildFile; fileRef = DBFA7147187F1D8600A76262 /* prep_cif.c */; };
50
- FDB52FBB1F6144FA00AA92E6 /* ffi_i386.c in Sources */ = {isa = PBXBuildFile; fileRef = DBFA7176187F1D9B00A76262 /* ffi_i386.c */; };
51
42
  FDB52FBC1F6144FA00AA92E6 /* raw_api.c in Sources */ = {isa = PBXBuildFile; fileRef = DBFA7148187F1D8600A76262 /* raw_api.c */; };
52
43
  FDB52FBD1F6144FA00AA92E6 /* sysv_arm64.S in Sources */ = {isa = PBXBuildFile; fileRef = DBFA716D187F1D9B00A76262 /* sysv_arm64.S */; };
53
44
  FDB52FBE1F6144FA00AA92E6 /* types.c in Sources */ = {isa = PBXBuildFile; fileRef = DBFA7149187F1D8600A76262 /* types.c */; };
@@ -56,7 +47,6 @@
56
47
  FDB52FD01F614A8B00AA92E6 /* ffi.h in CopyFiles */ = {isa = PBXBuildFile; fileRef = DBFA713E187F1D8600A76262 /* ffi.h */; };
57
48
  FDB52FD11F614AA700AA92E6 /* ffi_arm64.h in CopyFiles */ = {isa = PBXBuildFile; fileRef = DBFA715E187F1D9B00A76262 /* ffi_arm64.h */; };
58
49
  FDB52FD21F614AAB00AA92E6 /* ffi_armv7.h in CopyFiles */ = {isa = PBXBuildFile; fileRef = DBFA715F187F1D9B00A76262 /* ffi_armv7.h */; };
59
- FDB52FD31F614AB000AA92E6 /* ffi_i386.h in CopyFiles */ = {isa = PBXBuildFile; fileRef = DBFA7160187F1D9B00A76262 /* ffi_i386.h */; };
60
50
  FDB52FD41F614AB500AA92E6 /* ffi_x86_64.h in CopyFiles */ = {isa = PBXBuildFile; fileRef = DBFA7161187F1D9B00A76262 /* ffi_x86_64.h */; };
61
51
  FDB52FD51F614AE200AA92E6 /* ffi.h in CopyFiles */ = {isa = PBXBuildFile; fileRef = DBFA713E187F1D8600A76262 /* ffi.h */; };
62
52
  FDB52FD61F614AEA00AA92E6 /* ffi_arm64.h in CopyFiles */ = {isa = PBXBuildFile; fileRef = DBFA715E187F1D9B00A76262 /* ffi_arm64.h */; };
@@ -64,7 +54,6 @@
64
54
  FDB52FD81F614B8700AA92E6 /* ffitarget.h in CopyFiles */ = {isa = PBXBuildFile; fileRef = DBFA7141187F1D8600A76262 /* ffitarget.h */; };
65
55
  FDB52FD91F614B8E00AA92E6 /* ffitarget_arm64.h in CopyFiles */ = {isa = PBXBuildFile; fileRef = DBFA7166187F1D9B00A76262 /* ffitarget_arm64.h */; };
66
56
  FDB52FDA1F614B9300AA92E6 /* ffitarget_armv7.h in CopyFiles */ = {isa = PBXBuildFile; fileRef = DBFA7167187F1D9B00A76262 /* ffitarget_armv7.h */; };
67
- FDB52FDB1F614B9700AA92E6 /* ffitarget_i386.h in CopyFiles */ = {isa = PBXBuildFile; fileRef = DBFA7168187F1D9B00A76262 /* ffitarget_i386.h */; };
68
57
  FDB52FDD1F614BA900AA92E6 /* ffitarget_x86_64.h in CopyFiles */ = {isa = PBXBuildFile; fileRef = DBFA7169187F1D9B00A76262 /* ffitarget_x86_64.h */; };
69
58
  FDB52FDE1F6155E300AA92E6 /* ffitarget.h in CopyFiles */ = {isa = PBXBuildFile; fileRef = DBFA7141187F1D8600A76262 /* ffitarget.h */; };
70
59
  FDB52FDF1F6155EA00AA92E6 /* ffitarget_arm64.h in CopyFiles */ = {isa = PBXBuildFile; fileRef = DBFA7166187F1D9B00A76262 /* ffitarget_arm64.h */; };
@@ -76,9 +65,7 @@
76
65
  FDDB2F411F5D66E200EF414E /* ffiw64_x86_64.c in Sources */ = {isa = PBXBuildFile; fileRef = FDDB2F3F1F5D666900EF414E /* ffiw64_x86_64.c */; };
77
66
  FDDB2F461F5D691E00EF414E /* win64_x86_64.S in Sources */ = {isa = PBXBuildFile; fileRef = FDDB2F441F5D68C900EF414E /* win64_x86_64.S */; };
78
67
  FDDB2F4A1F5D846400EF414E /* ffi64_x86_64.c in Sources */ = {isa = PBXBuildFile; fileRef = DBFA718C187F1DA100A76262 /* ffi64_x86_64.c */; };
79
- FDDB2F4B1F5D846400EF414E /* sysv_i386.S in Sources */ = {isa = PBXBuildFile; fileRef = DBFA718B187F1DA100A76262 /* sysv_i386.S */; };
80
68
  FDDB2F4C1F5D846400EF414E /* prep_cif.c in Sources */ = {isa = PBXBuildFile; fileRef = DBFA7147187F1D8600A76262 /* prep_cif.c */; };
81
- FDDB2F4D1F5D846400EF414E /* ffi_i386.c in Sources */ = {isa = PBXBuildFile; fileRef = DBFA718D187F1DA100A76262 /* ffi_i386.c */; };
82
69
  FDDB2F4E1F5D846400EF414E /* ffiw64_x86_64.c in Sources */ = {isa = PBXBuildFile; fileRef = FDDB2F3F1F5D666900EF414E /* ffiw64_x86_64.c */; };
83
70
  FDDB2F4F1F5D846400EF414E /* types.c in Sources */ = {isa = PBXBuildFile; fileRef = DBFA7149187F1D8600A76262 /* types.c */; };
84
71
  FDDB2F501F5D846400EF414E /* raw_api.c in Sources */ = {isa = PBXBuildFile; fileRef = DBFA7148187F1D8600A76262 /* raw_api.c */; };
@@ -97,12 +84,10 @@
97
84
  FDB52FD01F614A8B00AA92E6 /* ffi.h in CopyFiles */,
98
85
  FDB52FD11F614AA700AA92E6 /* ffi_arm64.h in CopyFiles */,
99
86
  FDB52FD21F614AAB00AA92E6 /* ffi_armv7.h in CopyFiles */,
100
- FDB52FD31F614AB000AA92E6 /* ffi_i386.h in CopyFiles */,
101
87
  FDB52FD41F614AB500AA92E6 /* ffi_x86_64.h in CopyFiles */,
102
88
  FDB52FD81F614B8700AA92E6 /* ffitarget.h in CopyFiles */,
103
89
  FDB52FD91F614B8E00AA92E6 /* ffitarget_arm64.h in CopyFiles */,
104
90
  FDB52FDA1F614B9300AA92E6 /* ffitarget_armv7.h in CopyFiles */,
105
- FDB52FDB1F614B9700AA92E6 /* ffitarget_i386.h in CopyFiles */,
106
91
  FDB52FDD1F614BA900AA92E6 /* ffitarget_x86_64.h in CopyFiles */,
107
92
  );
108
93
  runOnlyForDeploymentPostprocessing = 0;
@@ -140,7 +125,6 @@
140
125
  /* Begin PBXFileReference section */
141
126
  43B5D3F71D35473200D1E1FD /* ffiw64_x86_64.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = ffiw64_x86_64.c; sourceTree = "<group>"; };
142
127
  43B5D3F91D3547CE00D1E1FD /* win64_x86_64.S */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.asm; path = win64_x86_64.S; sourceTree = "<group>"; };
143
- 43E9A5C51D352C1500926A8F /* sysv_i386.S */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.asm; path = sysv_i386.S; sourceTree = "<group>"; };
144
128
  43E9A5C61D352C1500926A8F /* unix64_x86_64.S */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.asm; path = unix64_x86_64.S; sourceTree = "<group>"; };
145
129
  43E9A5DA1D35373600926A8F /* internal.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = internal.h; sourceTree = "<group>"; };
146
130
  43E9A5DB1D35374400926A8F /* internal.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = internal.h; sourceTree = "<group>"; };
@@ -159,32 +143,23 @@
159
143
  DBFA7149187F1D8600A76262 /* types.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = types.c; sourceTree = "<group>"; };
160
144
  DBFA715E187F1D9B00A76262 /* ffi_arm64.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = ffi_arm64.h; sourceTree = "<group>"; };
161
145
  DBFA715F187F1D9B00A76262 /* ffi_armv7.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = ffi_armv7.h; sourceTree = "<group>"; };
162
- DBFA7160187F1D9B00A76262 /* ffi_i386.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = ffi_i386.h; sourceTree = "<group>"; };
163
146
  DBFA7161187F1D9B00A76262 /* ffi_x86_64.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = ffi_x86_64.h; sourceTree = "<group>"; };
164
147
  DBFA7162187F1D9B00A76262 /* fficonfig_arm64.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = fficonfig_arm64.h; sourceTree = "<group>"; };
165
148
  DBFA7163187F1D9B00A76262 /* fficonfig_armv7.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = fficonfig_armv7.h; sourceTree = "<group>"; };
166
- DBFA7164187F1D9B00A76262 /* fficonfig_i386.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = fficonfig_i386.h; sourceTree = "<group>"; };
167
149
  DBFA7165187F1D9B00A76262 /* fficonfig_x86_64.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = fficonfig_x86_64.h; sourceTree = "<group>"; };
168
150
  DBFA7166187F1D9B00A76262 /* ffitarget_arm64.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = ffitarget_arm64.h; sourceTree = "<group>"; };
169
151
  DBFA7167187F1D9B00A76262 /* ffitarget_armv7.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = ffitarget_armv7.h; sourceTree = "<group>"; };
170
- DBFA7168187F1D9B00A76262 /* ffitarget_i386.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = ffitarget_i386.h; sourceTree = "<group>"; };
171
152
  DBFA7169187F1D9B00A76262 /* ffitarget_x86_64.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = ffitarget_x86_64.h; sourceTree = "<group>"; };
172
153
  DBFA716C187F1D9B00A76262 /* ffi_arm64.c */ = {isa = PBXFileReference; fileEncoding = 4; indentWidth = 2; lastKnownFileType = sourcecode.c.c; path = ffi_arm64.c; sourceTree = "<group>"; };
173
154
  DBFA716D187F1D9B00A76262 /* sysv_arm64.S */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.asm; path = sysv_arm64.S; sourceTree = "<group>"; };
174
155
  DBFA716F187F1D9B00A76262 /* ffi_armv7.c */ = {isa = PBXFileReference; fileEncoding = 4; indentWidth = 2; lastKnownFileType = sourcecode.c.c; path = ffi_armv7.c; sourceTree = "<group>"; };
175
156
  DBFA7170187F1D9B00A76262 /* sysv_armv7.S */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.asm; path = sysv_armv7.S; sourceTree = "<group>"; };
176
157
  DBFA7175187F1D9B00A76262 /* ffi64_x86_64.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = ffi64_x86_64.c; sourceTree = "<group>"; };
177
- DBFA7176187F1D9B00A76262 /* ffi_i386.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = ffi_i386.c; sourceTree = "<group>"; };
178
- DBFA7182187F1DA100A76262 /* ffi_i386.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = ffi_i386.h; sourceTree = "<group>"; };
179
158
  DBFA7183187F1DA100A76262 /* ffi_x86_64.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = ffi_x86_64.h; sourceTree = "<group>"; };
180
- DBFA7184187F1DA100A76262 /* fficonfig_i386.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = fficonfig_i386.h; sourceTree = "<group>"; };
181
159
  DBFA7185187F1DA100A76262 /* fficonfig_x86_64.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = fficonfig_x86_64.h; sourceTree = "<group>"; };
182
- DBFA7186187F1DA100A76262 /* ffitarget_i386.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = ffitarget_i386.h; sourceTree = "<group>"; };
183
160
  DBFA7187187F1DA100A76262 /* ffitarget_x86_64.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = ffitarget_x86_64.h; sourceTree = "<group>"; };
184
161
  DBFA718A187F1DA100A76262 /* unix64_x86_64.S */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.asm; path = unix64_x86_64.S; sourceTree = "<group>"; };
185
- DBFA718B187F1DA100A76262 /* sysv_i386.S */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.asm; path = sysv_i386.S; sourceTree = "<group>"; };
186
162
  DBFA718C187F1DA100A76262 /* ffi64_x86_64.c */ = {isa = PBXFileReference; fileEncoding = 4; indentWidth = 2; lastKnownFileType = sourcecode.c.c; path = ffi64_x86_64.c; sourceTree = "<group>"; };
187
- DBFA718D187F1DA100A76262 /* ffi_i386.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = ffi_i386.c; sourceTree = "<group>"; };
188
163
  FDB52FC51F6144FA00AA92E6 /* libffi.a */ = {isa = PBXFileReference; explicitFileType = archive.ar; includeInIndex = 0; path = libffi.a; sourceTree = BUILT_PRODUCTS_DIR; };
189
164
  FDDB2F3E1F5D61BC00EF414E /* asmnames.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = asmnames.h; sourceTree = "<group>"; };
190
165
  FDDB2F3F1F5D666900EF414E /* ffiw64_x86_64.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = ffiw64_x86_64.c; sourceTree = "<group>"; };
@@ -262,15 +237,12 @@
262
237
  children = (
263
238
  DBFA715E187F1D9B00A76262 /* ffi_arm64.h */,
264
239
  DBFA715F187F1D9B00A76262 /* ffi_armv7.h */,
265
- DBFA7160187F1D9B00A76262 /* ffi_i386.h */,
266
240
  DBFA7161187F1D9B00A76262 /* ffi_x86_64.h */,
267
241
  DBFA7162187F1D9B00A76262 /* fficonfig_arm64.h */,
268
242
  DBFA7163187F1D9B00A76262 /* fficonfig_armv7.h */,
269
- DBFA7164187F1D9B00A76262 /* fficonfig_i386.h */,
270
243
  DBFA7165187F1D9B00A76262 /* fficonfig_x86_64.h */,
271
244
  DBFA7166187F1D9B00A76262 /* ffitarget_arm64.h */,
272
245
  DBFA7167187F1D9B00A76262 /* ffitarget_armv7.h */,
273
- DBFA7168187F1D9B00A76262 /* ffitarget_i386.h */,
274
246
  DBFA7169187F1D9B00A76262 /* ffitarget_x86_64.h */,
275
247
  );
276
248
  path = include;
@@ -313,8 +285,6 @@
313
285
  43E9A5DD1D35375400926A8F /* internal64.h */,
314
286
  DBFA7175187F1D9B00A76262 /* ffi64_x86_64.c */,
315
287
  43B5D3F71D35473200D1E1FD /* ffiw64_x86_64.c */,
316
- DBFA7176187F1D9B00A76262 /* ffi_i386.c */,
317
- 43E9A5C51D352C1500926A8F /* sysv_i386.S */,
318
288
  43E9A5C61D352C1500926A8F /* unix64_x86_64.S */,
319
289
  43B5D3F91D3547CE00D1E1FD /* win64_x86_64.S */,
320
290
  );
@@ -333,11 +303,8 @@
333
303
  DBFA7181187F1DA100A76262 /* include */ = {
334
304
  isa = PBXGroup;
335
305
  children = (
336
- DBFA7182187F1DA100A76262 /* ffi_i386.h */,
337
306
  DBFA7183187F1DA100A76262 /* ffi_x86_64.h */,
338
- DBFA7184187F1DA100A76262 /* fficonfig_i386.h */,
339
307
  DBFA7185187F1DA100A76262 /* fficonfig_x86_64.h */,
340
- DBFA7186187F1DA100A76262 /* ffitarget_i386.h */,
341
308
  DBFA7187187F1DA100A76262 /* ffitarget_x86_64.h */,
342
309
  );
343
310
  path = include;
@@ -359,8 +326,6 @@
359
326
  FDDB2F3E1F5D61BC00EF414E /* asmnames.h */,
360
327
  DBFA718C187F1DA100A76262 /* ffi64_x86_64.c */,
361
328
  FDDB2F3F1F5D666900EF414E /* ffiw64_x86_64.c */,
362
- DBFA718D187F1DA100A76262 /* ffi_i386.c */,
363
- DBFA718B187F1DA100A76262 /* sysv_i386.S */,
364
329
  DBFA718A187F1DA100A76262 /* unix64_x86_64.S */,
365
330
  FDDB2F441F5D68C900EF414E /* win64_x86_64.S */,
366
331
  );
@@ -379,11 +344,8 @@
379
344
  DBFA714A187F1D8600A76262 /* ffi.h in Headers */,
380
345
  DBFA718F187F1DA100A76262 /* ffi_x86_64.h in Headers */,
381
346
  DBFA7191187F1DA100A76262 /* fficonfig_x86_64.h in Headers */,
382
- DBFA718E187F1DA100A76262 /* ffi_i386.h in Headers */,
383
- DBFA7190187F1DA100A76262 /* fficonfig_i386.h in Headers */,
384
347
  DBFA714B187F1D8600A76262 /* ffi_common.h in Headers */,
385
348
  DBFA7193187F1DA100A76262 /* ffitarget_x86_64.h in Headers */,
386
- DBFA7192187F1DA100A76262 /* ffitarget_i386.h in Headers */,
387
349
  );
388
350
  runOnlyForDeploymentPostprocessing = 0;
389
351
  };
@@ -549,14 +511,12 @@
549
511
  buildActionMask = 2147483647;
550
512
  files = (
551
513
  43E9A5C81D352C1500926A8F /* unix64_x86_64.S in Sources */,
552
- 43E9A5C71D352C1500926A8F /* sysv_i386.S in Sources */,
553
514
  DBFA717E187F1D9B00A76262 /* ffi64_x86_64.c in Sources */,
554
515
  DBFA7179187F1D9B00A76262 /* ffi_armv7.c in Sources */,
555
516
  DBFA714E187F1D8600A76262 /* closures.c in Sources */,
556
517
  DBFA717A187F1D9B00A76262 /* sysv_armv7.S in Sources */,
557
518
  43B5D3F81D35473200D1E1FD /* ffiw64_x86_64.c in Sources */,
558
519
  DBFA7156187F1D8600A76262 /* prep_cif.c in Sources */,
559
- DBFA717F187F1D9B00A76262 /* ffi_i386.c in Sources */,
560
520
  DBFA7158187F1D8600A76262 /* raw_api.c in Sources */,
561
521
  DBFA7178187F1D9B00A76262 /* sysv_arm64.S in Sources */,
562
522
  DBFA715A187F1D8600A76262 /* types.c in Sources */,
@@ -570,9 +530,7 @@
570
530
  buildActionMask = 2147483647;
571
531
  files = (
572
532
  DBFA7196187F1DA100A76262 /* ffi64_x86_64.c in Sources */,
573
- DBFA7195187F1DA100A76262 /* sysv_i386.S in Sources */,
574
533
  DBFA7157187F1D8600A76262 /* prep_cif.c in Sources */,
575
- DBFA7197187F1DA100A76262 /* ffi_i386.c in Sources */,
576
534
  FDDB2F411F5D66E200EF414E /* ffiw64_x86_64.c in Sources */,
577
535
  DBFA715B187F1D8600A76262 /* types.c in Sources */,
578
536
  DBFA7159187F1D8600A76262 /* raw_api.c in Sources */,
@@ -587,14 +545,12 @@
587
545
  buildActionMask = 2147483647;
588
546
  files = (
589
547
  FDB52FB31F6144FA00AA92E6 /* unix64_x86_64.S in Sources */,
590
- FDB52FB41F6144FA00AA92E6 /* sysv_i386.S in Sources */,
591
548
  FDB52FB51F6144FA00AA92E6 /* ffi64_x86_64.c in Sources */,
592
549
  FDB52FB61F6144FA00AA92E6 /* ffi_armv7.c in Sources */,
593
550
  FDB52FB71F6144FA00AA92E6 /* closures.c in Sources */,
594
551
  FDB52FB81F6144FA00AA92E6 /* sysv_armv7.S in Sources */,
595
552
  FDB52FB91F6144FA00AA92E6 /* ffiw64_x86_64.c in Sources */,
596
553
  FDB52FBA1F6144FA00AA92E6 /* prep_cif.c in Sources */,
597
- FDB52FBB1F6144FA00AA92E6 /* ffi_i386.c in Sources */,
598
554
  FDB52FBC1F6144FA00AA92E6 /* raw_api.c in Sources */,
599
555
  FDB52FBD1F6144FA00AA92E6 /* sysv_arm64.S in Sources */,
600
556
  FDB52FBE1F6144FA00AA92E6 /* types.c in Sources */,
@@ -608,9 +564,7 @@
608
564
  buildActionMask = 2147483647;
609
565
  files = (
610
566
  FDDB2F4A1F5D846400EF414E /* ffi64_x86_64.c in Sources */,
611
- FDDB2F4B1F5D846400EF414E /* sysv_i386.S in Sources */,
612
567
  FDDB2F4C1F5D846400EF414E /* prep_cif.c in Sources */,
613
- FDDB2F4D1F5D846400EF414E /* ffi_i386.c in Sources */,
614
568
  FDDB2F4E1F5D846400EF414E /* ffiw64_x86_64.c in Sources */,
615
569
  FDDB2F4F1F5D846400EF414E /* types.c in Sources */,
616
570
  FDDB2F501F5D846400EF414E /* raw_api.c in Sources */,
@@ -712,7 +666,7 @@
712
666
  PRODUCT_NAME = ffi;
713
667
  SDKROOT = iphoneos;
714
668
  SKIP_INSTALL = YES;
715
- VALID_ARCHS = "arm64 armv7 armv7s i386 x86_64";
669
+ VALID_ARCHS = "arm64 armv7 armv7s x86_64";
716
670
  };
717
671
  name = Debug;
718
672
  };
@@ -746,7 +700,7 @@
746
700
  SDKROOT = iphoneos;
747
701
  SKIP_INSTALL = YES;
748
702
  VALIDATE_PRODUCT = YES;
749
- VALID_ARCHS = "arm64 armv7 armv7s i386 x86_64";
703
+ VALID_ARCHS = "arm64 armv7 armv7s x86_64";
750
704
  };
751
705
  name = Release;
752
706
  };