home *** CD-ROM | disk | FTP | other *** search
- Path: informatik.tu-muenchen.de!lrz-muenchen.de!uni-erlangen.de!news.tu-chemnitz.de!zrz.TU-Berlin.DE!news.uni-ulm.de!rz.uni-karlsruhe.de!blackbush.xlink.net!tank.news.pipex.net!pipex!news.mathworks.com!news-peer.gsl.net!news.gsl.net!news-res.gsl.net!news.gsl.net!portc01.blue.aol.com!newsstand.cit.cornell.edu!news.acsu.buffalo.edu!news.drenet.dnd.ca!crc-news.doc.ca!nott!bcarh189.bnr.ca!nrchh45.rich.nt.com!ferret.ocunix.on.ca!resurrect
- From: andrew@tamarix.demon.co.uk (Andrew Josey)
- Newsgroups: comp.unix.unixware.misc,comp.answers,news.answers
- Subject: UnixWare Frequently Asked Questions (Developer)
- Supersedes: <DvyxIn.1zn@tamarix.demon.co.uk>
- Followup-To: comp.unix.unixware.misc
- Date: Sun, 22 Sep 1996 07:30:24 GMT
- Organization: Home.
- Lines: 2057
- Sender: news@tamarix.demon.co.uk
- Approved: news-answers-request@MIT.EDU
- Expires: Sun, 27 Oct 1996 00:00:00 GMT
- Message-ID: <R.Dy4I6o.zF@tamarix.demon.co.uk>
- NNTP-Posting-Host: localhost
- Summary: Answers to questions frequently asked about SCO's UnixWare SDK
- X-NNTP-Posting-Host: tamarix.demon.co.uk
- X-Newsreader: TIN [version 1.2 PL2]
- Xref: informatik.tu-muenchen.de comp.unix.unixware.misc:17534 comp.answers:21236 news.answers:82330
-
- Reposting article removed by rogue canceller.
-
- Archive-name: unix-faq/unixware/developer
- Posting-Frequency: monthly
- Last-modified: August 11, 1996
- Version: 2.09
-
- UnixWare Frequently Asked Questions (Developer)
-
- This is the Developer section of the UnixWare Frequently Asked Questions
- file maintained on the Internet for the Usenet newsgroup
- comp.unix.unixware.misc. Its maintainer is Andrew Josey
- (andrew@tamarix.demon.co.uk). Suggestions and contributions are always
- welcome.
-
- This document and the other FAQ files may be found on the world wide web
- at http://www.freebird.org/faq/
-
- This document may also be obtained by anonymous ftp from the freebird
- archive at
-
- ftp.freebird.org:/unixware/freebird/hints/FAQ/overview
- ftp1.freebird.org:/pub/mirror/freebird/hints/FAQ/overview
- ftp2.freebird.org:/pub/unixware/freebird/hints/FAQ/overview
-
- Small print: This file is Copyright 1996 freebird.org. Permission is
- granted for copying for non-commercial use. Many proper names of
- companies and software mentioned in these files are trademarks of their
- respective owners. All views are those of the individual contributors
- and not of their employers.
-
- This article is posted monthly around the middle of the month. For more
- information about the files which compose the total UnixWare FAQ, see
- the "FAQ Overview" file posted regularly on the Internet newsgroup
- comp.unix.unixware.misc.
-
-
- INTRODUCTION
-
-
- The Developer section covers aspects of the UnixWare 1.1.x and UnixWare 2.x
- SDK. It also covers general concerns for anyone writing software for the
- UnixWare operating system.
-
-
- TABLE OF CONTENTS
-
- D0) How do I get ahold of UnixWare Developer Support?
- D1) What does the UnixWare 1.1 SDK contain?
- D2) Is there a C++ compiler for UnixWare 1.1?
- D3) What does the UnixWare 2.0 SDK contain?
- D4) Where is the ccs package on UnixWare 2.0?
- D5) Where is the documentation for the UnixWare SDK?
- D6) What books are there on UnixWare programming?
- D7) Where are the man pages for the Standard C functions?
- D8) Are there alternative SDKs to the UnixWare SDK for developers?
- D9) How do I correctly use the UCB compatibility libraries?
- D10) In what library is <undefined symbol> defined?
- D11) In what library is regex() and regcmp() defined?
- D12) In what library is XmbTextListToTextProperty defined?
- D13) What libraries do I need to include for X applications?
- D14) What libraries do I need to include for socket applications?
- D15) How do I compile the sample Motif applications?
- D16) Why do I get memory errors while building applications?
- D17) I don't like the new Motif look and feel, How do I get the old one?
- D18) How come I keep on getting as_dup proc failures?
- D19) How do I get the C compiler to accept C++ style comments?
- D20) How do I increase the number of socket connections for my application?
- D21) How do I run debug on a SUID root program?
- D22) Why do I get Driver without "f" flag not supported?
- D23) Why can't I get my SUID root program to work?
- D24) Why do I get a symbol error in librpcsvc.a on UnixWare 1.1?
- D25) How do I get kdb output to go to a tty?
- D26) Why do I have this library dtruntime.so.1 on UnixWare 2?
- D27) I included all the necessary libraries, why do I still get unresolved
- symbols?
- D28) How come I can't get some Motif keyboard mappings to work?
- D29) Why do I get a bad Makefile from xmkmf on UnixWare 2.0?
- D30) How do I get cc to place object files in specific directories?
- D31) Why does the open() call block when I try opening the serial port device?
- D32) How do I compile tin?
- D33) How do I compile emacs?
- D34) How do I compile Perl 5.001?
- D35) Where can I get audio software for UnixWare ?
- D36) Where can I get the GNU debugger (gdb) for UnixWare 2?
- D37) How can I debug an application without the source code?
- D38) When I link I can 't find the syslog routines, what should I do?
- D39) When I link I can 't find the strcasecmp routine?
- D40) When I link I can 't find the alloca routine?
- D41) How do I make a pkgmk add-on package?
- D42) How to build binaries on UnixWare to run on other SVR4 systems such
- as Solaris x86?
-
-
- Subject: D0) How do I get ahold of UnixWare Developer Support?
-
- The SCO Developer programme can be reached on 1-800-SCO-UNIX in North America,
- for the UK and International customers call SCO on +44 1923 816344.
-
- As a member of the developer programme you get 5 free technical support
- questions among other benefits - see http://www.sco.com/Developers
- for info on the Developer programmes.
-
- Subject: D1) What does the UnixWare 1.1 SDK contain?
-
- 1) C compiler
- 2) Enhanced Graphical debugger
- 3) Motif development tools (sorry, no GUI builder).
- 4) Network client/server developer tools {so what's new :-) }.
- 5) Online documentation through Fingertip Librarian.
- 6) Driver development tools including sample driver source.
- 7) Windowing Korn Shell
- 8) Software Packaging Tools
- 9) Kernel Debugger
-
- Subject: D2) Is there a C++ compiler for UnixWare 1.1?
-
- (Note the ordering information needs to be updated in the
- light of the transfer of the UnixWare business to SCO ,
- that information has been requested).
-
- The C++ Compilation System 2.0 for UnixWare 1.1 is available for the
- suggested retail price of U.S. $99 in CD ROM and QIC-24 tape formats.
- To order in the U.S. or Canada, call 1-800-457-1767 or fax (317)
- 364-8888. Outside North America, call +31-55-384279 or fax
- +31-55-434455.
-
- Subject: D3) What does the UnixWare 2.0 SDK contain?
-
- 1) C++ compiler with templates (C compiler is part of the AS and PE)
- 2) Enhanced Graphical debugger
- 3) Motif development tools (sorry, no GUI builder).
- 4) Network client/server developer tools {so what's new :-) }.
- 5) Online documentation through Dynatext.
- 6) Driver development tools including sample driver source.
- 7) Integrated window development tools
- 8) Software Packaging Tools
- 9) Kernel Debugger
- 10) Enhanced performance tools and profilers
- 11) Multithreaded application development
-
- Subject: D4) Where is the ccs package on UnixWare 2.0?
-
- The ccs package is no longer a part of the UnixWare SDK, but instead has
- been included on the UnixWare AS and PE media. This is to facilitate
- support for third- party SDKs and other software such as databases that
- need the C compiler present to function. Even though this does give you
- the C compiler, it does not give you all the components of the SDK such
- as the debugger, include files, and miscellaneous static libraries. So
- for a full development environment, an SDK is still considered
- essential.
-
- Note that you need to install the ccs package from your AS or PE media prior to
- installing the SDK, or YOU WILL NOT be able to install the C++ compiler.
-
- Subject: D5) Where is the documentation for the UnixWare SDK?
-
- UnixWare 2.01 includes all the UnixWare SDK documentation and provides
- it through the online documentation system of UnixWare 2.01. Printed
- versions of the SDK Documentation are available in English only from:
-
- Hart Graphics for the Novell Fulfillment Department
- P.O. Box 141805
- Austin, TX, USA 78714-9783
-
- Or courier to:
-
- Hart Graphics for the Novell Fulfillment Department
- 3106 Longhorn Blvd.
- Austin, TX, USA 78758
-
- Country Voice FAX
- Australia 0014-800-128-411 0014-800-124-233
- Canada 1-800-366-3892 1-800-826-5399
- Singapore 800-1100-073 800-1100-088
- U.S. 1-800-336-3892 1-800-826-5399
- All others U.S. Country Code U.S. Country Code
- +512/834-6905 +512/834-8901
-
- Group 6 Basic Software Development US$ 125.00
- Group 7 Networking Development US$ 95.00
- Group 8 Windowing Development US$ 95.00
- Group 9 C++ Development US$ 55.00
- Group 10 IHV Development (drivers) US$ 115.00
- Group 11 OSAPI Reference US$ 95.00
- Group 12 NetWare Lib. Ref. for C US$ 125.00
- Group 13 Motif Reference Manual US$ 75.00
- Group 14 Additional SDK Reference US$ 75.00
-
- Note: These prices do not include Shipping & Handling, or Tax.
-
- Subject: D6) What books are there on UnixWare programming?
-
- No UNIX programmer should be caught without the Stevens books:
-
- Advanced Programming in the UNIX Environment
- W. Richard Stevens
- Addison-Wesley, 1992
- ISBN 0-201-56317-7
-
- UNIX Network Programming
- W. Richard Stevens
- Prentice Hall, 1990
- ISBN 0-13-949876-1
-
- Donald Lewine's POSIX programming guide is also indispensable as a
- reference for "which standard defines what API?" kind of questions:
-
- POSIX Programmer's Guide
- Donald Lewine
- O'Reilly and Associates, Inc.
- ISBN 0-937175-73-0
-
-
- Subject: D7) Where are the man pages for the Standard C functions?
-
- UnixWare 1.1:
-
- Kevin Brannen (kbrannen@metronet.com) has become UnixWare's "Master of
- Man Pages":
-
- First, make sure you've gone thru the "Guide to Fixing Man". (I've sent
- Martin a note asking him to talk to Andrew Josey about putting my "Guide
- to Fixing Man" on the mail-server there at novell.co.uk.)
-
- Now do "apropos command" or "man -k command", you should see the
- topic to do a man on. For example, "man strchr" returns:
-
- No manual entry for strchr.
-
- So do "apropos strchr", which returns:
-
- string: strcat, strncat, strcmp, strncmp, strcpy, strncpy, strdup,
- strlen, strchr, strrchr, strpbrk, strspn, strcspn, strtok,
- strstr (3C) - string operations
-
- which tells you that you should do "man 3c string". Famous groupings
- that hide a lot of functions but which have no corresponding function are:
- string, memory, directory, trig, and exec.
-
-
- UnixWare 2.0:
-
- I just use the man -k command.
-
-
- Subject: D8) Are there alternative SDKs to the UnixWare SDK for developers?
-
- Yes, there are many options, and the number is increasing. The first
- option developers generally try is using the GNU gcc compiler and other
- GNU tools. The GNU tools are available from several sources. The first
- place to try is ftp.freebird.org or any of its mirror sites. Here you can
- get packaged binaries. The second is to get them from a CD-ROM
- distribution such as the Prime Time Freeware Tools and Toys for UnixWare
- or the Walnut Creek SVR4 (UnixWare) CD-ROM. These CDs include many
- useful utilities that any developer would find handy. The third is to
- get source from the Free Software Foundation or any of the many CD-ROMs
- and build the binaries yourself.
-
- Scott Raney <raney@metacard.com> writes:
-
- MetaCard is a complete GUI development environment that includes a
- graphical interface builder and a high-performance VHLL (Very High
- Level Language). With MetaCard both novice and professional
- developers can build graphical applications more rapidly than is
- possible with other tools. Email info@metacard.com or see
- http://www.metacard.com for more information.
-
- There are many third party compilers available for UnixWare, and if the
- vendors contact me I will include them in the FAQ.
-
- Subject: D9) How do I correctly use the UCB compatibility libraries?
-
- There are two problems that are typically encountered when
- compiling/linking code that uses Berkley-isms:
-
- * Undefined symbols at link time
- * Incompatibilities between the SysV header files and the UCB libraries
-
- C code using Berkley-isms such as index/rindex will generate "undefined
- symbol" messages for each of the BSD-specific functions. To get around
- this, you have one of two options:
-
- * Option A: Straight UCB compile
-
- Compile with the "UCB" compiler (/usr/ucb/cc). This is actually a shell
- script wrapper around the standard C compiler (/usr/ccs/bin/cc) that
- sets up the necessary #include and library paths. This is the path to
- take if you want a more "pure" BSD environment for your development.
-
- * Option B: SysV compile with Berkeley extensions
-
- If you want a SysV environment, but need to link in some functions
- only available in the BSD library (eg, you'll replace gethostname() with
- uname() later), simply link in the UCB libraries _after_ the standard
- (SysV) libraries. For example:
-
- cc -o foo foo.c -lc -L /usr/ucblib -lucb
-
- Note the order of the library specifications, and that "-lc" should
- precede the UCB library specification to resolve all possible synonyms
- against the SysV library, rather than the BSD library.
-
- Be careful exercising option (b), however. Merely linking against the
- UCB library, without the preceding "-lc", will cause code to be compiled
- against the SysV #include files (located in /usr/include) and then
- linked against the UCB libraries:
-
- cc -o foo foo.c -L /usr/ucblib -lucb # Don't do this
-
- (Note that an implicit "-lc" is appended to the command line.)
- Differences in such things as structure sizes between the SysV #includes
- and the UCB libraries can wreak all kinds of havoc - as Jim Vlcek
- discovered in just this fashion when trying to use setjmp in a source
- module that also called some UCB functions. One way to get around this
- is to insert a "-I /usr/ucbinclude" directive into the command line, but
- this is essentially the effect of using /usr/ucb/cc.
-
-
- Gordon W. Ross <gwr@mc.com> wrote:
-
- I just wanted to mention here that most people I have helped with
- porting problems related to the dirent or directory libraries have
- caused their own problems by incorrectly using the UCB library.
- The directory(3) routines in the UCB library only work with the
- header files in /usr/ucbinclude so if you fail to put that in
- your include path and just link with -lucb you end up with
- seriously broken programs. The stuff in /usr/ucbinclude/ and
- /usr/ucblib/ was meant to be used by /usr/ucb/cc only, and
- when used that way it (mostly) works. I have usually found it
- easiest to just stay away from the UCB library entirely.
- I would advise others to do the same. (The UCB library has
- well known problems in signal and some dbm functions.)
-
- Robert Withrow (witr@rwwa.com) wrote:
-
- In addition, checking the following things will almost always yield a
- working port for any reasonably `well behaved program':
-
- 1 Replace bcopy et.al with the apropriate memcpy functions...
-
- #define bcopy(b1,b2,len) memmove((b2), (b1), (size_t)(len))
- #define bzero(b,len) memset((b), 0, (size_t)(len))
- #define bcmp(b1,b2,len) memcmp((b1), (b2), (size_t)(len))
-
- 2 Replace index and rindex approprately:
-
- #define index(a,b) strchr((a),(b))
- #define rindex(a,b) strrchr((a),(b))
-
- 3 Don't use the SVR4 library's signal() routine,
- [use sigaction instead ...]
-
- /* Reliable signals */
- /* This was taken from Stevens... */
-
- #include <signal.h>
-
- typedef void Sigfunc(int);
-
- Sigfunc *signal(int signo, Sigfunc *func)
- {
- struct sigaction act, oact;
-
- act.sa_handler = func;
- sigemptyset(&act.sa_mask);
- act.sa_flags = 0;
- if (signo != SIGALRM) {
- act.sa_flags |= SA_ESTART;
- }
- if (sigaction(signo, &act, &oact) < 0)
- return(SIG_ERR);
- return(oact.sa_handler);
- }
-
- 4 Replace random with lrand
-
- #define random() lrand48()
- #define srandom(seed) srand48((seed))
-
- 5 Replace the bsd readdir code with the Posix code (requires changing an
- include file and a declaration usually, but also perhaps a symbol with a
- strlen.)
-
- 6 Replace wait3 and wait4 with posix wait code. This is complicated
- because some code *writes* into the values that posix only provides read
- access to.
-
-
- Rick Richardson (rick@digibd.com) wrote:
-
- Its much easier to port stuff than most people think.
-
- I've found that 99.99% of applications with BSDisms can be ported
- by simply compiling normally, but linking with -lc -lucb. This
- resolves the SVR4 C library first, avoiding problems with dirent
- and the like, but also lets you pick up any BSD-isms like
- random(), index(), etc.
-
- Really, its painless.
-
- Other advice for porting applications :
-
- What to use instead of gethostname, getdtablesize, getpagesize?
-
- (a) gethostname
-
- This can be replaced by using the sysinfo(2) routine.
-
- #include <sys/systeminfo.h>
-
- ....
-
- char buf[MAXHOSTNAME];
-
- /* BSD code was: */
- /* if (gethostname(buf, sizeof(buf)) < 0) { */
-
- if (sysinfo (SI_HOSTNAME, buf, sizeof(buf)) < 0) {
- perror("SI_HOSTNAME);
- exit(ERROR);
- }
-
- (b) getdtablesize
-
- This can be replaced by the sysconf(2) routine
-
- #include <unistd.h>
-
- ....
- long tablesize;
-
- #ifdef _SC_OPEN_MAX /* POSIX define*/
- tablesize = sysconf (_SC_OPEN_MAX);
- #else /* BSD code */
- tablesize = getdtablesize();
- #endif
-
- (c) getpagesize
-
- This can be replaced with a call to sysconf(2)
-
- #include <unistd.h>
-
- ....
- long pagesize;
-
- #ifdef _SC_PAGE_SIZE /* X/Open define*/
- pagesize = sysconf (_SC_PAGE_SIZE);
- #else /* BSD code */
- pagesize = getpagesize();
- #endif
-
-
-
-
- Subject: D10) In what library is <undefined symbol> defined?
-
- The command 'nm' can be used to examine the contents of library files,
- or use the following script to automate the process.
-
- --- Cut here and save to "who_defines", then "chmod +x who_defines"---
- #!/bin/sh
- if [ $# -ne 1 ]
- then
- echo "Usage: who_defines function_name" >&2
- exit 1
- fi
-
- # You may need to add library directories to this list.
-
- LIBDIRS="
- /usr/lib
- /usr/ccs/lib
- /usr/X/lib
- /usr/ucblib"
-
- for dir in $LIBDIRS
- do
- for lib in $dir/*.a $dir/*.so
- do
- if [ -r "$lib" ]
- then
- nm -px $lib | sed -n '/T \<'$1'\>/p' 2>/dev/null |
- while read ans
- do
- echo $lib:$ans
- done
- fi
- done
- done
- --- End of "who_defines" ---
-
-
- To determine where a symbol (eg, bind) is defined:
-
- % who_defines bind
- /usr/lib/libsocket.a:0x000000c0 T bind
- /usr/lib/libsocket.so:0x00008050 T bind
-
- Note that, as above, you will often get multiple answers. Here, we see
- that bind itself is in the socket directory (the .a and .so are the
- static and dynamic libraries, respectively). The library name is the
- path that precedes the colon; your ld command line should thus include
- the entry:
-
- -lsocket
-
-
- Subject: D11) In what library is regex() and regcmp() defined?
-
- The functions regex() and regcmp() are located in the general function library
- /usr/ccs/lib/libgen.a and can be included by using the option -lgen to cc.
-
- Subject: D12) In what library is XmbTextListToTextProperty defined?
-
- This function as well (as the function XmbTextPropertyToTextList()) is
- defined in the library /usr/X/lib/libXIM.so on UnixWare 1.1. This
- should not be a problem on UnixWare 2.0.
-
- Subject: D13) What libraries do I need to include for X applications?
-
- This is how the sample application periodic was linked:
-
- $ cc -o periodic periodic.o -O -Xa -T 0x8300000 -L//usr/X/lib
- /usr/X/lib/libMrm.so /usr/X/lib/libXm.so -lXt -lXext -lX11 -lgen -lnsl
- -z nodefs
-
-
- Subject: D14) What libraries do I need to include for socket applications?
-
- Socket applications need to include the sockets library and the
- networking support library:
-
- $ cc -o foo foo.c -lsocket -lnsl
-
- Subject: D15) How do I compile the sample Motif applications?
-
- The simple way to compile one of the sample Motif applications is to
- first copy it to some local working directory to avoid permission errors
- on the files:
-
- $ cp -r /usr/X/lib/motifdemos/periodic periodic
-
- Then cd into the periodic directory:
-
- $ cd periodic
-
- Run xmkmf to convert the Imakefile into a Makefile (See D29 first):
-
- $ xmkmf
- imake -DUseInstalled -I/usr/X/lib/config
-
- Then run make:
-
- $ make
- /bin/rm -f periodic.o
- cc -c -O -Xa -I. -I./X11 -I./X11 -I///usr/X/include -I///usr/X/include/X11
- -I/usr/include -I//usr/X/include -I. -DSVR4 -DSYSV386 -DI18N
- -DFUNCPROTO=15 -DNARROWPROTO -DLIBDIR=\"/usr/X/lib\"
- -DDESTDIR=\"/usr/X\" periodic.c
- /bin/rm -f periodic
- cc -o periodic periodic.o -O -Xa -T 0x8300000 -L//usr/X/lib
- /usr/X/lib/libMrm.so /usr/X/lib/libXm.so -lXt -lXext -lX11 -lgen -lnsl -z nodefs
-
- Then run:
-
- $ ./periodic
-
- Subject: D16) Why do I get memory errors while building applications?
-
- The first potential problem is running into user process limits which
- are controlled by the following tunables:.
-
- SDATLIM
- HDATLIM
- SSTKLIM
- HSTKLIM
- SVMMLIM
- HVMMLIM
-
- These may need to be increased so that enough memory resources are available to
- build very large applications.
-
- The second potential problem could be a lack of swap space. This can be
- checked by using the swap command. Remember that swap is a dynamic
- thing so just running the swap command after a failed compile does not
- tell the story of what is happening during the compile. On UnixWare 2,
- you can use the real time performance monitor (rtpm) or the GUI System
- Monitor to watch what is going on. More swap can be added by swapping
- to a file which should be covered in the administration FAQ.
-
- On UnixWare 2.0, there is also the possibility that you are running out
- of /tmp file space since this defaults to a memfs. Since the compiler
- heavily uses /tmp, this filesystem may need to be increased by editing
- the /etc/vfstab file entry for /tmp, or not using a memfs for /tmp at
- all.
-
- Subject: D17) I don't like the new Motif look and feel, How do I get the old
- one?
-
- Some developers have expressed the desire to have Motif version 1.2.3
- under UnixWare 2.0 have the older look and feel of Motif version 1.2.2.
- Following is a developers note:
-
- > ... the look and feel of the XmToggleButton
- > is vastly different under UW 2.0 than those of the standard
- > Motif version. The XmToggleButton in radio mode is a round
- > circle instead of the standard diamond shape. The non-radio
- > mode XmToggleButton displays a check mark inside the square
- > under UW 2.0. IMHO this is ugly.
-
- This is the standard look and feel for CDE. Sun, HP, IBM, DEC, Novell,
- Fujitsu, Hitachi, and other vendors are or will soon be shipping this
- same Motif (same source code). While UnixWare 2.0 does not include the
- CDE desktop, it does include the CDE Motif implementation.
-
- Furthermore, this user interface design change was in response to
- _significant_ user complaints about the old look. Hundreds of users have
- complained that the old visuals were not visibly distinctive, leaving
- them unsure which toggles were set and which were not. The new visuals
- are decidedly better, in the humble opinion of customers, user interface
- designers, and the vendors shipping CDE.
-
- > The question I have is
- > WHY OH WHY did Novell do this type of thing? The Motif look
- > and feel is supposed to be standard across all platforms.
- > What Novell did to Motif is gratuitous, and a disservice to
- > the efforts of a standard.
-
- Nope, just the opposite. We participated in the standards activities
- that lead to this change.
-
- In any case, one can get the old look (diamonds, no-checks) by setting
- these resources:
-
- *enableToggleVisual: false # use the diamond/empty-square visuals
- *enableToggleColor: false # use "select" color, instead of highlight color
-
- This will restore the original, hard-to-distinguish visuals.
-
- The complete set:
-
- *enableToggleVisual: {true|false}
- # use the diamond/empty-square visuals
-
- *enableToggleColor: {true|false}
- # use "select" color, instead of highlight color for selected toggles
-
- *enableBtn1Transfer: {button2_transfer|true|false}
- # true == Button 2 is ADJUST, Button 1 is TRANSFER
- # button2_transfer, Button 2 is TRANSFER, Button 1 is drag
- and drop
-
- *enableButtonTab: {true|false}
- # TAB moves among pushbuttons in tab groups, e.g.
- Apply/Reset/Cancel
-
- *enableDefaultButton: {true|false}
- # shows button highlight inside the default-ring on the default
- button
-
- *enableDragIcon: {true|false}
- # uses better default icons (visuals) for drag and drop
-
- *enableEtchedInMenu: {true|false}
- # shows menu buttons as "pressed in" rather than "pushed out"
-
- *enableMenuInCascade: {true|false}
- # can use the Button 3 to pull down menus on menu bars
-
- *enableMultiKeyBindings:{true|false}
- # enable use of additional key bindings (e.g. Sun's
- Cut/Copy/Paste)
-
- In all cases, a value of "false" gets the original (old) Motif behavior.
- For UW 2.0, the default .Xdefaults file gives "true" for all these,
- except the third ("button2_transfer").
-
- Subject: D18) How come I keep getting as_dup proc failures?
-
- UnixWare 1.1:
-
- These errors are generally caused by memory problems (as opposed to
- newproc pid_assign errors, which are generally due to low values of the
- NPROC and MAXUP tunables). These errors could be caused by insufficient
- RAM, swap space or by processes which take up too much memory.
- Processes which do many time calls may be prone to the localtime memory
- leak and might get very large and thus take up a lot of memory. Also,
- processes which do successive mallocs and frees may be prone to a
- problem with free (where memory does not get correctly returned to the
- system) and may also get very large and use too much memory.
-
- To find whether there are processes running which have grown too large,
- enter:
-
- ls -l /proc
-
- This will list all processes (by pid) and how much memory they take.
-
- Aside from adding more RAM or swap, if there are processes which are
- taking up an inordinately large amount of memory, try applying PTF174
- (localtime memory leak) and/or PTF161 (problem with free). These ptf's
- contain updates to shared object libraries and thus they should be able
- to be applied to the run-time system. The app should not have to be
- re-compiled.
-
- NOTE: ptf174 is contained in Update 1.1.3.
-
- UnixWare 2.0:
-
- I have never heard of anyone getting this under UnixWare 2.0, but the
- same memory problems would be at fault.
-
- Subject: D19) How do I get the C compiler to accept C++ style comments?
-
- By supplying the following options on the cc command line, you can get
- cc to accept C++ style comments:
-
- cc -W0,-B foo.c
-
- Subject: D20) How do I increase the number of socket connections for my
- application?
-
- UnixWare 1.1:
-
- To do this you first must edit the /etc/conf/sdevice.d/sockmod system
- file and increase the number in the third field. Normally this defaults
- to 128. The system maximum for this is about 256 connections due to a
- limitation in the library libc.so. After this value has been increased,
- the kernel must be rebuilt and the system rebooted. Also, the kernel
- tunable NUMTIM might need to be increased to allow for the greater
- number of streams modules required by the socket interface. For every
- socket connection opened there is an associated file descriptor. If the
- user executes the command 'ulimit -a' he/she will see that this defaults
- to 64. In order to get more than 64 connections the associated tunables
- SFNOLIM and HFNOLIM must be increased. Because of the limitations in
- the library libc that were described previously, there isn't much need
- to increase this beyond 256. There is an upper limit to the number of
- connections allowed due to kernel memory allocation limitations. Kernel
- memory must exist in the less than 16MB memory range due to
- historical/architectural reasons. This means that the kernel image,
- drivers, and kernel buffers (including streams buffers) live in the less
- than 16MB memory range. This creates the limitation on the number of
- connections based on how much memory can be acquired to maintain these
- connections. This has implications for machines with less than 16 MB of
- RAM, i.e., more RAM may be necessary to increase the number of
- connections. I was successful in getting 197 socket connections, and
- had a developer get around 230.
-
- Now with the number of connections increased, if the applications being
- run are things such as telnet or ftp, the /etc/inet/inetd.conf
- configuration needs to be such that the required number of server
- daemons can be started such as in.telnetd or in.ftpd.
-
- Note: after the initial release of this TID, I have had some developers
- in Novell USG state that they believe there should not be a limitation
- in the number of connections through libc. So it may be possible to
- increase this to a value greater than 256.
-
- UnixWare 2.0:
-
- There are several causes that lead to not having enough socket connections:
-
- 1) The ulimit values may be limiting the number of open files allowed.
- 2) For UNIX Domain sockets, the third field in
- /etc/conf/sdevice.d/ticots is set too low.
-
- 3) For Internet Domain sockets, the third field in
- /etc/conf/sdevice.d/tcp is set too low.
-
- First, increase the number of open files a process is allowed to have by
- tuning the SFNOLIM system tunable. This can be done using the System
- Tuner in the Admin_Tools folder on the desktop. (This value can also be
- increased temporarily by typing "ulimit -n unlimited" as root.)
-
- Second, for UNIX Domain sockets, increase the number in the third field
- of /etc/conf/sdevice.d/ticots. Rebuild this module by typing "idbuild
- -M ticots". For Internet Domain sockets, increase the number in the
- third field of /etc/conf/sdevice.d/tcp. Rebuild this module by typing
- "idbuild -M tcp".
-
- Reboot the system.
-
- Note: For this I increased the values to 1024, there appears to be no
- upper limit on how many connections there can be.
-
- Subject: D21) How do I run debug on a SUID root program?
-
- When trying to run debug on a setuid program, the following error
- message appears:
-
- System error attempting to control process <pid>
- Create failed: all resulting processes killed
-
- This happens whether debug is run by the program owner (usually root) or
- not. debug cannot be run by someone other than the program owner
- (usually root) because then the person running the program could make
- modifications to the program which are not explicitly allowed by
- setuid.
-
- The graphical version of debug cannot be run by the program owner
- (usually root) because this person is generally not the same person
- whose desktop debug will try to display on. By default, X does not
- allow one user to display windows on another person's desktop.
-
- To run the graphical version of debug on a setuid program:
-
- 1) xhost +
-
- (This allows other users to display windows on your desktop).
-
- 2) su to the person who owns the setuid program.
-
- 3) run debug on the program.
-
- Subject: D22) Why do I get Driver without "f" flag not supported?
-
- This driver probably has a version 0 Master file and does not have an
- "f" in the characteristics field (see man (4) Master). This means that
- this driver is not a DDI/DKI compliant driver, and thus will not work on
- UnixWare 2.0.
-
- The solution is to modify the driver to be DDI/DKI compliant. This will
- also guarantee that the driver will work on future releases of UnixWare.
- Consult the Device Driver Reference Manual (DDI/DKI) in the Dynatext
- Browser. It gives good detail on what is needed to be compliant, what
- is supported, and what is not supported.
-
- NOTE: We stated that UnixWare 1.1 drivers will run on UnixWare 2.0.
- The actual situation is that DDI/DKI compliant 1.1 drivers (drivers
- written for 1.1) will work on 2.0. The problem is that 1.1 supported a
- lot of older driver interfaces, but this support is not in 2.0.
- Developers need to become DDI/DKI compliant.
-
- Subject: D23) Why can't I get my SUID root program to work?
-
- The common situation is that a developer has a SUID application (The
- effective user ID bit set) for a root owned application and it is unable
- to locate dynamic libraries at runtime. The error would be something
- like:
-
- dynamic linker : xapplication : error opening libX11.so
- Killed
-
- This is common if the SUID root application is an X application.
-
- This is a deliberate action to prevent a problem with security. If the
- dynamic linker did not cause this to break on SUID programs a potential
- security hole would occur. The security hole would be in the form that
- the SUID program would use the LD_LIBRARY_PATH to search for dynamic
- libraries needed. In a SUID program that path must be static. If the
- library were located using the LD_LIBRARY_PATH then a user could
- potentially create his own library that mimics a well known library.
- This "imposter" library could have a deliberate security hole in it.
- When the application tried to locate a library such as libX11.so and
- went to the user's imposter library by using the LD_LIBRARY_PATH, the
- security would have been compromised since the application may be owned
- by root.
-
- To prevent this security problem, SUID applications must have the path
- to all libraries statically included. To do this the developer needs to
- set the LD_RUN_PATH to point to all libraries needed by that application
- prior to linking. By default SUID applications search for libraries in
- /usr/lib, but if the application is an X application, all the X
- libraries are in /usr/X/lib and these libraries would not be located if
- the LD_RUN_PATH environment variable was not set prior to linking.
-
- Subject: D24) Why do I get a symbol error in librpcsvc.a on UnixWare 1.1?
-
- This library has a symbol table problem. When trying to link to the library
- librpcsvc.a, the developer gets an error that this library is corrupt.
-
- This library can be fixed by running the 'ar' command on it as root.
-
- # ar -sr /usr/lib/librpcsvc.a
-
- Subject: D25) How do I get kdb output to go to a tty?
-
- The kdb command 'newterm' will let you change a kdb session to a tty.
- All subsequent kdb sessions will then go to this same tty. Just make
- sure there is a ttymon active on the tty before you do this.
-
- The syntax on UnixWare 2.0 is "newterm <driver> <minor #>", so for
- example "newterm iasy 2" will send output to /dev/tty01. For UnixWare
- 1.1 the syntax is a little different, but the effect is the same.
-
- Another option which will force all console output to another device is
- to edit the /stand/boot file and use the console parameter to indicate
- another device. See the man page for boot(4) for parameter details and
- the man page for boot(1) for information on the boot file itself.
-
- Subject: D26) Why do I have the library dtruntime.so.1 on UnixWare 2?
-
- Developers have noticed that several of the standard X libraries are
- symbolically linked to the library /usr/X/desktop/dtruntime.so.1. What
- is the reasoning behind this?
-
- The reason for this library is as follows:
-
- 1) dtruntime is a library that is the combination of many of the X libraries
-
- 2) This was done to speed up X programs. It accomplishes this 2 ways: the
- run-time linker has to do much, much less work at startup to resolve
- symbols and locality tuning is more effective on one large object (as
- opposed to many small ones) since there is a high correlation between
- references to multiple libraries (e.g. Xtfunc always calls Xfunc).
-
- 3) There is no wasted space on a run-time system (a system with no SDK).
- Simply, many libraries are link-edited to one and links are made to the
- individual names. On a system with the SDK installed, 3 MB is wasted,
- since we can't link the run-time libraries to the build libraries (i.e.
- ZZZ.so.1 -> ZZZ.so).
-
- 4) Any programmer who uses the SDK will not see dtruntime unless he/she is
- doing ls's around /usr/X (see #5).
-
- 5) One's binaries still say that the program requires libXt.so.5.0 to run.
- It just happens to be that on our system, this file is a link to
- dtruntime.
-
- In fact, we took great effort in not "exposing the implementation"
- so that executables will never be dependent on dtruntime and the ABI
- is not violated.
-
- 6) Some have commented "what a hack".
-
- This is, actually, an unhack. Novell realized that the illusion
- of separate libraries was just that . . . so we put them together. The
- beauty of the idea is that we can unlink the libraries at any time if
- there was a reason to do so (see #5).
-
- Subject: D27) I included all the necessary libraries, why do I still get
- unresolved symbols?
-
- Some developers have noticed that while linking an application on
- UnixWare with the correct libraries, they still get unresolved symbols.
- The libraries are even verified with the 'nm' command to contain the
- needed symbols.
-
- It has been noted that how files are specified on the cc command line
- affects what libraries are searched and included.
-
- The following command line will not work:
-
- $ cc -lsocket -lnsl -lgen -o main.o main.c
-
- Where this one will:
-
- $ cc -o main.o main.c -lsocket -lnsl -lgen
-
- Note that the libraries must be specified last. The reason for this is
- because the first few options go to the C compiler, where the last
- options go to the linker. Before someone states that this is broke,
- this is actually done to be SVID/ABI compliant.
-
- Subject: D28) Why can't I get some Motif keyboard mappings to work?
-
- A Developer had an application that remapped keys on the keyboard in the
- defaults file located in /usr/X/lib/app-defaults under UnixWare 1.1.3
- and it worked fine. When moved to UnixWare 2.01, the application can no
- longer map the keys correctly.
-
- The problem here is that in going from UnixWare 1.x to UnixWare 2.x the
- Motif library changed from 1.1 to 1.2. With this library change, the
- concept of Virtual Key bindings was introduced which adds a level of
- abstraction between actual Key events and what applications act on.
- Client side generated osfXXX key events are then translated to actual
- key events at the Server level.
-
- When an application overloads Raw Key events, there's no guarantee that
- Motif will not overload those.
-
- In a test program I was able to overload <Key>Home and <Key>End with no
- problem but could not overload <Key>Insert. Changing the <Key>Insert to
- <Key>osfInsert worked fine. In general the application should overload
- the osfXXX events instead.
-
- The developer needs to modify the translation table to overload
- <Key>osfInsert <Key>osfBeginLine and <Key>osfEndLine instead of the
- <Key>Insert, <Key>Home and <Key>End translations.
-
- Subject: D29) Why do I get a bad Makefile from xmkmf on UnixWare 2.01?
-
- During the building of periodic in the /usr/X/lib/motifdemos/periodic
- directory, I get these problems:
-
- $ cd periodic
- $ ls -l
- total 130
- -r--r--r-- 1 darrend other 984 Jun 22 10:50 Imakefile
- -r--r--r-- 1 darrend other 1127 Jun 22 10:50 Periodic.ad
- -r--r--r-- 1 darrend other 18137 Jun 22 10:50 periodic.c
- -r--r--r-- 1 darrend other 35962 Jun 22 10:50 periodic.uil
- -r--r--r-- 1 darrend other 7381 Jun 22 10:50 periodic_local.uil
- $ xmkmf
- imake -DUseInstalled -I/usr/X/lib/config
- $ make
- /bin/rm -f periodic.o
- cc -c -O -Xa -I. -I./X11 -I./X11 -I///usr/X/include -I///usr/X/include/X
- 11 -I/usr/include -I//usr/X/include -I. -DSVR4 -DSYSV386 -DI18N
- -DFUNCPROTO=15
- -DNARROWPROTO -DLIBDIR=\"/usr/X/lib\" -DDESTDIR=\"/usr/X\" periodic.c
- /bin/rm -f periodic
- cc -o periodic periodic.o -O -Xa -T 0x8300000 -L//usr/X/lib ./lib/Mrm/
- libMrm.so ./lib/Xm/libXm.so -lXt -lXext -lX11 -lgen -lnsl -z nodefs
- UX:ld: ERROR: ./lib/Mrm/libMrm.so: fatal error: cannot open file for reading
- *** Error code 1 (bu21)
- UX:make: ERROR: fatal error.
- $
-
- It appears that the Motif templates file in /usr/X/lib/config is
- incorrect. You can get imake or xmkmf to work correctly if you fix the
- file /usr/X/lib/config/Motif.tmpl with the following corrections.
-
- Change:
- MTOOLKITSRC = $(LIBSRC)/Xt
- MWIDGETSRC = $(LIBSRC)/Xm
- MRESOURCESRC = $(LIBSRC)/Mrm
-
- To:
- MTOOLKITSRC = /usr/X/lib
- MWIDGETSRC = /usr/X/lib
- MRESOURCESRC = /usr/X/lib
-
- I suggest that you comment out the old lines like this:
- /* MTOOLKITSRC = $(LIBSRC)/Xt */
- /* MWIDGETSRC = $(LIBSRC)/Xm */
- /* MRESOURCESRC = $(LIBSRC)/Mrm */
-
- Note also that you will get a permissions error if you try to build this
- application in that directory. I suggest making a local copy, as root
- does not have the necessary environment for building this application
- (No X references).
-
- Subject: D30) How do I get cc to place object files in specific directories?
-
-
- Developers using the C compiler cc need to place object files in
- specific directories. Note that this feature is supported by some third
- party compilers, e.g.
-
- $ cc -c darren.c -o /tmp/darren.o
-
- The SVID definition states that the -o option only applies to the
- linker. Since using the -c option means the linker is never called,
- this option will not work.
-
- There is a workaround using the -Wa option to the compiler (see the cc
- man page.)
-
- $ cc -c darren.c -Wa,'-o/tmp/darren.o'
-
-
- Note that I did not put a space after the -o option.
-
- Subject: D31) Why does the open() call block when I try opening the serial port
- device?
-
- The general symptoms of this problem are:
-
- 1) I try to open the serial port device and the open() call blocks.
-
- 2) How can I bypass this insistence on having a modem carrier when I am not
- talking to a modem?
-
- 3) I don't want O_NOBLOCK behavior for my serial device.
-
-
- One solution involves making a special serial cable as follows:
-
- You could loop 6, 8 and 20 at the Unix end to assert DCD.
-
-
- Another solution involves opening the driver non-blocking. There is an
- O_NDELAY flag or an O_NOBLOCK flag to open() which causes the open call
- to succeed without waiting for carrier detect to be asserted. If you use
- either of these modes, you can turn off the non blocking behavior,
- since this is not the operating mode you may desire for the subsequent
- read() and write() calls.
-
- You use fcntl() after open() to turn off O_NDELAY (error checks omitted):
-
- fd = open ( "/dev/tty01h", O_RDWR | O_NDELAY );
- flags = fcntl ( fd, F_GETFL );
- fcntl ( fd, F_SETFL, flags & ~O_NDELAY );
-
-
- Subject: D32) How do I compile tin?
-
- This should by now be a classic problem in compiling tin under UnixWare
- (1.0 at least, I don't know if 1.1 fixed this particular bug).
-
- When you're compiling tin, the make may fail on the first source file
- with messages like the following:
-
- "/usr/include/sys/termios.h", line 503: (struct) tag redeclared: winsize
- active.c, line 615: warning: argument is incompatible with prototype: arg #4
- active.c, line 616: warning: argument is incompatible with prototype: arg #4
- make: fatal error.
-
- If this occurs, you've encountered a bug in one of the UnixWare system
- header files. You can do one of two things to compile tin under
- UnixWare:
-
- * Fix the header file. Change all occurrences of
-
- _IO_PT_PTEM_H
-
- to
-
- _IO_PTEM_H
-
- in the file /usr/include/sys/ptem.h.
-
- <or>
-
- * Hack the tin header file tin.h, which is what I did. At line 130 in
- tin.h, you'll find two #include directives, <sys/ptem.h> and
- <sys/tty.h>. Place the following #define between these two #includes:
-
- #define _IO_PTEM_H
-
- This works around the problem with the system header files, if you're
- not excited about modifying them (or don't have su privileges).
-
-
- Subject: D33) How do I compile emacs?
-
- The UnixWare cc preprocessor (cc -P) doesn't work the same as
- /usr/ccs/bin/cpp from the configure script. You have three options:
-
- 1) Use gcc. The GNU compiler groks the GNU configure file.
-
- 2) Use the UnixWare preprocessor /usr/ccs/bin/cpp directly.
-
- 3) Get the emacs binary as indicated in the FAQ.
-
- Subject: D34) How do I compile Perl 5.001?
-
- Note that Perl 5.001 source and binaries are now available from ftp.abs.net
-
- tye@fohnix.metronet.com (Tye McQueen) wrote:
-
- Porting (aka Installing) Perl 5.x to UnixWare systems can be
- confusing, but it need not be difficult. Here are some notes
- to help you. I hope to make some of these notes obsolete in a
- future release of Perl and to include the remaining ones in a
- README.svr4 file in that distribution.
-
- First, be sure you have Perl5.001m or later. You can fetch a copy
- from:
- ftp://ftp.metronet.com/pub/perl/source/perl5.001m.tar.gz
- or many other places listed in the Perl meta-FAQ, which can be
- found at:
- http://www.khoros.unm.edu/staff/neilb/perl/metaFAQ/metaFAQ.html
- or
- ftp://ftp.khoros.unm.edu/pub/perl/metaFAQ.txt
- I don't recommend trying to apply patches to a Perl5.000 or
- Perl5.001 distribution; just fetch the full latest distribution.
-
- Next, an easy way to build Perl successfully is simply:
-
- 1. $ mv -f config.sh config.sh.old
- 2. $ ./Configure -dsE
- 3. You can edit config.sh here (but don't do it this first time).
- 4. $ ./Configure -S
- 5. $ env LD_LIBRARY_PATH=`pwd` make
- 6. $ env LD_LIBRARY_PATH=`pwd` make test
- 7. Become "root", if you aren't already.
- 8. # env LD_LIBRARY_PATH=`pwd` make install
- 9. Answer "yes" that you want /usr/bin/perl set up.
-
- I say "simply" because this method only asks you one question and I've
- told you what the answer is. Yes, it is more steps than it should be.
-
- You might want to save the last two steps until you are sure you
- have everything configured the way you like. Please don't let the
- "WHOA THERE!!!"s scare you. They are there for a reason and the
- default answer ("yes") is what you want.
-
- More advanced options
-
- If you don't like the directories that Configure picks to install
- things into, the simplest change is to add "-Dprefix=/usr/local" on
- the end of Step 2 above (where "/usr/local" is the directory where
- you want "bin/*", "lib/perl5/...", and possibly "man/*/*" to be
- installed). ./Configure will pick /usr/local if it exists,
- otherwise it will probably pick /opt.
-
- You can also go back to Step 3 above and change the paths in config.sh
- that you don't like (the Notes section has more hints on doing this).
-
- There are even more options you can give to Configure to influence
- what directories it picks, but I haven't tested those options so I
- won't go into those switches here. You can type "./Configure -h" for
- more information on switches that can be given to Configure.
-
- If you want to use GNU CC to build Perl:
-
- * Add "-Dcc=gcc" on the end of Step 2 above.
- * Be sure to not use GNU AS, GNU LD, nor GNU LIBC.
- * Make sure you installed GNU CC correctly, including the
- "fix-includes" step.
- * You may be able to use GNU's gdbm to emulate odbm and ndbm for the
- ODBM_File and NDBM_File extensions, but I've seen reports of
- problems (lock ups) with this under Linux.
-
- I haven't installed gcc so I haven't tested this (these hints come
- from problems others have had using GCC on other systems).
-
- Possible problems
-
- Building Perl on UnixWare 1.x then running on UnixWare 2.x
-
- The most serious problem I am aware of is that a Perl executable
- compiled on UnixWare 1.x may run on UnixWare 2.x but it will not
- do I/O correctly. This is because Perl uses some "officially
- non-standard" optimizations (that happen to port well to a wide
- variety of UNIX systems) in order to get much faster I/O under many
- circumstances.
-
- If you really want one version of Perl that will run on both UnixWare
- 1.x and UnixWare 2.x, then you can disable these optimizations either
- by adding "-Dd_stdiobase=undef" on the end of Step 2 above or by
- going back to Step 3 above and changing d_stdiobase='define' to
- d_stdiobase='undef' then continuing on with the rest of the steps. I
- have tested both of these methods and am using such a version of Perl
- under both UnixWare 1.1 and UnixWare 2.01.
-
- If I don't find any problems with it I will update the hints/svr4.sh
- file to do this automatically for UnixWare systems. I'll also see if
- Novell or SCO will make this version available in "pkgadd" format.
-
- File glob tests fail due to broken csh in UnixWare 1.1.4.
-
- I have two reports that the version of csh included with UnixWare 1.1.4
- is broken (which is the version of csh included in PTF2001 which fixes
- memory leaks in csh). This will cause some of the "file glob" tests to
- fail.
-
- If this happens to you, you can get around the problem by going back
- to Step 3 above and changing d_csh='define' to d_csh='undef' in
- config.sh then continuing on with the remaining steps. You might also
- want to check out my File::Glob module which does file globbing inside
- Perl (http://www.metronet.com/~tye/glob.html).
-
- Easy to break DynaLoader, ODBM_File, and NDBM_File.
-
- You should be able to include Dynamic Loading along with both the
- ODBM_File and NDBM_File extensions in Perl under SVR4. It is very easy
- to run into problems using any of these three features under SVR4, but
- if you follow the above instructions, then you shouldn't run into
- these problems.
-
- You won't get the ODBM_File nor NDBM_File extensions if you haven't
- installed the "BSD Compatibility" package. This is because the dbm
- routines are kept in /usr/ucblib/libucb.a and the ndbm routines are
- kept in /usr/ucblib/libdbm.a and require /usr/ucblib/libucb.a.
-
- This stuff is easy to break because all SVR4 systems (except UnixWare
- 2.x -- thanks Novell!) have a broken /usr/ucblib/libucb.a which will
- often break programs that try to use it. The hints/svr4.sh file can
- usually prevent problems by telling Perl to not use most of the
- routines in libucb.a. The way hints/svr4.sh does this is why Configure
- gives you all of those scary "WHOA THERE!!!" warnings.
-
- You can use most (on UnixWare 2.x, all) of the BSD-compatibility
- routines, if you want. I made the defaults to not use any of these
- for several reasons.
-
- * Prior to UnixWare 2.x, trying to ld with the floating point
- routines from libucb.a (ecvt, gcvt, fcvt, etc.) resulted in
- "undefined symbol" errors. If using them only in a dynamically
- loaded extension, then these "unresolved external" errors might
- not show up until you tried to use the extension.
- * I worried that there could be SVR4.x systems with versions of
- libucb.a where even more of these routines don't work.
- * I don't believe that they add any functionality over the
- corresponding native SVR4.x routines, even considering how Perl
- knows how to use them. If anyone finds otherwise, please let us or
- me know so that Perl can be fixed to use the SVR4.x routines more
- effectively.
- * I worry that they add some overhead, though probably not a great
- amount.
-
- Notes
-
- Changing where Perl will be installed
-
- Don't worry too much about all the stuff in config.sh that may not
- make sense to you. You can just change the first part of any absolute
- paths (those that start with "/") that appear between single quotes
- (') after an equal sign (=). But don't change any of these "paths"
- that point to files that already exist on your system (ie. only change
- ones that point either to directories or to places that don't exist
- yet). Save a copy of config.sh before you edit it in case you change
- your mind.
-
-
- Subject D35) Where can I get audio software for UnixWare ?
-
- Voxware driver support for UnixWare 1.x and 2.x can
- be found on ftp.abs.net:/unixware/freebird/sound.
-
-
- Subject D36) Where can I get the GNU debugger (gdb) for UnixWare 2?
-
- This can be found in the developer section of the freebird
- archive. Check ftp://ftp.freebird.org/unixware/developer.
-
-
- Subject: D37) How can I debug an application without the source code?
-
- Peter Lord writes:
-
- If you are a developer working on a new software product, then debugging
- an application is fairly straight forward. But what can you do if you
- are an end user and don't have access to the source code?
-
- You may come across this problem when trying to run an application
- designed for a different operating system on UnixWare.
-
- Truss
-
- Truss(1) is a wonderful program designed for debugging BINARY programs.
- It takes control of the process you are interested and prints out all
- the system calls your program makes!
-
- For example, if you tried to run the SCO version of Framemaker 3.1X on
- UnixWare, you will find it fails without any sensible error message. By
- trussing the Framemaker binaries, you can find out if any of the system
- calls are failing. In this example, it was easy to find out that
- Framemaker was trying to run a program from the bin.i386 directory ...
- but only a bin.scounix directory existed. A simple symbolic link brought
- the application into life!
-
- Lets take a simple example.
-
- $ ls /fred
- UX:ls: ERROR: Cannot access /fred: No such file or directory
- $
-
- In this case we get a error message which can be understood ... but this
- may not always be the case. Now, if we truss this same command we get :-
-
- $ truss -o/tmp/trussout ls /fred
- UX:ls: ERROR: Cannot access /fred: No such file or directory
- $
-
- and the file /tmp/trussout contains :-
-
- ....
- lxstat(2, "/fred", 0x08047520) Err#2 ENOENT
- ....
- write(2, " U X : l s : ", 7) = 7
- write(2, " E R R O R", 5) = 5
- write(2, " : ", 2) = 2
- write(2, " C a n n o t a c c e s".., 47) = 47
- _exit(2)
-
- Here you can see that ls has made a system call lxstat which returns an
- error.
-
- So you can see that although truss cannot follow all of the program, it
- can print out the system calls and so give you some clues to where your
- program is failing.
-
- One useful truss option is -t. This allows tracing of certain system
- calls only (and thus reducing the amount of output you need to scan
- through). See the truss manual page for more options.
-
- Truss can even follow processes which are currently running! For
- example, if you want to debug your running lockd daemon, use ps to find
- out it's process id and then use the command truss -p pid.
-
- Subject: D38) When I link I can 't find the syslog routines, what should I do?
-
- You need to include libgen. Add -lgen to your link line.
-
- Subject: D39) When I link I can 't find the strcasecmp routine?
-
- You need to link to the ucblib library. This has to be done
- as follows:
- -lc -L/usr/ucblib -lucb
-
- Alternately just extract the object file (stricmp.o) from /usr/ucblib/libucb.a
- and link that to your executable:
-
- $ cd /tmp
- $ ar x /usr/ucblib/libucb.a stricmp.o
-
- Subject: D40) When I link I can 't find the alloca routine?
-
- See D38 above.
-
- Subject: D41) How do I make a pkgmk add-on package?
-
- UnixWare supports the SVR4 packaging tools and the pgmk(1) utility
- to create a package. If you cannot find the packaging tool that you need ,
- check that you have the Software Packaging Tools (softint) package
- installed from the SDK (or ask SCO to make a PTF - since they
- tools really ought to be available to all developers)
-
- These three tools are in the Base
-
- /usr/bin/pkginfo - display software package information
- /usr/bin/pkgparam - display package parameter values
- /usr/bin/pkgtrans - translate package format
-
- The key scripts for creating packages are in the SDK softint package:
-
- /usr/bin/pkgmk - create a package
- /usr/bin/pkgproto - generate a package prototype file
-
- For further details refer to the Software Tools Book in Dynatext, Chapter 8,
- or the UNIX SVR4 Programmer's Guide: System Services
- and Application Packaging Tools Manual. The Generic Application Binary
- Interface (gABI) specification is also a good reference for this material.
-
- This will allow the system to track all installed software thus
- ensuring its integrity.
-
- Its good practice for applications to only install or create files in
- designated places within the file tree away from the system
- files if possible. A possible scenario is noted below.
-
- root or "/"
- / | \ \
- / | \ \
- opt usr etc var
- / | \ | | / \
- bin man lib bin opt opt tmp
- / \ / \
- pkg1 pkgn pkg1 pkgn
-
- /opt, /var/opt and /etc/opt\f1 are reserved in the file
- tree for the installation of application software packages. Each
- add-on package should adhere to the following rules.
- Static package objects should be installed in /opt/lib/pkg, where
- pkg is the package abbreviation.
-
- Package objects that change in normal operations (for example,
- log and spool files) should be installed in /var/opt/pkg
-
- Machine-specific configuration files should be installed in
- /etc/opt/pkg.
-
- Executables that are directly invoked by users should be installed
- in /opt/bin
-
- Only package objects that must reside in specific locations within the
- system file tree in order to function properly (for example,
- special files in /dev) should be installed in those locations.
-
- An advantage of putting all package files under /opt is that allows
- that directory to be networked.
-
- A very simple example - The mush Package
- -----------------------------------------
- To create an SVR4 package the following files should be created
-
- copyright pkginfo prototype postinstall
-
- copyright
- ---------
- This contains the copyright notice for the package. For example:
-
-
- Mush is copyright (c) 1986, 1987, 1988, 1989, 1990, 1991 by Dan Heller.
- All Rights Reserved. This software is not in the public domain.
-
- Redistribution of the unmodified source code is permitted as long as all
- copyright notices remain intact and all other identifying notices remain
- in the code and in the binary. This includes message headers on outgoing
- mail and the startup message. Future releases may extract the release
- version from the message headers of mush-originated messages to aid in
- implementing features and providing backwards compatibility with previous
- versions. Modification of the source for personal use is permitted.
- Modifications sent to the authors are humbly accepted and it is their
- prerogative to make the mods official. Only the "official" sources may be
- redistributed and no sale of the code or any part thereof is permitted
- without written consent from the authors. Further, no part of the code
- may be used in any other product, free or otherwise, without consent from
- the authors. Distribution of sources containing adaptations of the SunView
- interface to XView or to any X11-based interface is expressly prohibited.
-
- MUSH IS PROVIDED AS IS, WITHOUT WARRANTY. AUTHORS HEREBY DISCLAIM
- ALL WARRANTIES INCLUDING BUT NOT LIMITED TO THE IMPLIED WARRANTIES
- OF FITNESS FOR A PARTICULAR PURPOSE.
-
- pkginfo
- -------
-
- pkginfo is an ASCII file that describes the characteristics
- of the package along with information that helps control the
- flow of installation. It is created by the software package
- developer.
-
- Each entry in the pkginfo file is a line that establishes
- the value of a parameter in the following form:
-
- PARAM="value"
-
- An example follows:
-
- $ cat pkginfo
- PKG="mush"
- VERSION="7.2.5"
- NAME="Mail Users Shell"
- CATEGORY="application"
- CLASSES="none"
- PREDEPEND=mush
- VENDOR="(c) 1989 Dan Heller"
-
-
- For more information see pkginfo(4).
-
- prototype - package information file
- --------------------------------------
-
- prototype is an ASCII file used to specify package
- information. Each entry in the file describes a single
- deliverable object. An object may be a data file,
- directory, source file, executable object, etc. This file
- is generated by the package developer (most often using the
- pkgproto command).
-
- Entries in a prototype file consist of several fields of
- information separated by white space. Comment lines begin
- with a ``#'' and are ignored.
-
- An example follows:
-
-
- $ cat prototype
- i pkginfo
- i copyright
- i postinstall
- d none /opt ? ? ?
- d none /opt/bin ? ? ?
- d none /etc ? ? ?
- d none /etc/mail ? ? ?
- f none /opt/bin/mush 0755 bin bin
- d none /opt/lib/mush 0755 bin bin
- d none /opt/man 0755 bin bin
- d none /opt/man/man1 0755 bin bin
- f none /opt/man/man1/mush.1 0644 bin bin
- f none /opt/lib/mush/Mushrc 0644 bin bin
- f none /opt/lib/mush/cmd_help 0644 bin bin
- f none /opt/lib/mush/Mailrc 0644 bin bin
- f none /opt/lib/mush/Gnurc 0644 bin bin
- f none /opt/lib/mush/advanced.mushrc 0644 bin bin
- f none /opt/lib/mush/sample.mushrc 0644 bin bin
-
-
- For more information see prototype(4).
-
- postinstall - postinstallation commands
- -------------------------------------------
-
- This script is run with root privilege after the installation (note
- that a preinstall file can be created to run commands before the
- installation). (Note that this script asks for input and
- strictly speaking that should be done thru a request script).
-
- An example follows:
-
- $ cat postinstall
-
- echo "\n\t*** NOTE: To setup your From: address line edit /etc/mail/mush/Mushrc"
- echo "\tAttempting to set this up. If not setup the From: line will default"
- echo "\tto the system name. Its best to use a domain address i.e. site.domain"
- echo "\talthough you must be registered."
- echo "\tEnter your domain address --->\c"
- read address
- if [ "${address}" = "" ]
- then
- echo "\tYou did not enter an address so /etc/mail/mush/Mushrc not setup."
- else
- echo "\tYou entered \"$address\" as your domain name"
- echo "\tThis will now be entered in the /etc/mail/mush/Mushrc file."
- echo "\tIf you made a mistake edit the file by hand."
- fi
- sleep 2
- echo "set hostname=\"$address\"" >>/etc/mail/mush/Mushrc
-
-
- pkgmk - produce an installable package
- ---------------------------------------
-
- To build the package use pkgmk.
-
- NOTE: pkgmk requires root privilege.
-
- For example to create the package in /var/spool/pkg.
-
- Ensure you are the same directory as the packaging commands,
- and that the target package files are installed in the correct
- locations (this simplifies things a lot).
-
- # pkgmk -ai386 -r /
-
- If you want to overwrite an existing package in the /var/spool/pkg
- directory use the "-o" flag to pkgmk; pkgmk -ai386 -o -r /.
-
- If you don't want to install the utility in its final
- destination prior to package creation, then a tree of files
- can be created in a subdirectory call root, and the prototype
- file edited as follows:
-
- $ cat prototype
- i pkginfo
- i copyright
- i postinstall
- d none /opt ? ? ?
- d none /opt/bin ? ? ?
- d none /etc ? ? ?
- d none /etc/mail ? ? ?
- f none /opt/bin/mush=root/opt/bin 0755 bin bin
- d none /opt/lib/mush=root/opt/lib 0755 bin bin
- d none /opt/man=root/opt/man 0755 bin bin
- d none /opt/man/man1=root/opt/man/man1 0755 bin bin
- f none /opt/man/man1/mush.1=root/opt/man/man1/mush.1 0644 bin bin
- f none /opt/lib/mush/Mushrc=root/opt/lib/mush/Mushrc 0644 bin bin
- f none /opt/lib/mush/cmd_help=root/opt/lib/mush/cmd_help 0644 bin bin
- f none /opt/lib/mush/Mailrc=root/opt/lib/mush/Mailrc 0644 bin bin
- f none /opt/lib/mush/Gnurc=root/opt/lib/mush/Gnurc 0644 bin bin
- f none /opt/lib/mush/advanced.mushrc=root/opt/lib/mush/advanced.mushrc 0644 bin bin
- f none /opt/lib/mush/sample.mushrc=root/opt/lib/mush/sample.mushrc 0644 bin bin
-
- Package creation is the simply:
-
- pkgmk -ai386 -o
-
- (no -r / this time)
-
- Creating a floppy copy
- ----------------------
-
- To create a floppy copy:
-
- # pkgtrans spool diskette1 mush
-
- Another Example - Sendmail
- ============================
- This example uses the menu routines to generate a blue screen menu
- upon installation.
-
- The packaging tree is listed below:
-
- $ find . -print
- ..
- ../install
- ../install/copyright
- ../install/i.save
- ../install/menu.1
- ../install/menu.err
- ../install/menu.intro
- ../install/postinstall
- ../install/postremove
- ../install/preinstall
- ../install/r.save
- ../install/request
- ../pkginfo
- ../prototype
- ../root
- ../root/etc
- ../root/etc/mail
- ../root/etc/mail/mailsurr
- ../root/usr
- ../root/usr/ucblib
- ../root/usr/ucblib/sendmail
- ../root/usr/ucblib/sendmail.cf
- $
-
- The contents of some of the key files above are listed below:
-
- copyright
- ---------
-
- copyright - the copyright notice
-
- i.save
- ------
-
- i.save - a script run by the system to backup files
-
- #!/bin/sh
- # i.save script
- # script which backs up files
- #
- while read src dst ; do
-
- [ "$src" = /dev/null ] && continue
-
- if [ -f $dst ] ; then
- echo $dst | cpio -pdmu $PKGSAV >/dev/null 2>&1
- fi
- cp $src $dst.tmp || exit 1
- mv $dst.tmp $dst || exit 1
- done
- exit 0
- # end of i.save script
-
-
- menu.1
- --------
-
- menu.1 - part of the blue screen menu
-
-
- ..pageno
- Page %d of %d
- ..ul
- Sendmail Installation
- ..helpbanner
- Help on Sendmail Installation
- ..hhelp_ban
- Help on menus
- ..ur
- Introduction
- ..ll
- Please make a selection.
- ..lr
- Del=Cancel F1=Help
- ..top
-
- This is a binary distribution of Sendmail 8.7.3 for UnixWare 2.x.
- This package sets up your system to use Sendmail instead of the
- default mailsurr based mailer.
-
- AS SUCH, THIS IS AN UNSUPPORTED PACKAGE, TO BE USED AT YOUR OWN RISK.
-
- This package saves all files it changes so they can be restored
- on its removal. You must restart TCP/IP after installing this package
-
- sh /etc/inet/rc.restart
-
- This port by :
-
- Joe Doupnik, jrd@cc.usu.edu, Utah State University, 31 Dec 1995.
-
- ..bottom
- press 'ENTER' (or 'RETURN') to install.
- ..help
- The following assumptions are made about the installation:
-
- o The directories used by this pacakage are
- /usr/ucblib - for the mail executable
- /etc/mail - for the mail configuration
-
- ..helpinst
- Esc=Quit Help Del=Cancel F1=Instructions
- ..hhelpinst
- Esc=Quit Instructions Del=Cancel
-
-
- menu.err
- ----------
- menu.err - another part of the blue menu screens
-
-
- ..pageno
- Page %d of %d
- ..ul
- Sendmail Installation
- ..helpbanner
- Help on Sendmail Installation
- ..hhelp_ban
- Help on menus
- ..ur
- Error
- ..ll
- Press return when ready
- ..lr
- Del=Cancel F1=Help
- ..top
-
-
-
-
-
-
-
-
- `echo $ERROR`
- ..bottom
- Press 'ENTER' (or 'RETURN') to continue.
- ..help
- ..helpinst
- Esc=Quit Help Del=Cancel F1=Instructions
- ..hhelpinst
- Esc=Quit Instructions Del=Cancel
-
-
- menu.intro
- -----------
- menu.intro - more of the blue menu
-
-
- ..pageno
- Page %d of %d
- ..ul
- Sendmail Installation
- ..helpbanner
- Sendmail Copyright Notice
- ..hhelp_ban
- Help on menus
- ..ur
- Introduction
- ..lr
- Del=Cancel F1=View Copyright
- ..ll
- Press RETURN when ready
- ..top
- Welcome to the Sendmail installation.
-
- This installs sendmail as the default mailer.
- This package is copyrighted. To re-view the copyright notice press F1 or '?'.
-
-
- ..bottom
- Press 'ENTER' (or 'RETURN') to continue.
- ..help
- The full notice may be found in /var/sadm/pkg/sendmail/install/copyright
-
- Copyright (c) 1983, 1995 Eric P. Allman
- Copyright (c) 1988, 1993
- The Regents of the University of California. All rights reserved.
-
-
- ..helpinst
- Esc=Quit Copyright Del=Cancel F1=Instructions
- ..hhelpinst
- Esc=Quit Instructions Del=Cancel
-
-
- postinstall
- -----------
-
- postinstall - the script executed after the software is installed
-
- #!/bin/sh
- # postinstall script
-
-
- if [ -f /etc/inet/config ] ; then
- if grep sendmail: /etc/inet/config >/dev/null ; then
- :
- else
-
- # Save old version with the packaging
- echo /etc/inet/config | cpio -pdmu $PKGSAV 2>/dev/null
- echo '8:/usr/ucblib/sendmail::y:/usr/ucblib/sendmail.cf:-bd -q2h :' >> /etc/inet/config
- fi
- fi
-
- echo /etc/init.d/smtpinit |cpio -pdmu $PKGSAV 2>/dev/null
-
- TMP=/tmp/pkg$$
- echo "#!/bin/sh \nexit 0" > $TMP
- cat /etc/init.d/smtpinit >>$TMP
- cp $TMP /etc/init.d/smtpinit
-
- exit 0
- # end of postinstall script
-
- postremove
- -----------
-
- postremove - script executed to removing the software
-
- #!/bin/sh
- # postremove used to restore original files
-
- cd $PKGSAV
- echo "Warning the following files have been restored, any changes"
- echo "made to them since installing this package will be lost."
- find . -type f -print|cpio -pdmuv /
- exit 0
- # end of postremove
-
-
- preinstall
- ----------
-
- preinstall - executed before installing files
-
- #!/bin/sh
- # preinstall - some dependency checks
-
- rel=`uname -v |cut -f1 -d"."`
- if [ "$rel" -ne "2" ]
- then
- echo "This package requires UnixWare version 2.x to install."
- exit 1
- fi
- sh /etc/rc2.d/S81smtp stop
-
- exit 0
- # end of preinstall
-
- r.save
- -------
-
- r.save - class script to restore files
-
-
- #!/bin/sh
- #
- # script which backs up files
- #
-
- cd $PKGSAV
-
- while read file ; do
- if [ -f ./$file ]
- then
- mv ./$file $file.tmp || continue
- mv $file.tmp $file
- else
- rm -f $file
- fi
- done
- exit 0
- # end of r.save script
-
- request
- -------
-
- request - script to display the menus & handle the input
-
- # geta question default
- MENU=/usr/sbin/menu
-
- cd $REQDIR || exit 1
- rm -f /tmp/out.$$
- $MENU -f menu.intro -o /tmp/out.$$
- if [ ! -f /tmp/out.$$ ] ; then
- exit 1
- else
- . /tmp/out.$$
- fi
-
- rm -f /tmp/out.$$
- $MENU -f menu.1 -o /tmp/out.$$
- if [ ! -f /tmp/out.$$ ] ; then
- exit 1
- else
- . /tmp/out.$$
- fi
-
- echo "NPATH=$NPATH" >> $1
-
-
-
- pkginfo
- -------
- The pkginfo script has the save class defined so
- that files can be backed up and restored using the
- i.save and r.save scripts
-
- ARCH=i386
- PKG=sendmail
- VERSION=8.7.3
- NAME=Sendmail Mailer
- CATEGORY=system
- DEPEND=sendmail
- CLASSES=none save
-
-
-
- prototype
- --------
- The prototype shows the save class being used for the
- mailsurr, and old sendmail files.
-
- i pkginfo
- i preinstall=install/preinstall
- i copyright=install/copyright
- i menu.intro=install/menu.intro
- i menu.1=install/menu.1
- i menu.err=install/menu.err
- i postinstall=install/postinstall
- i postremove=install/postremove
- i request=install/request
- i i.save=install/i.save
- i r.save=install/r.save
- d none / ? ? ?
- d none /usr ? ? ?
- d none /etc ? ? ?
- d none /etc/mail ? ? ?
- d none /etc/ucbmail ? ? ?
- d none /usr/ucblib ? ? ?
- f save /etc/mail/mailsurr=root/etc/mail/mailsurr 444 root mail
- f save /usr/ucblib/sendmail=root/usr/ucblib/sendmail 04111 root mail
- f save /etc/ucbmail/sendmail.cf=root/usr/ucblib/sendmail.cf 444 bin bin
-
-
- Creating the package
- --------------------
- In this case
- pkgmk -ai386 -o
-
- Subject: D42) How to build binaries on UnixWare to run on other SVR4 systems
- such as Solaris x86?
-
- Scott Raney <raney@metacard.com> writes:
-
- 1) Always link libraries dynamically.
-
- 2) We had to put the following hack in to make UnixWare 2.0 binaries
- run on Solaris 2.4:
- #ifdef UNIXWARE
- extern "C" {
- int sys_nerr;
- int *__thr_errno()
- {
- return &errno;
- }
- }
- #endif
-
- 3) Be sure to thoroughly test all code that runs subrocesses,
- especially code that reads and writes to pipes to the child processes.
- The gotchas here are too obscure to detail here, but they'll get you
- if you don't hunt them down.
-
-
- John Moyer (jrm@questconsult.com) writes :
-
- To build binaries that run under Dell Unix from Unixware 2.0x, static
- linking is best. Static linking is not possible with Athena Widgets or
- wide character support or anything else that requires -lnsl.
-
- To build X11R6 binaries from UnixWare 2.0x to run under Unixware 1.1.4
- I found it necessary to link with libc.so and libnsl.so from unixware
- 1.1.4. This is not necessary if libXaw.so is built with the x.org
- wide character support instead of using -lw.
-
- Binaries with "long double" variables do not seem to run under the
- Linux iBCS emulation. Static linking seems to me to be best for Linux
- iBCS.
-
-
- Acknowledgements
- ---------------
-
- Special thanks to Darren R. Davis and the Novell UnixWare
- Developer Support team for getting this FAQ going and to
- those folks who've made suggestions and contributions either
- directly or via the netnews.
-
-
- --
- Andrew Josey, Disclaimer: Any views expressed are not those of
- my employer, either past, present or future.
-
-