[petsc-users] Error in configuring PETSc with Cygwin on Windows by using MS-MPI

Barry Smith bsmith at petsc.dev
Thu Nov 13 09:05:05 CST 2025


  Change

__attribute__((packed))

to 

/* __attribute__((packed)) */ 

in include/petscmath.h 

and run make again.

I think you should install a new version of Microsoft's compilers etc.

  Barry


> On Nov 13, 2025, at 3:53 AM, 程奔 <202321009113 at mail.scut.edu.cn> wrote:
> 
> Hi Barry
> 
> 
> 
> Thanks for your advice.
> I use AI help me that change the file on the petsc-3.24.1/arch-mswin-c-opt/externalpackages/petsc-pkg-parmetis-f5e3aab04fd5/headers/gk_arch. 
> 
> 
> The change is from: 
> 
> #ifdef __MSC__ 
>   #include "ms_stdint.h"
>   #include "ms_inttypes.h"
>   #include "ms_stat.h"              
> #else
> #ifndef SUNOS
>   #include <stdint.h>
> #endif
> #if !defined(WIN32) && !defined(__MINGW32__)
>   #include <sys/resource.h>
> #endif
>   #include <inttypes.h>
>   #include <sys/types.h>
>   #include <sys/time.h>
> #endif
> 
> To:
> 
> #if (defined(__MSC__) || defined(_MSC_VER)) && defined(_MSC_VER) && _MSC_VER < 1900
>   #include "ms_stdint.h"
>   #include "ms_inttypes.h"
>   #include "ms_stat.h"
> #else
> #ifndef SUNOS
>   #include <stdint.h>
> #endif
> #if !defined(WIN32) && !defined(__MINGW32__) && !defined(_MSC_VER)
>   #include <sys/resource.h>
> #endif
>   #include <inttypes.h>
>   #include <sys/types.h>
> #if !defined(_MSC_VER)
>   #include <sys/time.h>
> #endif
> #endif
> 
> 
> 
> Then I configure the PETSc:
> 
> ./configure --with-debugging=0 --with-cc=cl --with-fc=0 --with-cxx=cl --download-f2cblaslapack=/cygdrive/g/mypetsc/f2cblaslapack-3.8.0.q2.tar.gz --with-mpi-include=\[/cygdrive/g/MSmpi/MicrosoftSDKs/Include,/cygdrive/g/MSmpi/MicrosoftSDKs/Include/x64\] --with-mpi-lib=\[/cygdrive/g/MSmpi/MicrosoftSDKs/Lib/x64/msmpifec.lib,/cygdrive/g/MSmpi/MicrosoftSDKs/Lib/x64/msmpi.lib\] --with-mpiexec=/cygdrive/g/MSmpi/MicrosoftMPI/Bin/mpiexec --download-metis=/cygdrive/g/mypetsc/petsc-pkg-metis-69fb26dd0428.tar.gz --download-parmetis=/cygdrive/g/mypetsc/petsc-pkg-parmetis-f5e3aab04fd5.tar.gz --with-strict-petscerrorcode=0 --with-64-bit-indices
> 
> It seems good, but then I make it
> 
> it  have the error:
> 
> 
> 
> make[3]: *** [gmakefile:211: arch-mswin-c-opt/obj/src/sys/objects/device/interface/mark_dcontext.o] Error 2
> make[3]: Leaving directory '/cygdrive/g/mypetsc/petsc-3.24.1'
> make[2]: *** [/cygdrive/g/mypetsc/petsc-3.24.1/lib/petsc/conf/rules_doc.mk:5: libs] Error 2
> make[2]: Leaving directory '/cygdrive/g/mypetsc/petsc-3.24.1'
> **************************ERROR*************************************
>   Error during compile, check arch-mswin-c-opt/lib/petsc/conf/make.log
>   Send it and arch-mswin-c-opt/lib/petsc/conf/configure.log to petsc-maint at mcs.anl.gov <mailto:petsc-maint at mcs.anl.gov>
> ********************************************************************
> make[1]: *** [makefile:44: all] Error 1
> make: *** [GNUmakefile:9: all] Error 2
> 
> 
> The new configure.log and make.log is attached below.
> 
> I don't know if it is caused by the change I made or the other problems.
> 
> 
> 
> So I ask for your help again.  
> Looking forward your reply!
> 
> 
> sinserely,
> Cheng.
> 
> 
> 
> 
> 
> 
> 
> -----原始邮件-----
> 发件人: "Barry Smith" <bsmith at petsc.dev <mailto:bsmith at petsc.dev>>
> 发送时间: 2025-11-13 00:03:50 (星期四)
> 收件人: 程奔 <202321009113 at mail.scut.edu.cn <mailto:202321009113 at mail.scut.edu.cn>>
> 抄送: PETSc <petsc-users at mcs.anl.gov <mailto:petsc-users at mcs.anl.gov>>
> 主题: Re: [petsc-users] Error in configuring PETSc with Cygwin on Windows by using MS-MPI
> 
> G:\VisualStudio2022\VC\Tools\MSVC\14.37.32822\include\stdint.h(37): error C2371: 'int_fast16_t': redefinition; different basic types
> G:\mypetsc\petsc-3.24.1\arch-mswin-c-opt\externalpackages\petsc-pkg-parmetis-f5e3aab04fd5\headers\ms_stdint.h(80): note: see declaration of 'int_fast16_t'
> G:\VisualStudio2022\VC\Tools\MSVC\14.37.32822\include\stdint.h(41): error C2371: 'uint_fast16_t': redefinition; different basic types
> G:\mypetsc\petsc-3.24.1\arch-mswin-c-opt\externalpackages\petsc-pkg-parmetis-f5e3aab04fd5\headers\ms_stdint.h(84): note: see declaration of 'uint_fast16_t'
> G:\VisualStudio2022\VC\Tools\MSVC\14.37.32822\include\stdint.h(49): warning C4005: 'INT8_MIN': macro redefinition
> G:\mypetsc\petsc-3.24.1\arch-mswin-c-opt\externalpackages\petsc-pkg-parmetis-f5e3aab04fd5\headers\ms_stdint.h(107): note: see previous definition of 'INT8_MIN'
> 
> Parmetis has its own definitions for many C standard types, etc in headers\ms_stdint.h that duplicate what is available in stdint.h on Unix systems. Normally, this gets included when __MSC_ is defined instead of stdint.h (in gk_arch.h).
> 
> But for some reason, with your system it appears that Microsoft's stdint.h is also getting included; presumably brought in through some other system include file since it is only included in one place.
> 
> $ git grep stdint.h
> headers/gk_arch.h:  #include "ms_stdint.h"
> headers/gk_arch.h:  #include <stdint.h>
> headers/ms_inttypes.h:#include "ms_stdint.h"
> headers/ms_stdint.h:// ISO C9x  compliant stdint.h for Microsoft Visual Studio
> 
> You have a fairly old VisualStudio, 2022. Can you upgrade to the latest? Let us know if this resolves the problem.
> 
> Barry
> 
> 
> 
> 
>  
> 
> 
> 
> 
> 
> On Nov 12, 2025, at 5:29 AM, 程奔 <202321009113 at mail.scut.edu.cn <mailto:202321009113 at mail.scut.edu.cn>> wrote:
> 
> Hi Barry
> Thanks for your reply.
> I check the package parmetis,and the "petsc-pkg-parmetis-45100eac9301.tar.gz" is form https://urldefense.us/v3/__https://bitbucket.org/petsc/pkg-parmetis/get/v4.0.3.tar.gz__;!!G_uCfscf7eWS!fxWXWboQRNUYFGMA0mW58ZDCE6A4aGfOZvzcj0EG2lHsj_174DkztA-YDWKfPXg9WJxjRkZ13WsNy2TXkQuzMkw$ . So I made a mistake about the package.
> Then I download the package form https://urldefense.us/v3/__https://bitbucket.org/petsc/pkg-parmetis/get/v4.0.3-p9.tar.gz__;!!G_uCfscf7eWS!fxWXWboQRNUYFGMA0mW58ZDCE6A4aGfOZvzcj0EG2lHsj_174DkztA-YDWKfPXg9WJxjRkZ13WsNy2TXPQoo3R0$  and it is "petsc-pkg-parmetis-f5e3aab04fd5.tar.gz" 
> 
> 
> Then the compiler option in configuration is:
> ./configure --with-debugging=0 --with-cc=cl --with-fc=0 --with-cxx=cl --download-f2cblaslapack=/cygdrive/g/mypetsc/f2cblaslapack-3.8.0.q2.tar.gz --with-mpi-include=\[/cygdrive/g/MSmpi/MicrosoftSDKs/Include,/cygdrive/g/MSmpi/MicrosoftSDKs/Include/x64\] --with-mpi-lib=\[/cygdrive/g/MSmpi/MicrosoftSDKs/Lib/x64/msmpifec.lib,/cygdrive/g/MSmpi/MicrosoftSDKs/Lib/x64/msmpi.lib\] --with-mpiexec=/cygdrive/g/MSmpi/MicrosoftMPI/Bin/mpiexec --download-metis=/cygdrive/g/mypetsc/petsc-pkg-metis-69fb26dd0428.tar.gz --download-parmetis=/cygdrive/g/mypetsc/petsc-pkg-parmetis-f5e3aab04fd5.tar.gz --with-strict-petscerrorcode=0 --with-64-bit-indices
> 
> but it still have the same error:
> *********************************************************************************************
> =============================================================================================
> =============================================================================================
>                 Configuring PARMETIS with CMake; this may take several minutes
> =============================================================================================
> =============================================================================================
>                Compiling and installing PARMETIS; this may take several minutes
> =============================================================================================
> 
> 
> *********************************************************************************************
>            UNABLE to CONFIGURE with GIVEN OPTIONS (see configure.log for details):
> ---------------------------------------------------------------------------------------------
>                                Error running make on  PARMETIS
> 
> 
> *********************************************************************************************
> 
> 
> The new configure.log is attached below.
> So I ask for your help again.  
> Looking forward your reply!
> 
> 
> sinserely,
> Cheng.
> 
> 
> 
> 
> -----原始邮件-----
> 发件人: "Barry Smith" <bsmith at petsc.dev <mailto:bsmith at petsc.dev>>
> 发送时间: 2025-11-11 23:29:01 (星期二)
> 收件人: "Matthew Knepley" <knepley at gmail.com <mailto:knepley at gmail.com>>
> 抄送: 程奔 <ctchengben at mail.scut.edu.cn <mailto:ctchengben at mail.scut.edu.cn>>, petsc-users at mcs.anl.gov <mailto:petsc-users at mcs.anl.gov>
> 主题: Re: [petsc-users] Error in configuring PETSc with Cygwin on Windows by using MS-MPI
> 
> 
>   Where/how did you obtain /cygdrive/g/mypetsc/petsc-pkg-parmetis-45100eac9301.tar.gz ? Was it from PETSc ./configure?
> 
>     self.version          = '4.0.3'
>     self.versionname      = 'PARMETIS_MAJOR_VERSION.PARMETIS_MINOR_VERSION.PARMETIS_SUBMINOR_VERSION'
>     self.gitcommit         = 'v'+self.version+'-p9'
>     self.download          = ['git://https://bitbucket.org/petsc/pkg-parmetis.git','https://bitbucket.org/petsc/pkg-parmetis/get/'+self.gitcommit+'.tar.gz <git://https//bitbucket.org/petsc/pkg-parmetis.git','https://bitbucket.org/petsc/pkg-parmetis/get/'+self.gitcommit+'.tar.gz>']
> 
> 
> 
> On Nov 11, 2025, at 7:35 AM, Matthew Knepley <knepley at gmail.com <mailto:knepley at gmail.com>> wrote:
> 
> On Tue, Nov 11, 2025 at 4:44 AM 程奔 <ctchengben at mail.scut.edu.cn <mailto:ctchengben at mail.scut.edu.cn>> wrote:
> Hello,
> Recently I try to install PETSc with Cygwin since I'd like to use PETSc with Visual Studio on Windows10 plateform.For the sake of clarity, I firstly list the softwares/packages used below:
> 1. PETSc: version 3.14.1
> 2. VS: version 2022 
> 3. MS MPI: download Microsoft MPI v10.1.2
> 4. Cygwin
> 
> Quick question: Have you considered installing on WSL? I have had much better luck with that on Windows.
> 
> This seems to be an incompatibility of ParMetis Windows support and your version:
> 
> G:\VisualStudio2022\VC\Tools\MSVC\14.37.32822\include\stdint.h(37): error C2371: 'int_fast16_t': redefinition; different basic types^M
> G:\mypetsc\petsc-3.24.1\arch-mswin-c-opt\externalpackages\petsc-pkg-parmetis-f5e3aab04fd5\headers\ms_stdint.h(80): note: see declaration of 'int_fast16_t'^M
> G:\VisualStudio2022\VC\Tools\MSVC\14.37.32822\include\stdint.h(41): error C2371: 'uint_fast16_t': redefinition; different basic types^M
> G:\mypetsc\petsc-3.24.1\arch-mswin-c-opt\externalpackages\petsc-pkg-parmetis-f5e3aab04fd5\headers\ms_stdint.h(84): note: see declaration of 'uint_fast16_t'^M 
> 
>   Thanks,
> 
>      Matt
> 
> And the compiler option in configuration is:
> ./configure --with-debugging=0 --with-cc=cl --with-fc=0 --with-cxx=cl 
> --download-f2cblaslapack=/cygdrive/g/mypetsc/f2cblaslapack-3.8.0.q2.tar.gz 
> --with-mpi-include=\[/cygdrive/g/MSmpi/MicrosoftSDKs/Include,/cygdrive/g/MSmpi/MicrosoftSDKs/Include/x64\] 
> --with-mpi-lib=\[/cygdrive/g/MSmpi/MicrosoftSDKs/Lib/x64/msmpifec.lib,/cygdrive/g/MSmpi/MicrosoftSDKs/Lib/x64/msmpi.lib\] 
> --with-mpiexec=/cygdrive/g/MSmpi/MicrosoftMPI/Bin/mpiexec 
> --download-metis=/cygdrive/g/mypetsc/petsc-pkg-metis-69fb26dd0428.tar.gz 
> --download-parmetis=/cygdrive/g/mypetsc/petsc-pkg-parmetis-45100eac9301.tar.gz 
> --with-strict-petscerrorcode=0 --with-64-bit-indices --download-hdf5=/cygdrive/g/mypetsc/hdf5-1.14.3-p1.tar.bz2
> 
> 
> 
> 
> 
> 
> but there return an error:
> *********************************************************************************************
> =============================================================================================
> =============================================================================================
>                 Configuring PARMETIS with CMake; this may take several minutes
> =============================================================================================
> =============================================================================================
>                Compiling and installing PARMETIS; this may take several minutes
> =============================================================================================
> 
> 
> *********************************************************************************************
>            UNABLE to CONFIGURE with GIVEN OPTIONS (see configure.log for details):
> ---------------------------------------------------------------------------------------------
>                                Error running make on  PARMETIS
> 
> 
> *********************************************************************************************
> 
> 
> The configure.log is attached below.
> So I write this email to report my problem and ask for your help.  
> Looking forward your reply!
> 
> 
> sinserely,
> Cheng.
> 
> 
> -- 
> What most experimenters take for granted before they begin their experiments is infinitely more interesting than any results to which their experiments lead.
> -- Norbert Wiener
> 
> https://urldefense.us/v3/__https://www.cse.buffalo.edu/*knepley/__;fg!!G_uCfscf7eWS!fxWXWboQRNUYFGMA0mW58ZDCE6A4aGfOZvzcj0EG2lHsj_174DkztA-YDWKfPXg9WJxjRkZ13WsNy2TXA-nTYTc$ 
> 
> 

-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.mcs.anl.gov/pipermail/petsc-users/attachments/20251113/b019f5a4/attachment-0003.html>
-------------- next part --------------
A non-text attachment was scrubbed...
Name: configure.log
Type: application/octet-stream
Size: 2302425 bytes
Desc: not available
URL: <http://lists.mcs.anl.gov/pipermail/petsc-users/attachments/20251113/b019f5a4/attachment-0002.obj>
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.mcs.anl.gov/pipermail/petsc-users/attachments/20251113/b019f5a4/attachment-0004.html>
-------------- next part --------------
A non-text attachment was scrubbed...
Name: make.log
Type: application/octet-stream
Size: 17055 bytes
Desc: not available
URL: <http://lists.mcs.anl.gov/pipermail/petsc-users/attachments/20251113/b019f5a4/attachment-0003.obj>
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.mcs.anl.gov/pipermail/petsc-users/attachments/20251113/b019f5a4/attachment-0005.html>


More information about the petsc-users mailing list