Skip to content
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

Build failures against NumPy 2.0 with GCC 14 #393

Closed
mgorny opened this issue May 21, 2024 · 8 comments
Closed

Build failures against NumPy 2.0 with GCC 14 #393

mgorny opened this issue May 21, 2024 · 8 comments

Comments

@mgorny
Copy link

mgorny commented May 21, 2024

When using a stricter compiler (e.g. GCC 14) and building against NumPy 2.0.0rc2, the build fails over a bunch of type mismatches:

building 'fitsio._fitsio_wrap' extension
creating build/temp.linux-x86_64-cpython-312/fitsio
gcc-14 -fno-strict-overflow -Wsign-compare -fPIC -I/usr/lib/python3.12/site-packages/numpy/_core/include -Ibuild/temp.linux-x86_64-cpython-312/cfitsio-4.2.0 -Ibuild/temp.linux-x86_64-cpython-312/cfitsio-4.2.0 -I/usr/include/python3.12 -c fitsio/fitsio_pywrap.c -o build/temp.linux-x86_64-cpython-312/fitsio/fitsio_pywrap.o
In file included from /usr/lib/python3.12/site-packages/numpy/_core/include/numpy/ndarraytypes.h:1909,
                 from /usr/lib/python3.12/site-packages/numpy/_core/include/numpy/ndarrayobject.h:12,
                 from /usr/lib/python3.12/site-packages/numpy/_core/include/numpy/arrayobject.h:5,
                 from fitsio/fitsio_pywrap.c:28:
/usr/lib/python3.12/site-packages/numpy/_core/include/numpy/npy_1_7_deprecated_api.h:17:2: warning: #warning "Using deprecated NumPy API, disable it with " "#define NPY_NO_DEPRECATED_API NPY_1_7_API_VERSION" [-Wcpp]
   17 | #warning "Using deprecated NumPy API, disable it with " \
      |  ^~~~~~~
fitsio/fitsio_pywrap.c: In function ‘get_int64_from_array’:
fitsio/fitsio_pywrap.c:561:29: error: passing argument 1 of ‘PyArray_TYPE’ from incompatible pointer type [-Wincompatible-pointer-types]
  561 |     npy_type = PyArray_TYPE(arr);
      |                             ^~~
      |                             |
      |                             PyObject * {aka struct _object *}
/usr/lib/python3.12/site-packages/numpy/_core/include/numpy/ndarraytypes.h:1563:35: note: expected ‘const PyArrayObject *’ {aka ‘const struct tagPyArrayObject_fields *’} but argument is of type ‘PyObject *’ {aka ‘struct _object *’}
 1563 | PyArray_TYPE(const PyArrayObject *arr)
      |              ~~~~~~~~~~~~~~~~~~~~~^~~
/usr/lib/python3.12/site-packages/numpy/_core/include/numpy/ndarraytypes.h:1021:50: error: passing argument 1 of ‘PyArray_CHKFLAGS’ from incompatible pointer type [-Wincompatible-pointer-types]
 1021 | #define PyArray_ISCONTIGUOUS(m) PyArray_CHKFLAGS((m), NPY_ARRAY_C_CONTIGUOUS)
      |                                                  ^~~
      |                                                  |
      |                                                  PyObject * {aka struct _object *}
