Friday, October 21, 2011

Topspin and Iconnmr

From the viewpoint of safely providing a walk-on environment, IconNMR is quite handy.  Here is a simple format of how we can implement this. The immediate platform that can benefit from this is the new 800 MHz spectrometer.  

Before we proceed, keeping the target users in mind i.e. UWNetid users, we should first replicate our Krb5/LDAP auth/auth system in the 800 MHz system's host.

  • We can implement the same icewm window manager with the usual startup script. 
  • From the autostart.prop file, we can start iconnmr. 
  • IconNMR can be configured so that the user is locked out of changing any parameters.  This locks up the Topspin gui automatically so that TS is used only to display the progress of data being collected and the spectrum that gets generated. 
  • We still need to make sure that the user cannot access autostart.prop and remove the icon startup command. Such a possibility will give them a potential to access the regular TS interface freely with all its functionalities. 
  •  
With further consultation from Bruker,  it looks like this is the simplest way to implement this scheme as of now.



continued 10.24.2011

There are a few points worth recording after further investigation here.

  • When the user is logged into ICONNMR interface, based on the configuration, indeed the user cannot access the autostart.prop from the Topspin main window. In fact, most of the pull down menu items on the top are disabled automatically.
  • One caveat that needs to be mentioned is this. It takes a few seconds for the autostart.prop to kick in so that IconNMR starts up in earnest. During this period, the topspin window is like a normal window. Nevertheless one cannot prevent IconNMR from starting eventually.  
  • A more serious issue is the following : Until a dataset is open from within ICONNMR, the gui lockdown does not commence.
  • The TOPSPIN gui lock down includes the inability for a user to close the TS window by brute force i.e. by using the 'X' widget on the top right corner of the window. 









Tuesday, August 30, 2011

superuser in Topspin

We know that the NMR superuser is distinct from the login account and at the time of installation, one can choose an existing user in the file system to be the NMR user. More importantly a unique password for the NMR superuser is maintained in a hashed format in the file /opt/topspin/conf/nmradminpassword.   Any time after the installation, you can change the NMR superuser by running /opt/topspin/prog/bin/installnmr. The shell syntax is :

installnmr  "Topspin install path"   "nmrsuperuser .  

Although no 'installation' per se takes place, this script evidently sets file access privileges in the intended manner. The last part of the above statement is under the hood as of now. If I learn more about this I will update the post accordingly.

"setuid = 0 error" : I have been getting the error"seteuid = 0 failed " whenever I start edprosol and the error message asks me to install ICONNMR properly.   What connection does the above has with ICONNMR installation, I don't know. But this error message also continues with the suggestion that " run $TSHOME/prog/bin/installnmr " correctly.

  Indeed, running 'installnmr /opt/topspin nmrsu'  does indeed remove this pop-up error from Topspin, when you start edprosol, for instance.

  Two more  points before we go.

  • If you ever forgot the NMR superuser password, simply delete the file /opt/topspin/conf/nmradminpassword and then run the installnmr script. This will allow you to enter a new password. 
  • Following the ICONNMR related error message, I tried re-installing ICONNMR in one of the instruments.  This step is not warranted to let the popup message go away and in fact I landed myself into another situation.  I started getting 'module go not found' error inside Topspin, when I start an acquisition. This was solved after I did a cf followed by expinstall, edsolve, etc.  The message here is that, it is safer to do a 'cf' after re-installing any part of the software from the distribution medium.   You might end up with some hiccup or other down the road. 









Friday, April 30, 2010

AU compilation Issues - part II

AU compilation for TS 1.3 PL10 solved : 

Even though DRX499 was running only a 32 bit distro, au compilation was failing even after I installed the latest glibc.   The failure was occurring with the linker binary i.e. ld. The Bruker's stock 'ld' did not work for some reason.  The kludge I found in the web is one of two types :

  • Edit the /usr/lib/libc.so.  Change the following phrase : GROUP ( /lib/libc.so.6  /usr/lib/libc_nonshared.a AS_NEEDED ( /lib/ld-linux.so.2 ) ) to  GROUP ( /lib/libc.so.6  /usr/lib/libc_nonshared.a  ). I could confirm indeed that this works.  People out there add a warning to change the phrase back to the original after you are done, since some other application will need this original configuration of libc.so
  • Alternatively, link the /usr/bin/ld  script to the appropriate location within your application.  In my case it is :  $TSHOME/gnu/i686-pc-linux-gnu/bin.  This too does the job. 
