This chapter describes known runtime problems.
The following runtime bug descriptions have been added to this chapter since this document was published on the Solaris 8 10/00 Documentation CD and in the Installation Kiosk on the Solaris 8 10/00 Installation CD.
The name of this product is Solaris 8 10/00, but code and path or package path names may use Solaris 2.8 or SunOS 5.8. Always follow the code or path as it is written.
An exploit referred to as "Brown Orifice" creates an HTTP server as a Java applet, which has the effect of turning the Netscape browser into a web server. This allows remote users to access local and networked files. These files include URLs located behind firewalls using "file://", "http://", "https://", "ftp://", and other types of connections. There are no symptoms that would show the problem has occurred.
This is not an architectural problem with the Java security model.
Netscape Communicator versions 4.04 through 4.74 are affected. For more information on this vulnerability see CERT advisory CA-2000-15 at: http://www.cert.org/advisories/CA-2000-15.html
To correct this issue download and install Netscape Communicator version 4.75 from: http://www.sun.com/software/solaris/netscape
ypbind has a buffer overflow which can be exploited remotely to gain root access on the compromised system.
Workaround: To prevent this problem, apply patch 110322-01 .
A problem occurs when compiling a Motif program in the Solaris 8 operating environment when you link to a shared library that has been compiled in the Solaris 2.4, 2.5, 2.5.1 or 2.6 operating environments and the older library also uses the Motif Application Programming Interface (API).
The Motif program uses Motif version 2.1 and the old shared library uses Motif version 1.2. A core dump occurs. This is not a binary compatibility problem for applications compiled in the Solaris 2.4, 2.5, 2.5.1, 2.6 operating environments, which should run correctly in the Solaris 8 operating environment.
Workaround: If you have an older shared library that links directly to the Motif library, and if you want to compile a program in the Solaris 8 operating environment that links to both Motif and that older shared library, use a line like this to compile:
cc foo.c -o program -DMOTIF12_HEADERS -I/usr/openwin/include -I/usr/dt/include -lXm12 -lXt -lX11 |
The sdtwinlst (Window List) and sdtgwm (Windows Manager) icons do not appear in Application Manager. A generic icon is displayed instead. The reason is that two action files, sdtgwm.dt and sdtwinlst.dt, are missing from the directory /usr/dt/appconfig/types/C.
Workaround: To add the missing icons:
Create a new file in /usr/dt/appconfig/type/C and name it sdtgwm.dt.
Edit this file and insert the following text:
ACTION SDtgwm { LABEL GWM TYPE COMMAND EXEC_STRING sdtgwm ICON SDtgwm WINDOW_TYPE NO_STDIO } |
Create a new file in /usr/dt/appconfig/type/C and name it sdtwinlst.dt.
Edit this file and insert the following text:
ACTION SDtWinLst { LABEL Window List TYPE COMMAND EXEC_STRING sdtwinlst ICON SDtWinLst WINDOW_TYPE NO_STDIO } |
To verify all actions have been reloaded, exit the CDE session and log in again.
A CDROM with an unusual data layout might fail to mount automatically. The File Manager Window might not display the CDROM's contents after it is inserted into the drive.
Workaround: Mount the CDROM manually:
Become root.
Stop the volume manager:
/etc/init.d/volmgt stop |
Mount the CDROM:
mount -F hsfs -r device_pathname /mnt |
Where device_pathname is the pathname to where in the system the CDROM drive is connected to. For example, /dev/dsk/c0t6d0s0.
CDROM drives are typically connected to c0t6d0s0 or to c0t2d0s0 at the factory, but you must use the correct pathname for this command to work.
Restart the volume manager:
/etc/init.d/volmgt start |
If you insert a diskette into its drive on a system with SCSI removable media devices and then select Check for Floppy from the File menu in OpenWindowsTM File Manager, File Manager mounts the diskette in the /floppy directory, but fails to display a File Manager view listing the disk contents. The Format Floppy and Eject Floppy options do not appear in the File menu of File Manager.
Workaround: Choose one of the following workarounds.
To view the contents of a diskette, follow these steps:
Click on the / folder in the File Manager Iconic Path.
Double-click on the floppy folder in the / display window.
Double-click on the floppy0 folder in the /floppy display window.
To format a diskette, follow these steps:
Unmount the diskette.
% volrmmount -e floppy0 |
Format the diskette.
% fdformat floppy0 |
To create a new file system on a diskette, follow these steps:
If you have already unmounted the diskette, go to step 2 of this workaround.
Unmount the diskette.
% volrmmount -e floppy0 |
Create the appropriate file system on the diskette.
To create a new UFS file system on the diskette, use the newfs command:
% newfs /vol/dev/aliases/floppy0 |
To create a PCFS file system on the diskette, use the mkfs command:
% mkfs -F pcfs /vol/dev/aliases/floppy0 |
Mount the diskette.
% volrmmount -i floppy0 |
To eject the diskette, use the eject command.
% eject floppy0 |
To prevent this problem, apply patch 109463-01.
After deleting the last item from the desktop (for example, the last appointment in your Calendar or the last address in the Address Manager), it is restored from the handheld device to the desktop when you synchronize your handheld device.
Workaround: Manually delete the last entry from the handheld device prior to synchronization.
If you exchange multibyte data between a PDA device and Solaris CDE, the data may be corrupted in both environments.
Workaround: Back up your data on your personal computer with the PDA backup utility before you run the PDASync application. If you accidentally exchange multibyte data and corrupt that data, restore your data from the backup.
After selecting Help -> Information from the Front Panel, a list of obsolete files is returned. The correct file is S8FCSreleasenotes.
The following error message is displayed when memory is low:
CIM_ERR_LOW_ON_MEMORY |
Workaround: To reset the CIM Object Manager Repository:
Become superuser.
Stop the CIM Object Manager.
# /etc/init.d/init.wbem stop |
Remove the JavaSpaces log directory.
# /bin/rm -rf /var/sadm/wbem/log |
Restart the CIM Object Manager.
# /etc/init.d/init.wbem start |
You will lose any proprietary definitions in your datastore. You must recompile the MOF files that contain those definitions using the mofcomp command. For example:
# /usr/sadm/bin/mofcomp -u root -p root_password your_mof_file |
When running either /usr/sadm/bin/mofcomp or /usr/sadm/bin/wbemadmin the following error message may appear:
NO_SUCH_QUALIFIER1: Qualifier association not found. |
Workaround: To reset the CIM Object Manager Repository:
Become superuser.
Stop the CIM Object Manager.
# /etc/init.d/init.wbem stop |
Rename the JavaSpaces log directory.
# mv /var/sadm/wbem/log /var/sadm/wbem/logprepatch |
Restart the CIM Object Manager.
# /etc/init.d/init.wbem start |
You will lose any proprietary definitions in your datastore. You must recompile the MOF files that contain those definitions using the mofcomp command. For example:
# /usr/sadm/bin/mofcomp -u root -p root_password your_mof_file |
If you enumerate instances of the Solaris_FileSystem class by using CIM WorkShop or the WBEM APIs, then the CIMOM no longer runs and the following error message is displayed:
Attempted to complete RMI action enumInstances and received exception java.rmi.UnmarshalException: Error unmarshaling return header; nested exception is: java.io.EOFException |
Workaround: In superuser mode, restart the CIMOM by typing the following command:
# /etc/init.d/init.wbem start |
USB capable systems with small memory configurations might panic when booting from either disk, CD or a network when several USB devices are connected. One of the following panic messages will appear in this event:
panic[cpu0]/thread=1040800: main: unable to fork init. |
or
panic[cpu0]/thread=2a1000fdd40: BAD TRAP: type=31 rp=2a1000fd0a0 addr=c0 mmu_fsr=0 occurred in module "genunix" due to a NULL pointer dereference |
Workaround: If you have more than 4 USB devices, boot the system with only the USB keyboard and mouse connected. After you see the Solaris login prompt, connect the remaining USB devices.
Java Plug-in 1.2 is the default plug-in that runs Java 2 applets but not all Java 1.1 applets. If you require the Java Plug-in 1.1, you can download it from http://www.sun.com/solaris/netscape.
If you choose to have both Java Plug-in 1.1 and Java Plug-in 1.2 on the same system, you must follow the instructions for how to install Java Plug-in 1.1 and then configure your environment accordingly.
This procedure is outlined in the "Installing Java Plug-in" section of the Java Plug-in for Solaris Users Guide that is available from http://www.sun.com/solaris/netscape/jpis/usersguide_java_plugin.html.
libjvm.so does not function correctly if it is brought into the process using dlopen. It must be linked into the executable when that object is created.
Workaround: Explicitly name libjvm.so (-ljvm) and libjava.so (-ljava) as dependencies when you create an executable.
By default, the Solaris ata device driver has the DMA feature disabled for ATA/ATAPI devices.
This feature has been disabled to avoid problems on some systems that do not properly support DMA on ATA/ATAPI drives. Most of the problems are related to an outdated system BIOS.
To enable (or disable) DMA for the ata driver after an installation of the Solaris 8 operating environment:
Run the Solaris (Intel Platform Edition) Device Configuration Assistant from the boot diskette or the installation CD (if your system supports CD-ROM booting).
When booting with the boot diskette, the new ata-dma-enabled property value will be preserved on the diskette. Therefore, the changed value is in effect when reusing the boot diskette.
Press F2_Continue to scan for devices.
Press F2_Continue to display a list of boot devices.
Press F4_Boot Tasks, select View/Edit Property Settings, and press F2_Continue.
Change the value of the ata-dma-enabled property to 1 to enable DMA (a value of 0 disables DMA):
Select the ata-dma-enabled property from the list and press F3_Change.
Type 1 and press F2_Continue to enable (type 0 and press F2_Continue to disable).
Press F2_Back, then F3_Back to return to the Boot Solaris menu.
Select the device from which you want to install (network adapter or CD-ROM drive) and press F2_Continue.
If any problems occur after enabling DMA, disable DMA (set the ata-dma-enabled property to 0 using the above procedure), update your system with the latest BIOS from your hardware manufacturer, and then re-enable DMA.
If the ab2admin command fails, the error message contains additional information besides command failed. For example, it may also include path not found or invalid ID.
Workaround: If the message command failed is displayed, make sure that the operation failed. For example, if the command you submitted should have deleted a collection from the AnswerBook2 database, type the following command to verify that the collection is displayed in the database.
# ab2admin -o list |
During the startup of an AnswerBook2TM server, the ab2cd script may display the following erroneous error message.
sort: can't read /tmp/ab1_sort.XXX: No such file or directory |
This error message states that the ab2cd script has not located any of the AnswerBook (Display PostScriptTM) collections on the CD.
Workaround: Ignore the error message.
Perform the following steps to print from any non-ISO8859-1 locale using the Font Downloader.
Log in to CDE.
Type fdl at the command line to start the Font Downloader.
Specify the printer by selecting Add from the Printer menu.
Select Font Bundle from the Download menu.
The font bundles are then downloaded to the specified printer, depending on what codeset is needed for printing.
LucidaSansLat4 font aliases are not available so related error messages might appear when launching a Java application from any UTF-8 locale.
Workaround: Log into the ISO-1 equivalent of the locale and launch the Java application from there.
sdtwinlst (Windows List) and sdtgwm (Graphical Workspace Manager) are unlocalized in UTF-8 selected encodings for European languages.
Workaround: Login to an ISO8859-1 encoding, then run sdtwinlst and sdtgwm.
Some dead-key combinations do not work correctly in CDE. Also, names for months do not function correctly in the Calendar Manager in the Greek locale.
If you attempt to print extended characters when using Calendar Manager in a partial locale, the extended characters do not print correctly.
You cannot cut or paste Arabic text between an application or window running under en_US.UTF-8 in Arabic input mode and one running under ar_EY.ISO8859-6 in Arabic input mode.
When you right-click in any CDE application for a European locale, the CDE Extras drop-down menu does not display any options.
Complex Text Language (CTL) support for entering Hebrew, Arabic, or Thai has been implemented in en_US.UTF-8 and European UTF-8 locales, but is not supported in ja_JP.UTF-8, ko.UTF-8, also known as ko_KR.UTF-8, zh.UTF-8, which is also known as zh_CH.UTF-8, and zh_TW.UTF-8 locales.
Workaround: Use the en_US.UTF-8 locale if you need to enter Thai, Arabic, or Hebrew using CTL. If you want to enter those languages in Asian and Japanese UTF-8 locales:
Create a symbolic link to common CTL modules. In the case of ja_JP.UTF-8:
# cd /usr/lib/locale/ja_JP.UTF-8 # mkdir LO_LTYPE ; cd LO_LTYPE # ln -s ../../common/LO_LTYPE/umle.layout.so.1 ja_JP.UTF-8.layout.so.1 # mkdir sparcv9 ; cd sparcv9 # ln -s ../../../common/LO_LTYPE/sparcv9/umle.layout.so.1 ja_JP.UTF-8.layout.so.1 |
Edit the /usr/openwin/lib/locale/ja_JP.UTF-8/XLC_LOCALE file by commenting out the load_option delay_nocheck line from Thai, Arabic, or Hebrew entries. For example, in the case of Thai:
# fs14 class (Thai) fs14 { charset TIS620.2533-0:GR font { # load_option delay_nocheck <--- comment out primary TIS620.2533-0:GR }} |
Several screens in the Smart Card application are not fully localized.
The Add, Modify, and Remove User screens are blank in the Greek locale of the Solstice AdminTool software.
Workaround: In superuser mode, copy the following file :
# cp /usr/openwin/lib/locale/C/app-defaults/Admin /usr/openwin/lib/locale/el_GR.ISO8859-7/app-defaults/Admin |
When you are in the Italian locale using the Font Downloader, both the Add and Cancel buttons in the Add Printer dialog box are incorrectly labeled; they are both labeled A ....
The left button should be labeled Aggiungi (Add).
The right button should be labeled Annulla (Cancel).
The following table describes the differences between the Sun Solaris Arabic keyboard and the Microsoft Arabic keyboard.
Table 2-1 Differences Between Sun and Microsoft Arabic Keyboards
Key |
Sun Keyboard Layout |
Microsoft Keyboard Layout |
---|---|---|
T |
T |
Arabic Lam_alef with Hamza below |
U |
U |
Right single quotation mark |
I |
I |
Arabic multiplication sign |
O |
O |
Arabic division sign |
A |
; |
Arabic Kasra |
S |
S |
Arabic Kasratan |
Z |
Z |
Tilde |
X |
X |
Arabic Sukun |
C |
Arabic Kasratan |
Left curly bracket |
V |
Arabic Kasra |
Right curly bracket |
M |
Sukun |
Single low quotation mark |
< |
< |
Arabic comma |
SEAM uses some of the resource files in the Solaris 8 operating environment, but only when the Kerberos settings are selected during an installation.
The Euro currency symbol is not generated when pressing AltGr+E in the UTF-8 locale.
Workaround: Perform the following steps to enter the Euro currency symbol in the UTF-8 locale:
Select Lookup in the UTF-8 Input Mode Selection window.
Select Currency Symbols.
Select the Euro symbol.
In the Greek locale type dumpcs at the console prompt. Then copy and paste the Euro currency symbol.
Sorting in the European UTF-8 locales does not work properly.
Workaround: Before you attempt to sort in a FIGGS UTF-8 locale, set the LC_COLLATE variable to the ISO1 equivalent.
# echo $LC_COLLATE > es_ES.UTF-8 # setenv LC_COLLATE es_ES.IS08859-1 |