Patch-ID# 107702-12 Keywords: security Tooltip xinerama LANG buffer crash restoring management Synopsis: CDE 1.3: dtsession patch Date: Apr/14/2003 Install Requirements: None Solaris Release: 7 SunOS Release: 5.7 Unbundled Product: CDE Unbundled Release: 1.3 Xref: This patch available for x86 as 107703 Topic: CDE 1.3: dtsession patch NOTE: Refer to Special Install Instructions section for IMPORTANT specific information on this patch. Relevant Architectures: sparc BugId's fixed with this patch: 4197661 4197661 4213057 4213057 4283121 4283121 4284715 4284715 4293551 4293551 4299998 4299998 4316439 4316439 4349846 4349846 4448598 4448598 4743546 4743546 4763733 4763733 4788212 4788212 Changes incorporated in this version: 4788212 Patches accumulated and obsoleted by this patch: Patches which conflict with this patch: Patches required with this patch: 108376-18 or greater Obsoleted by: Files included with this patch: /usr/dt/config/C/sys.resources /usr/dt/config/C/sys.resources /usr/dt/share/man/man1/dtsession.1 /usr/dt/share/man/man1/dtsession.1 /usr/dt/bin/dtsession /usr/dt/bin/dtsession Problem Description: 4788212 /usr/dt/bin/dtsession $HOME env overflow (from 107702-11) 4743546 With 105634-08 (or newer), DIALOG_SYSTEM_MODAL can be cleared by screen (from 107702-10) 4763733 dtsession crash on restoring session with very long lines (from 107702-09) 4349846 CDE color management does not work well with HP motif library (from 107702-08) 4448598 LANG buffer overflow in sessionmgr (from 107702-07) 4293551 dtsession in xinerama mode should (optionally) not center the logout dialog box (from 107702-06) 4213057 Tooltip functionality (from 107702-05) 4316439 dtsession is multi-threaded but calls vfork, which is MT-unsafe (from 107702-04) 4299998 Users with duplicate UIDs sometimes need root password to unlock (from 107702-03) 4284715 dtsession still has problems with SIGCLD when PAM is used (from 107702-02) 4283121 messages popping up over locked screen (from 107702-01) 4197661 X server or dtsession crashes when home session is set and SunPCi is running Patch Installation Instructions: -------------------------------- For Solaris 2.0-2.6 releases, refer to the Install.info file and/or the README within the patch for instructions on using the generic 'installpatch' and 'backoutpatch' scripts provided with each patch. For Solaris 7 release, refer to the man pages for instructions on using 'patchadd' and 'patchrm' scripts provided with Solaris. Any other special or non-generic installation instructions should be described below as special instructions. The following example installs a patch to a standalone machine: example# patchadd /var/spool/patch/104945-02 The following example removes a patch from a standalone system: example# patchrm 104945-02 For additional examples please see the appropriate man pages. Special Install Instructions: ----------------------------- In order to put in a complete fix for bug: 4283121: message popping up over locked screen Please install these additional patches: 107226-09 (or newer) for Solaris 7. Special Notes: -------------- NOTE 1: RFE 4293551 dtsession in xinerama mode should (optionally) not center the logout dialog box NOTE 2: In order to get full functionality of fix 4743546, install the following patch in addition to this patch: 107226-19 (or newer) CDE 1.3: dtwm patch ===================================================================== Sun(tm) delivers a version of CDE that has been extended to provide some basic support when run in multi-headed Xinerama mode. This support is to make the positioning of the following CDE dialogs resource configurable: - Login (a.k.a. dtgreet) - Logout Confirmation - Unlock Display - Restart Workspace Confirmation - Move/Resize Coordinates. The reason for making these dialogs configurable in terms of their window positioning is obvious, they are all non-movable. That is, these dialogs are all centered in the logical screen regardless of the number of physical monitors available. Without the ability to configure these dialogs, they will be split across monitors and will cause many ease-of-use issues. CDE patches (107180-25, 107226-13, 107702-07, or newer) and the Xsun patch (108376-18, or newer), when installed together, allow the user to configure the positioning of the previously mentioned dialogs using the following X resources: xineramaDefaultFramebuffer xineramaCenterHintX xineramaCenterHintY Resource Description ======================== If the xineramaDefaultFramebuffer resource has a value between 0 and (n-1), within the Xinerama screen, then dialogs will be centered on that framebuffer. If the xineramaDefaultFramebuffer resource has a value of -1, then dialogs will be centered using the values in xineramaCenterHintX and xineramaCenterHintY. To set resources system-wide, copy Xresources and sys.resources from /usr/dt/config/C to /etc/dt/config/C and add the appropriate lines. Setting resources in the Xresources file affects Login, while setting them in sys.resources affects Logout Confirmation, Unlock Display, Restart Workspace Confirmation, and Move/Resize Coordinates. Note that the resources for dtlogin, and thus the position of the Login dialog, cannot be set on a per-user basis on a single machine because dtgreet is run from root before the user is identified. The position of the other dialogs can be set on a per-user basis by creating or modifying the appropriate resource files in the user's HOME directory, .Xdefaults. The X resources have no effect if Xinerama is not being used or if their default values are -1. Example of using these resources ================================ The following are a few examples assuming a two-headed system. 1) To set Login, Logout Confirmation, Restart Workspace Manager Confirmation, Unlock Display and the Resize/Move Coordinate dialogs centered on the first screen: *xineramaDefaultFramebuffer: 0 in both Xresources and sys.resources files. Alternatively to have these dialogs centered on the second screen: *xineramaDefaultFramebuffer: 1 in both Xresources and sys.resources files. 2) If desired, these dialogs do not have to be centered on a particular screen. Instead you can position them anywhere within the entire Xinerama screen by setting their X and Y coordinates. Taking a two-headed system, each screen is 1024 pixels high by 1024 pixels wide, it is possible to place the dialogs in the lower left part of the second screen. To position the dialogs 100 pixels to the left of the second screen and 200 pixels from the bottom, set the following resources: *xineramaDefaultFramebuffer: -1 *xineramaCenterHintX: 1124 *xineramaCenterHintY: 824 A new resource ============== A new resource, dtsession*cacheColors, is introduced in this patch. When this resource is set to True dtsession caches frequently used colors for sharing between applications, improving desktop performance. If this resource is set to False, bug 4349846 is fixed which allows remote machines running non-Solaris versions of Unix to remote display Motif applications on multiheaded Solaris machines. The resource is set to True by default. It can be set to False by adding the following line to the Dtsession resource file: dtsession*cacheColors: False Please see the dtsession(1X) man page for instructions on how to edit resources for dtsession. README -- Last modified date: Monday, April 14, 2003