But it turns out that Bruker itself provides an elegant alternative to this without messing with the system or the application's distribution.   Here it is :

  • Edit the file $TSHOME/exp/stan/nmr/au/makeau

  • Uncomment the # $opt_native = 1; 

This perl script, which is responsible for handling the 'au' program compilation, then sources  'gcc' as well as the linker scripts from the system's own distro rather than from the $TSHOME/gnu tree.  I could confirm that the compilation proceeds without any issues now.

Tuesday, April 20, 2010

Topspin Display issues and Fedora - in General

I am revisiting a topic that has been already touched upon, but since this seems to be a recurring theme, I am summarizing the remedy to these problems in this post.
For example, look at this xwinplot related post earlier.

The common problem with xwinplot, nmrsim or similar is the fact that, missing display libraries make the said program die quietly.  This makes it impossible either to display a pulse program or start up the plot editor and do your thing.   I had referred to this Bruker bug post earlier, which captures the content of the problem.   The simple take home message that will help us solve this display related problem is this.  In a shell window, run the following (I am using the example of nmrsim here):

/opt/topspin/topspin -e ldd /opt/topspin/prog/mod/nmrsim.mod

You can substitute plot in place of nmrsim.mod if you are trying to troubleshoot the failure of plot module.

Now,  you get a listing of all the shared object libraries that are required and found in your distro. example : libXt.so.6 => /usr/lib/libXt.so.6

If one or more libraries are missing, on the other hand, you see something like this:

libXmu.so.6 => not found
libXpm.so.4 => not found

Your job now is to simply install these missing libraries. In case of Fedora you can simply search for libXpm or libXmu using yum and install them.  Tip:  Just install the i386 or i686.  For Topspin, you don't need the x86_64 libraries any way.  

Now fire up the respective program withing TS viz. nmrsim or plot and confirm that it works.  It did, for me.    You can iterate this procedure for any other modules with which you might have trouble later on.  The message is the same.  You are missing some important shared libraries.  Go find them !

Tuesday, January 12, 2010

Peaceful co-Xistence : XWIN and TS on the same machine

since I still have an incentive to keep the XWINNMR chugging along (since I am still busy putting together the XWIN -> TS transition plan) but on the other hand I do despiiiise the unpatched RHL8.2 (!!) sucking up resources with runaway processes, I wanted to experiment with running XWINNMR on the shiny RHEL 5.4.

