On Thu, 2011-03-03 at 16:16 -0500, Dan Rosenberg wrote: > > > > Looking at a couple of these exploits, my suspicion is that looking at > > slabinfo simply improves the odds of success by a small factor (ie 10x > > or so) and doesn't present a real obstacle to attackers. All that > > appears to be required is to arrange that an overrunnable object be > > allocated next to one that is exploitable when overrun. And that can be > > arranged with fairly high probability on SLUB's merged caches. > > > > This is accurate, but the primary goal of exploit mitigation isn't > necessarily to completely prevent the possibility of exploitation (time > has shown that this is unlikely to be feasible), but rather to increase > the cost of investment required to develop a reliable exploit. If > removing read access to /proc/slabinfo means that heap exploits are even > slightly more likely to fail, then that's a win as far as I'm concerned > and may be the thing that prevents some helpless end user from getting > compromised. Well if it were a 1000x-1000000x difficulty improvement, I would say you had a point. But at 10x, it's just not a real obstacle. For instance, in this exploit: http://www.exploit-db.com/exploits/14814/ ..there's already detection of successful smashing, so working around not having /proc/slabinfo is as simple as putting the initial smash in a loop. I can probably improve my odds of success to nearly 100% by pre-allocating a ton of objects all at once to get my own private slab page and tidy adjoining allocations. I'll only fail if someone does a simultaneous allocation between my target objects or I happen to straddle slab pages. And once an exploit writer has figured that out once, everyone else just copies it (like they've copied the slabinfo technique). At which point, we might as well make the file more permissive again.. > > On the other hand, I'm not convinced the contents of this file are of > > much use to people without admin access. > > > > Exactly. We might as well do everything we can to make attackers' lives > more difficult, especially when the cost is so low. There are thousands of attackers and millions of users. Most of those millions are on single-user systems with no local attackers. For every attacker's life we make trivially more difficult, we're also making a few real user's lives more difficult. It's not obvious that this is a good trade-off. -- Mathematics is the supreme nostalgia of our time. -- To unsubscribe, send a message with 'unsubscribe linux-mm' in the body to majordomo@xxxxxxxxxx For more info on Linux MM, see: http://www.linux-mm.org/ . Fight unfair telecom internet charges in Canada: sign http://stopthemeter.ca/ Don't email: <a href=mailto:"dont@xxxxxxxxx"> email@xxxxxxxxx </a>