[Rd] R-2.11.1 build and 'so' libraries withouth the 'lib' prefix//update

Simon Urbanek simon.urbanek at r-project.org
Mon Jul 12 21:52:15 CEST 2010


On Jul 12, 2010, at 2:50 PM, lI wrote:

> On Monday 12 July 2010 11:07:23 lI wrote:
>> On Monday 12 July 2010 10:29:30 lI wrote:
>>> Greetings,
>>> 
>>> I have a computer with the following setup:
>>> 1)cblfs (pure 64-bit (amd64) linux), kernel2.6.34 gcc4.4.2
>>> 2)R-2.11.1
>>> 
>>> I compiled R with BLAS and lapack  using the switched  ( --with-blas="-
>>> lpthread -latlas  -lfptf77blas"
>>> --with-lapack="-llapack -lcblas"  ).
>>> (( http://cran.r-project.org/doc/manuals/R-admin.html#Linear-algebra) )
>>> 
>>> Prior to compiling R-2.11.1
>>> sh conigure --help   gave  options including  the following
>>> SHLIB_LD         command for linking shared libraries
>>>                which contain object files  from a C or Fortran compiler
>>> only SHLIB_LDFLAGS   special flags used by SHLIB_LD
>>> SHLIB_CXXLDFLAGS   special flags used by SHLIB_CXXLD
>>> SHLIB_FCD   command for linking shared libraries which contain object
>>> files from the Fortran 95 compiler
>>> SHLIB_FCLDFLAGS  special flags used by SHLIB_FCLD
>>> 
>>> 
>>> I did not know what to set for these   and accepted whatever the defaults
>>> were.  I ended up with shared-libraries which are  as  follows:-
>>> 
>>> $R_HOME/lib/{libRblas.so,libRlapack.so  }  i.e. with   the prefix 'lib'
>>> and the following shared-libraries  without the 'lib' prefix.
>>> 
>>> $R_HOME/modules/{R_X11.so,internet.so,lapack.so,vfonts.so }
>>> $R_HOME/library/cluster/libs/cluster.so
>>> $R_HOME/library/foreign/libs/foreign.so
>>> $R_HOME/library/grDevices/libs/grDevices.so
>>> $R_HOME/library/grid/libs/grid.so
>>> $R_HOME/library/KernSmooth/libs/KernSmooth.so
>>> $R_HOME/library/lattice/libs/lattice.so
>>> $R_HOME/library/MASS/libs/MASS.so
>>> $R_HOME/library/Matrix/libs/Matrix.so
>>> $R_HOME/library/methods/libs/methods.so
>>> $R_HOME/library/mgcv/libs/mgcv.so
>>> $R_HOME/library/nlme/libs/nlme.so
>>> $R_HOME/library/nnet/libs/nnet.so
>>> $R_HOME/library/rpart/libs/rpart.so
>>> $R_HOME/library/spatial/libs/spatial.so
>>> $R_HOME/library/splines/libs/splines.so
>>> $R_HOME/library/stats/libs/stats.so
>>> $R_HOME/library/survival/libs/survival.so
>>> $R_HOME/library/tools/libs/tools.so
>>> 
>>> 
>>> In linux builds   the linker usually looks for libs with the 'lib' 
>>> prefix. In this installation  all the libraries
>>> ---in $R_HOME/modules
>>> ---in $R_HOME/library/patha/to/whatevr
>>> 
>>> do not have the   'lib' prefix.
>>> 
>>> QUESTION:
>>> A) does any on list know   SHLIB_LD   SHLIB_LDFLAGS  SHLIB_CXXLDFLAGS
>>> SHLIB_FCD   SHLIB_FCLDFLAGS    settings for compiling R  and do these
>>> result in  so libs with the 'lib' prefix?
>>> B) If all of A) is negative what is there to be done to    to enable
>>> generation   libraries in $R_HOME/modules $R_HOME/library/~  with the
>>> 'lib' prefix?
>> 
>> I forgot to add     my configure/make  options.  These were:-
>> ########################
>> export BUILD64="-m64"
>> sh configure \
>> CC="gcc $BUILD64" \
>> CXX="g++ $BUILD64" \
>> F77="gfortran  $BUILD64" \
>> FC="gfortran  $BUILD64" \
>> JAVA_HOME=$JAVA_HOME \
>> LIBnn=lib64 \
>> CPPFLAGS="-I$ATLAS_HOME/include -I/opt/acml4.4.0/gfortran64_mp/include  -
>> I/opt/acml4.4.0/gfortran64/include -I/usr/local/numerics/include" \
>> LDFLAGS="-L$ATLAS_HOME/lib  -L/opt/acml4.4.0/gfortran64_mp/lib -
>> L/usr/local/numerics/lib -L/usr/lib" \
>> --prefix=/opt/TEST/R-2.11.1 \
>> --x-includes=$XORG_PREFIX/include \
>> --x-libraries=$XORG_PREFIX/lib \
>> --with-tcl-config=/usr/lib  \
>> --with-tk-config=/usr/lib \
>> --with-system-zlib=/usr  \
>> --with-system-bzlib=/usr \
>> --with-system-pcre=/usr  \
>> --with-x  \
>> --with-libpth-prefix=/usr \
>> --with-libintl-prefix=/usr \
>> --with-blas="-lpthread -latlas  -lfptf77blas" \
>> --with-lapack="-llapack -lcblas" \
>> --enable-R-shlib \
>> --enable-BLAS-shlib
>> ################
>> 
>> The sources  compiled trouble-free.   with  'make'  as normal user.
>> I then ran  'make install' as  super-user  and int installed in the prefix
>> as set..
>> 
>> A reply to the following questions would be much appreciateed:-
>> QUESTION:
>> A) does any on list know   SHLIB_LD   SHLIB_LDFLAGS  SHLIB_CXXLDFLAGS
>> SHLIB_FCD   SHLIB_FCLDFLAGS    settings for compiling R  and do these
>>  result in  so libs with the 'lib' prefix?
>> B) If all of A) is negative what is there to be done to   enable
>> generation  of  shared-libraries in $R_HOME/modules/ and 
>> $R_HOME/library/~ directories/sub-directories  with the 'lib'    prefix?
>> 
>> 
> thanks everyone for the help in clarifying what were share-libraries  and 
> otherwise.
> 
> As stated above I used two switches
> --enable-R-shlib \
> --enable-BLAS-shlib
> in the   configure options of the downloaded R-2.11.1 source  prior to 
> compilation.
> 
> I am compiling  R-2.11.1   as  an optional dependency of kdeedu-4.4.5.    This 
> asks for R-shlib   )which I noticed it is disable by the default  in the 
> configure script.)
> 
> After compile and install of R-2.11.1,  I am only able to start R from the 
> command  line

How are you starting it? The R start script does setup everything so that you should never touch anything inside.


> when I   move the generated libRblas.so to libRblas.soDUFF and 
> symlink libacml.so    to libRblas.so  and update $R_HOME/etc/ldpaths  
> accordingly.  I am unable to start R  with the compiled-in  $R_HOME/libR.so 
> and  $R_HOME/libRblas.so.
> 
> QUESTIONS:
> A) How  does one  start R with the  the generated  libR.so and libRblas.so? 

bin/R


> B) is the generated  libR.so  interchangable with libRblas.so  (i.e. R library 
> without blas   enhanced algebra  capabilities?)
> 

No - those are two entirely different libraries. The libRblas can be interchanged with a suitably complete BLAS implementation, but please do read the manuals for details.

Cheers,
Simon



More information about the R-devel mailing list