loadmodule IFS environment variable checking error

Vulnerability Description

Brief Description: loadmodule(1) uses system(3) to execute ld.so(1). It doesn't properly restrict the IFS variable.

Detailed Description: loadmodule is a program that loads moldules dynamically into a running kernel. loadmodule uses system to execute ld.so to do the actual dynamic loading. loadmodule does not reset the environment variable IFS to a safe state before it calls system.

Component(s): loadmodule system sh

Version(s): those distributed with the named operating systems

Operating System(s): SunOS 4.1.1, SunOS 4.1.2, SunOS 4.1.3 (trusted source); SunOS 4.1.3, Openwindows 3.0 (verified);

Other Information: A user account is required.

Effects:Access to the account of the owner of loadmodule; this must be root, or else the modules could not be loaded into the kernel.

Detecting the Vulnerability:

* Compare versions with those listed in "Vulnerable Systems." If it matches any of those, you are vulnerable.

* Replace ld.so with a shell script or program that prints the current value of IFS. Add the character / to the value of IFS. Run loadmodule and see if the value of IFS in your current environment is printed. If so, you have the vulnerability.

Fixing the Vulnerability:

* Upgrade to a newer version.

* For SunOS 4.1.x systems, apply Sun patch 100448-02.

* For Solaris systems, apply Sun patch 101200-02.

* For Openwindows, turn off setuid permission on /usr/openwin/bin/loadmodule.

* If you have the source code, clean out the environment before calling system.

Cataloguing

Keywords:loadmodule, system, sh, IFS

Exploiting

Attack Methods or Tools: Not provided.

Related Information

Advisories and Other Alerts: CA-93:18; Sun 00124

Related Vulnerabilities: none.

History

First Report We Know Of: by Mark Kraitchman kraitch@eecs.berkeley.edu, Peter Shipley

Revisions of Database Record

1. Omar Vanegas(Jul 22, 1998): Entered into DOVES.

2. Mike Dilger(original): Entered into original database.