fitsio/fitsio_pywrap.c:575:10: note: in expansion of macro ‘PyArray_ISCONTIGUOUS’
  575 |     if (!PyArray_ISCONTIGUOUS(arr)) {
      |          ^~~~~~~~~~~~~~~~~~~~
/usr/lib/python3.12/site-packages/numpy/_core/include/numpy/ndarraytypes.h:1569:39: note: expected ‘const PyArrayObject *’ {aka ‘const struct tagPyArrayObject_fields *’} but argument is of type ‘PyObject *’ {aka ‘struct _object *’}
 1569 | PyArray_CHKFLAGS(const PyArrayObject *arr, int flags)
      |                  ~~~~~~~~~~~~~~~~~~~~~^~~
fitsio/fitsio_pywrap.c:580:28: error: passing argument 1 of ‘PyArray_DATA’ from incompatible pointer type [-Wincompatible-pointer-types]
  580 |     colnums = PyArray_DATA(arr);
      |                            ^~~
      |                            |
      |                            PyObject * {aka struct _object *}
/usr/lib/python3.12/site-packages/numpy/_core/include/numpy/ndarraytypes.h:1508:35: note: expected ‘const PyArrayObject *’ {aka ‘const struct tagPyArrayObject_fields *’} but argument is of type ‘PyObject *’ {aka ‘struct _object *’}
 1508 | PyArray_DATA(const PyArrayObject *arr)
      |              ~~~~~~~~~~~~~~~~~~~~~^~~
fitsio/fitsio_pywrap.c:581:27: error: passing argument 1 of ‘PyArray_DIMS’ from incompatible pointer type [-Wincompatible-pointer-types]
  581 |     *ncols = PyArray_SIZE(arr);
      |                           ^~~
      |                           |
      |                           PyObject * {aka struct _object *}
/usr/lib/python3.12/site-packages/numpy/_core/include/numpy/ndarrayobject.h:79:59: note: in definition of macro ‘PyArray_SIZE’
   79 | #define PyArray_SIZE(m) PyArray_MultiplyList(PyArray_DIMS(m), PyArray_NDIM(m))
      |                                                           ^
/usr/lib/python3.12/site-packages/numpy/_core/include/numpy/ndarraytypes.h:1520:35: note: expected ‘const PyArrayObject *’ {aka ‘const struct tagPyArrayObject_fields *’} but argument is of type ‘PyObject *’ {aka ‘struct _object *’}
 1520 | PyArray_DIMS(const PyArrayObject *arr)
      |              ~~~~~~~~~~~~~~~~~~~~~^~~
fitsio/fitsio_pywrap.c:581:27: error: passing argument 1 of ‘PyArray_NDIM’ from incompatible pointer type [-Wincompatible-pointer-types]
  581 |     *ncols = PyArray_SIZE(arr);
      |                           ^~~
      |                           |
      |                           PyObject * {aka struct _object *}
/usr/lib/python3.12/site-packages/numpy/_core/include/numpy/ndarrayobject.h:79:76: note: in definition of macro ‘PyArray_SIZE’
   79 | #define PyArray_SIZE(m) PyArray_MultiplyList(PyArray_DIMS(m), PyArray_NDIM(m))
      |                                                                            ^
/usr/lib/python3.12/site-packages/numpy/_core/include/numpy/ndarraytypes.h:1502:35: note: expected ‘const PyArrayObject *’ {aka ‘const struct tagPyArrayObject_fields *’} but argument is of type ‘PyObject *’ {aka ‘struct _object *’}
 1502 | PyArray_NDIM(const PyArrayObject *arr)
      |              ~~~~~~~~~~~~~~~~~~~~~^~~
fitsio/fitsio_pywrap.c: In function ‘PyFITSObject_create_image_hdu’:
fitsio/fitsio_pywrap.c:1451:34: error: passing argument 1 of ‘PyArray_TYPE’ from incompatible pointer type [-Wincompatible-pointer-types]
 1451 |         npy_dtype = PyArray_TYPE(array);
      |                                  ^~~~~
      |                                  |
      |                                  PyObject * {aka struct _object *}
[…]

(the list is actually quite long)

@jakirkham
Copy link

Hi All 👋

NumPy is planning to release 2.0 on June 16th ( numpy/numpy#24300 (comment) ). NumPy 2.0.0 RC packages for conda & wheels came out at the beginning of April ( numpy/numpy#24300 (comment) )

NumPy has put out a migration guide. More details are in the release notes

If fitsio makes use of NumPy's C API (and produces wheels that use it), having a release of fitsio with wheels built against NumPy 2.0.0rc1 would be helpful to ensure NumPy 1 & 2 compatible wheels (as wheels built against NumPy 1 won't be compatible with NumPy 2). More details in this NumPy 2 ABI doc

Also as NumPy is tracking ecosystem support for NumPy 2.0, it would be helpful to share fitsio current support status in issue (with any plans): numpy/numpy#26191

@esheldon
Copy link
Owner

Thanks. We definitely have some work to do but it looks mostly mechanical.

@esheldon
Copy link
Owner

Does #394 solve the issues for you?

@mgorny
Copy link
Author

mgorny commented Jun 10, 2024

Yes, it does. Thanks a lot!

@jakirkham
Copy link

Thanks all! 🙏

Should we close this issue then? Or do you want to wait for a release?

@esheldon
Copy link
Owner

I'm thinking to close and make a release ASAP, but I'm happy to hear counterarguments.

@jakirkham
Copy link

SGTM

@mgorny
Copy link
Author

mgorny commented Jun 10, 2024

Feel free to close it.

razvand added a commit to open-crs/dataset that referenced this issue Dec 26, 2024
Several package versions result in build / runtime errors. Update the
`pyprojects.toml` file to use the proper version for packages.

There were several issues, detailed below.

There in an issue with the `requests` package v2.32, unable to handle
the `http+docker` URL scheme (as discussed here:
psf/requests#6707).  Solution is to downgrade
the `requests` package. Meaning using the line below in
`pyprojects.toml`:

```
requests = "2.31.0"
```

There is an issue with the `numpy` package when using GCC14 (as
discussed here: esheldon/fitsio#393). Solution
is to downgrade the `numpy` package together with the `pandas` package.
Meaning using the lines below in `pyprojects.toml`:

```
pandas= "2.2.1"
numpy = "1.26.4"
```

Signed-off-by: Razvan Deaconescu <razvan.deaconescu@upb.ro>
razvand added a commit to open-crs/dataset that referenced this issue Dec 27, 2024
Several package versions result in build / runtime errors. Update the
`pyprojects.toml` file to use the proper version for packages.

There were several issues, detailed below.

There in an issue with the `requests` package v2.32, unable to handle
the `http+docker` URL scheme (as discussed here:
psf/requests#6707).  Solution is to downgrade
the `requests` package. Meaning using the line below in
`pyprojects.toml`:

```
requests = "2.31.0"
```

There is an issue with the `numpy` package when using GCC14 (as
discussed here: esheldon/fitsio#393). Solution
is to downgrade the `numpy` package together with the `pandas` package.
Meaning using the lines below in `pyprojects.toml`:

```
pandas = "2.2.1"
numpy = "1.26.4"
```

Signed-off-by: Razvan Deaconescu <razvan.deaconescu@upb.ro>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

3 participants