HEASoft v6.30.1 - Known Issues

If you are using HEASoft v6.30 and don't want to upgrade to v6.30.1 just yet, see the HEASoft 6.30 Issues List.

Several packages track issues separately from this page:

The following is a list of known issues in v6.30.1 of HEASoft not covered by the above pages.


Last modified Tuesday, 15-Nov-2022 13:00:57 EST

  • Apple XCode 14.0 & third-party GCC:

    Users who have updated their Apple XCode to the very latest version (14.0) and are using the recommended third-party compilers (e.g., Homebrew or MacPorts) may run into build problems in the CCFITS library ["Assertion failed: (_file->_atomsArrayCount == computedAtomCount && "more atoms allocated than expected")]. This appears to be a problem in the XCode Command Line Tools (CLT) that will be fixed in a future XCode update. Downgrading to XCode 13.4 should fix the problem in the meantime.

    If the direct link to the XCode CLT 13.4 disk image in the link above does not work for you, try this page instead (requires an Apple account).

    Update:

    The latest XCode 14.1 RC released by Apple appears to have fixed this problem.

  • BAT (Swift) software & GCC 12:

    Imaging software for the Swift BAT instrument is generating incorrect numerical values when built on a Mac using GCC 12 from e.g. Homebrew or MacPorts. We are investigating, but until further notice recommend that users avoid GCC 12 and use for example GCC 11 or GCC 10 instead.

  • extractor & HALOSAT:

    The extractor task may have issues creating new event files from HALOSAT data. To update your source code installation with a fix, download this patch for extractor and then rebuild & reinstall extractor, for example:

    First, unpack the tar file above your existing heasoft-6.30.1 source code folder.  Next, initialize heasoft and then:
    
    $ cd heasoft-6.30.1/ftools/heasarc/tasks/extractor
    $ hmake clean
    $ hmake
    $ hmake install
    
  • XTE pcabackest:

    The XTE task pcabackest has been updated to fix the "modelfile=CALDB" option. Previously use of this option was estimating the background to be only a tiny fraction of the true background. To update your source code installation with a fix, download the new version of pcabackest.c and then rebuild & reinstall pcabackest, for example:

    First, move the new pcabackest.c into the tool location:
    
    $ mv ~/Downloads/pcabackest.c heasoft-6.30.1/ftools/xte/tasks/pcabackest/.
    
    Initialize heasoft, then:
    
    $ cd heasoft-6.30.1/ftools/xte/tasks/pcabackest/
    $ hmake clean
    $ hmake
    $ hmake install
    
  • IXPE HEASoftPy 6.30.1 patch issue:

    Some IXPE Python code was not updated in the 6.30.1 patch release as intended. The 6.30.1 patch file (used to update existing 6.30 installations) and the 6.30.1 downloads are all corrected now (13-Apr-2022 15:45 EDT), but if you patched your 6.30 release or downloaded 6.30.1 prior to April 13 and plan to use the IXPE software, please update your installation in the following way:

    • For existing 6.30 source code installations that were patched for 6.30.1, just remove the earlier source patch file and run "hdpatch_6.30.1" again (see the patch page if you disposed of hdpatch_6.30.1 already):
      $ rm heasoft-6.30.1_src_patch.tar.gz
      $ sh hdpatch_6.30.1
      
    • For existing 6.30 pre-compiled binary installations that were patched for 6.30.1, please re-acquire and re-apply the relevant binary tar file from the links at the patch page.

    • For users who instead acquired a new 6.30.1 installation (source or pre-compiled binaries), please download this file. Then, initialize your 6.30.1 installation and unpack that file in the location defined by $HEADAS, for example:
      $ cd $HEADAS
      $ tar zxf ~/Downloads/heasoftpy_ixpe_6.30.1.tar.gz
      

  • Mac "C compiler cannot create executables":

    The HEASoft configure script may fail with "C compiler cannot create executables", and one of the config.logs may show

    ld: library not found for -lSystem

    This error typically implies that your compiler suite (e.g. Homebrew or MacPorts) is out-of-synch with the Apple (XCode) Command Line Tools (CLT), for example if you updated the CLT but did not reinstall Homebrew after doing so. Since these third-party compilers use the CLT, they must typically be rebuilt/reinstalled whenever XCode/CLT are updated.

    For example, some users have worked their way past this by uninstalling the CLT and then reinstalling the CLT, then uninstalling and reinstalling the Homebrew compilers.

    Another common problem in the configure stage is the following:

    ld: unsupported tapi file type '!tapi-tbd' in YAML file '/Library/Developer/CommandLineTools/SDKs/MacOSX10.15.sdk/usr/lib/libSystem.tbd' for architecture x86_64

    This can typically be resolved by putting /usr/bin at the front of your PATH environment variable (as recommended in our Mac installation guide).

  • Mac "gcc-11: error: unrecognized command-line option '-iwithsysroot'; did you mean '-isysroot'?":

    On newer macOS we have found that using the Apple Perl (/usr/bin/perl) alongside third-party GCC (Homebrew, MacPorts, etc.) may cause build problems as a result of flags ("-iwithsysroot") that Apple's Perl inserts into our C/Perl library configuration. So, we recommend that you install and use e.g. the matching Homebrew or MacPorts Perl.
  • Using "sudo" or "screen":

    Since configuring HEASoft typically works best when setting environment variables to point to specific compilers, using sudo at the configure stage is not recommended since sudo spawns a new shell that does not automatically inherit current environment settings. The sudo command should not be needed for configuring in any case; it should only be necessary when running "make install", and only then if you are writing to a root-protected area (e.g. /usr/local or /Applications).

    Similarly, the screen command does not inherit all environment variables, so if you spawn a screen session before running the configure script, be sure to check or set environment variables after starting the screen utility.
  • Apple clang 12 (or newer):

    Builds of HEASoft using version 12 or newer of the Apple clang compiler are not supported, though we hope to be able to support clang again in a future release. Users are advised to follow the instructions in our Mac installation guide for using third-party compilers (Homebrew, MacPorts, etc.) instead.
  • "Developer cannot be verified" or "unidentified developer" error on Macs:

    Some Mac users have reported problems configuring and/or running pre-compiled HEASoft binaries. To free HEASoft binaries from the Apple quarantine, use the xattr utility, e.g.:
    $ cd heasoft-6.30/x86_64-apple-darwin20.6.0
    $ xattr -r -d com.apple.quarantine BUILD_DIR/configure lib/* bin/*
    
  • Fortran compiler requirements:

    HEASoft now includes a new dependency on the FGSL library which requires a Fortran 2008 feature (c_loc for targeted arrays); therefore GNU Fortran compilers older than version ~5.x are unsupported.
  • XIMAGE and gfortran 8.x (or newer) on macOS:

    When built with the Apple XCode C compiler (clang) paired with gfortran newer than version 8.0, ximage may generate "Invalid header key" messages and a Tcl error "Failed to run tcl: pgtk::upcopy MAP1 MAP9". Subsequent attempts to display the image may then result in a segmentation fault. Note that this problem will affect tasks that use ximage such as xrtpipeline or nupipeline. To get around this, we recommend avoiding the Apple XCode compilers and using only a third-party compiler suite instead, as noted in our Mac installation guide.

  • Perl symbol lookup error, "undefined symbol: Perl_Gthr_key_ptr":

    If running a HEASoft Perl script generates an error similar to the above, it may result from a Perl version incompatibility (common when using the pre-compiled binaries), but it may also occur if you have the VERSIONER_PERL_PREFER_32_BIT environment variable set to "yes". If "echo VERSIONER_PERL_PREFER_32_BIT" returns "yes", then unset it:

       unset VERSIONER_PERL_PREFER_32_BIT
    
    or, in C-shell:
    
       unsetenv VERSIONER_PERL_PREFER_32_BIT
    
  • Mac "configure failed..." Fortran compiler issue:

    The configure script may generate an error ("Configure failed in the AST package!", or "configure failed for heacore component fftw!") resulting from a MacPorts assembler (as) under /opt/local/bin being ahead of the default Apple /usr/bin/as in a user's PATH (which may result from an automated change made to .profile during a MacPorts installation). To get past this issue, put /usr/bin at the front of your PATH:

       export PATH="/usr/bin:$PATH"
    
  • MacPorts "unexpected token" linker issue:

    If you are using MacPorts compilers in your build, 'make' may fail when building the HEASoft source code distribution with an error referring to a new Xcode linker ("ld") format ("tbd"), e.g.:

    ld: in '/System/Library/PrivateFrameworks/CoreEmoji.framework/Versions/A/CoreEmoji.tbd', unexpected token: !tapi-tbd-v2 ...
    
    The underlying issue is discussed here and here; it appears that when new versions of the XCode command line tools are released, problems such as this may affect MacPorts compilers until they catch up with Apple's changes. Users should be able to get around the error in our build by installing the MacPorts 'xcode' variant of the linker ld64 as a temporary measure:
    
        sudo port install ld64 +ld64_xcode
    
    
    and when MacPorts eventually supports the latest XCode command line tools, you can switch back to the latest ld64 with the following:
    
        sudo port install ld64 +ld64_latest
    
    
  • Mac "suffix or operands invalid for 'movq'" Fortran compiler issue:

    When using the gnu.org gfortran binaries note their recommendation that when installing new versions of the compiler you should remove the previous gfortran installation first:

       $ sudo rm -r /usr/local/gfortran /usr/local/bin/gfortran
    
    Failure to do so may result in a corrupted compiler installation, leading to the "suffix or operands invalid for 'movq'" error.


  • Ubuntu ds9 & HEASoft:

    After initializing HEASoft on Ubuntu Linux, the ds9 GUI (if installed) may fail to start up (mentioning "can't find package xml", "can't find package uri 1.1", or "package require base64""). This results from incompatibilities between the Tcl/Tk included with HEASoft and the Ubuntu system libraries. Until a more elegant solution can be devised, we recommend that users try one of the following options, depending on the file type of your ds9 (shell script or compiled executable - check the output from "file `which ds9`" to determine which it is):

    
    1) If ds9 is the shell script version, edit it to change the line
    
         exec wish8.6 -f ${DS9_HOME-/usr/share/saods9}/library/ds9.tcl $*
    
       to
    
         exec /usr/bin/env -u LD_LIBRARY_PATH /usr/bin/wish8.6 -f ${DS9_HOME-/usr/share/saods9}/library/ds9.tcl $*
    
    or
    
    2) If ds9 is the compiled executable version, create a new file
       "$HEADAS/bin/ds9" containing the following lines:
    
         #!/bin/sh
         exec /usr/bin/env -u LD_LIBRARY_PATH /usr/bin/ds9 "$@"
    
       (Note this assumes that `which ds9` = /usr/bin/ds9)
    
       To make the new script executable, run the following command:
    
         $ chmod +x $HEADAS/bin/ds9
    
       Then, as long as $HEADAS/bin is ahead of /usr/bin in your PATH, you
       should now be able to successfully run ds9 from the command line:
    
         $ rehash
         $ ds9
    
    


  • "relocation R_X86_64_32 against `.rodata' can not be used when making a shared object":

    Users building HEASoft from the source code distribution may run into this error which refers to a "Bad value" in the file heacore/wcslib/C/cel.o, from which the linker "could not read symbols". It also suggests that you "recompile with -fPIC". This situation most likely occurrs when users perform a re-build after a previously unsuccessful build attempt. To get past this issue, try the following:
    
       $ cd heasoft-6.27.1/BUILD_DIR
       $ make distclean
    
    
    When that finishes, restart the build procedure beginning with "./configure", then "make", and let us know if this does not resolve the problem.


  • fv - XPA_METHOD:

    Some users of the fv GUI may experience long delays at startup, or error messages of the type "XPA$WARNING: xpans needs to be running on this machine", or "XPA$ERROR: invalid host name specified: $host:$port" (when using the ds9 display device). These issues tend to occur on Macs with customized firewall settings, or on machines without valid IP addresses. This can be resolved by setting the XPA_METHOD environment variable to the value "local" (to use local/UNIX sockets instead of inet sockets):
    
            export XPA_METHOD=local          # Bourne shell (bash/sh)
    or
            setenv XPA_METHOD local          # C-shell (csh/tcsh)
    
    
  • Perl version mismatch::

    Pre-compiled Perl libraries used extensively by mission software (Swift, Suzaku, NuSTAR) and other packages are not especially portable, so we generally recommend building HEASoft from the source code distribution.


  • xspec / PLT - wenv, whead, wdata:

    Some GNU Fortran compilers (gfortran 4.4.x, 4.0.x, 4.1.x) appear to have internal issues which prevent the PLT commands wenv, whead and wdata from working unless an output file is specified; i.e. attempts at producing terminal output may fail with "Fortran runtime error: Invalid argument". To get around this, provide an output file name when using these commands, for example:
         wenv myFile1.qdp
         whead myFile2.qdp
         wdata myFile3.qdp
    


  • HEASoft and other software packages (CIAO, XMM-SAS):

    Please note:

    Users may wish to download and run our hwrap script to create an alternate runtime environment for HEASoft to help avoid conflicts with other software packages, but if not, please take note of the potential pitfalls below:

    • CIAO:

      Please see the following notes at the CXC website regarding the potential dangers of using CIAO and HEASoft together in the same session:



    • XMM-SAS:

      The XMM-SAS setup typically adjusts your LD_LIBRARY_PATH environment variable (or DYLD_LIBRARY_PATH on macOS) to include the SAS library folders, one of which includes a copy of the C++ compiler library (libstdc++). This can cause problems building HEASoft, so we recommend that HEASoft be built in a session in which the SAS has not been initialized, or at least one in which your [DY]LD_LIBRARY_PATH is either empty or otherwise does not include the installed SAS directories.

      Similarly, after both SAS and HEASoft are installed, if they are initialized in the same session (terminal), C++-based tasks such as XSPEC may suffer runtime problems if the XMM-SAS library directories precede the one needed by XSPEC in [DY]LD_LIBRARY_PATH (as is the case if the SAS is initialized after HEASoft. As an example, if you compiled HEASoft on a Mac using the Homebrew compilers, XSPEC will need to have the Homebrew library path ahead of the SAS library directories in your DYLD_LIBRARY_PATH:
           For example:
      
           C-shell:
      
               setenv DYLD_LIBRARY_PATH "/usr/local/opt/gcc/lib/gcc/10:${DYLD_LIBRARY_PATH}
      
           Bourne shell:
      
               export DYLD_LIBRARY_PATH="/usr/local/opt/gcc/lib/gcc/10:${DYLD_LIBRARY_PATH}
        
      Additionally, when both the SAS & HEASoft are used in the same session and the SAS was initialized after HEASoft, the SAS setup changes the value of the environment variable PGPLOT_FONT with the result that plots in e.g. XSPEC may (or may not, depending on the software distributions in use) have no axis labels or values. Users can fix this by resetting PGPLOT_FONT to point to the HEASoft location:
           C-shell:
      
               setenv PGPLOT_FONT $HEADAS/lib/grfont.dat
      
           Bourne shell:
      
               export PGPLOT_FONT=$HEADAS/lib/grfont.dat
      
        
      or by simply re-initializing HEASoft:
           C-shell:
      
               source $HEADAS/headas-init.csh
      
           Bourne shell:
      
               . $HEADAS/headas-init.sh
        
      This may in turn have consequences for plotting in XMM-SAS, in which case users may need to return PGPLOT_FONT to the SAS setting when using it for data analysis.


If you have any questions about the information above, please write to us at the FTOOLS help desk.
FTOOLS HELP DESK

If FTOOLS has been useful in your research, please reference this site (http://heasarc.gsfc.nasa.gov/ftools) and use the ASCL reference for HEASoft [ascl:1408.004] or the ASCL reference for the original FTOOLs paper [ascl:9912.002]:

Blackburn, J. K. 1995, in ASP Conf. Ser., Vol. 77, Astronomical Data Analysis Software and Systems IV, ed. R. A. Shaw, H. E. Payne, and J. J. E. Hayes (San Francisco: ASP), 367.

Web page maintained by: Bryan K. Irby