I have been making progress, so far. Here is a useful summary of what matters, for future reference :

  • Since XWINNMR and the associated installation suite is matched evenly with the the RedHat 8.2 in antiquity,  there are non-existent locations in RHEL5 such as /usr/lib/X11 that need to be made up.   Refer to my post on how Xwinplot , which also belongs to the same generation as the Xwinnmr itself, was made to work in a RHEL5.4 platform to get a feel for what I am talking about.
  • The Xwinnmr suite has the installation script called startme and this looks for xterm in /usr/X11/bin.  If it is non-existent, it quits. So do this :
    • ln -sf /usr/bin/xterm /usr/X11/bin/xterm
  • If need be, create the directory tree X11/bin under /usr,before creating the link as above.
  • Since running the startme script from CDROM leads to file permission issues (I don't know why), I copied the startme script and two other directories that were on the CDROM to /tmp.    It took a while for me to copy all the contents of the CDROM to /tmp and so there is an additional overhead. But once this was done, the SWIM install interface launched without issues.   When run from CDROM, somehow X complains about   DISPLAY.
  • OS type:  For some reason if the script compalins about non-compatibility of the OS, you can silence the same by doing so:
    • sh ./startme --no-os-check
  • There are several other switches that may be useful on special occassions.  To list them all, do this :
    • sh startme --help-work-around
  • If you have problem bringing up the swim gui, do this :
    • sh startme -d localhost:0.0
The installation proceeded smoothly after this.  Since I already have installed Topspin on this host, I moved the original /usr/diskless to /usr/diskless.TS to avoid the conflict.  Similarly I moved the /usr/local/flexlm tree to a different name to avoid any clashes.

The installation part proceeded quite easily. The problem I am tackling at this point is to make the 24 and 8 bit overlay mode work fine with X11 so that Xwinnmr can render the colors correctly.  I will post  an update on this topic once that issue is sorted out.

Friday, January 8, 2010

Win over the XWINPLOT...

Since XWINPLOT is still a plot editor that belongs to the 'archaea' branch of computer programs, time and again you can end up with the frustration of making peace between the old and the new. One such instance arose when I upgraded the RHEL v4 to RHELv5.4 on DRX499, which runs Topspin 1.3 PL8.

Fortunately, I did not throw away the v4 distro and that saved me a LOT of trouble, as you will see below.

First, when I start the plot command,  the status bar says that plot progam is starting but it silently commits suicide, without leaving a discernible trace. When I captured the hist output (there is no savelogs command here; another of the quirks of TS1.3) and sent it to HQ, Mike Engelhardt forwarded me this Bruker Knowledge base link and said that my problem is similar to the one addressed :

http://www.bruker-biospin.com/shell/bkb/show_bug.cgi?id=8702

Basically this item highlights the fact that how xwinplot dies quietly if some of the needed shared libraries are not found.  In my case, there were two :

libdps.so.1


libdpstk.so.1

This is where the old distro. came in handy. When I located these files in RHELv4 distro., they were sitting under /usr/X11R6/lib.  The lib directory was completely absent in the case of RHELV5.4.

Solution :
  • I copied over the entire directory /usr/X11R6/lib from v4 to the v5.4 distro. Even though the above said libraries were now available, the plot program could not still see these. 
  • Therefore I created a soft link from /usr/X11R6/iib/ for the above two files into /usr/lib/ with identical names.  This solved the problem of plot dying prematurely.  It turns out that, with RHELv5.4 distro, /usr/lib is where the plot program is looking for the libraries. 
  • By the way, the command I used to list out the libraries that were missing is given in the Knowledge Base article : 
topspin -e ldd /opt/topspin/prog/mod/xwinplot.mod

Now plot is working properly and I am also able to print the spectrum, as before.

Before I stumbled onto using the old distro to rummage the files, I tried some web search for the above two library files and the process was ugly, to put it mildly. So, it is a good thing to keep the backward compatible stuff around for a bit, until we iron out all the problems in the migrated system.

Friday, December 11, 2009

tricks and treats..

Here are a few 'postit' type notes that will come in handy. I will keep adding to this list whenever I catch a fish or two to add :

NMRSim installation
  • When you install TS1.3 or TS2.1 in a EL 5 or Fedora 10 like environment, you might get a complaint from NMRSim that it is not able to find : /usr/lib/X11/app-defaults.  Simply do this :
    • ln -sf /usr/share/X11/app-defaults /usr/lib/X11/app-defaults
  • Now reinstall NMRSim and the error will evaporate away.  
curdir and write permisssion :

  • Whenever you install a newer version of TS or XWIN, it often happens that the write permissions for the tree is changed en masse to a given user like nmrsu. It important that many of the directories need to have write access for all users for normal operation, on one hand, but a global write is a bad choice from security viewpoint, on the other.  You can create a separate group for all the NMR users involved and chgrp the tree to that special group and provide write permission for the tree and this is an acceptable solution. 
  • But, there is one directory, i.e. $TSHOME/prog/curdir/$nmruser, for which this does not work i.e. the respective nmruser needs to be the owner of this branch of the tree.  So, you must remember to chown the curdir/$nmruser to nmruser:nmruser for proper fucntioning of TS for that user's login. Also, don't forget the '-R' switch while you do this.
smoking out the port on which the CPRserver is running - the easy way..

  • Let me add that this tip is relevant when you are not  sitting at 'the spectrometer' console. If you are, simply enter hist on command line and find out the port number from there. But, if your spectrometer is in planet Mars and if you are at your desk, travelling back and fro is a bit trying.  That is where this tip becomes quite useful.
  • First of,  ssh into the remote host.
  • Then,
    • cd /opt/topspin/prog/curdir/current TS user
    • cat CPR.ref
  • The text output of CPR.ref will show a string such as :  corbaloc:iiop::5500/CPRMsg
  •  5500 is the port number on which the cpr server is running, according to the above output.
restarting the dataserver 
  • It might  happen that the data tree could not be opened sometimes (in the local TS session). If so, you can enter the command dataserver and this will launch another fresh dataserver thread. You can access the tree then on.
about remote connections 
  • If you are connecting to a remote TS server with a client, you have to make sure that the port into which you are connecting on the server is indeed the port at which the server is listening. To find this out, refer to the "smoking out the port on which the CPRserver is running" above.  If your remote connection is disabled from within Topspin on the remote server, you should enable the same by going to the Preferences - Misc - remote connections section.  You must restart Topspin on the remote server for your connection from a client to succeed.