diff options
author | Joshua Kinard <kumba@gentoo.org> | 2004-07-23 01:54:38 +0000 |
---|---|---|
committer | Joshua Kinard <kumba@gentoo.org> | 2004-07-23 01:54:38 +0000 |
commit | d37cf1d910b598443b506fb351a0708d9c92fe80 (patch) | |
tree | 370e25dd901788715c1c601d3660eb5e1fd0cf7e /sys-kernel/mips-sources | |
parent | Version bump, bumped using abeni! (diff) | |
download | historical-d37cf1d910b598443b506fb351a0708d9c92fe80.tar.gz historical-d37cf1d910b598443b506fb351a0708d9c92fe80.tar.bz2 historical-d37cf1d910b598443b506fb351a0708d9c92fe80.zip |
Added security patches for 2.6.x kernels for the following vulns: CAN-2004-0495, CAN-2004-0496, CAN-2004-0497, & CAN-2004-0596.
Diffstat (limited to 'sys-kernel/mips-sources')
-rw-r--r-- | sys-kernel/mips-sources/ChangeLog | 14 | ||||
-rw-r--r-- | sys-kernel/mips-sources/Manifest | 61 | ||||
-rw-r--r-- | sys-kernel/mips-sources/files/CAN-2004-0495_0496-2.6-sparse.patch | 911 | ||||
-rw-r--r-- | sys-kernel/mips-sources/files/CAN-2004-0497-2.6-attr_gid.patch | 26 | ||||
-rw-r--r-- | sys-kernel/mips-sources/files/CAN-2004-0596-2.6-eql.patch | 46 | ||||
-rw-r--r-- | sys-kernel/mips-sources/files/digest-mips-sources-2.6.4-r5 (renamed from sys-kernel/mips-sources/files/digest-mips-sources-2.6.4-r4) | 0 | ||||
-rw-r--r-- | sys-kernel/mips-sources/files/digest-mips-sources-2.6.5-r4 (renamed from sys-kernel/mips-sources/files/digest-mips-sources-2.6.5-r3) | 0 | ||||
-rw-r--r-- | sys-kernel/mips-sources/files/digest-mips-sources-2.6.6-r3 (renamed from sys-kernel/mips-sources/files/digest-mips-sources-2.6.6-r2) | 0 | ||||
-rw-r--r-- | sys-kernel/mips-sources/files/digest-mips-sources-2.6.7-r2 (renamed from sys-kernel/mips-sources/files/digest-mips-sources-2.6.7-r1) | 0 | ||||
-rw-r--r-- | sys-kernel/mips-sources/mips-sources-2.6.4-r5.ebuild (renamed from sys-kernel/mips-sources/mips-sources-2.6.4-r4.ebuild) | 5 | ||||
-rw-r--r-- | sys-kernel/mips-sources/mips-sources-2.6.5-r4.ebuild (renamed from sys-kernel/mips-sources/mips-sources-2.6.5-r3.ebuild) | 7 | ||||
-rw-r--r-- | sys-kernel/mips-sources/mips-sources-2.6.6-r3.ebuild (renamed from sys-kernel/mips-sources/mips-sources-2.6.6-r2.ebuild) | 5 | ||||
-rw-r--r-- | sys-kernel/mips-sources/mips-sources-2.6.7-r2.ebuild (renamed from sys-kernel/mips-sources/mips-sources-2.6.7-r1.ebuild) | 4 |
13 files changed, 1043 insertions, 36 deletions
diff --git a/sys-kernel/mips-sources/ChangeLog b/sys-kernel/mips-sources/ChangeLog index 5a71632a2d72..a4361d289b58 100644 --- a/sys-kernel/mips-sources/ChangeLog +++ b/sys-kernel/mips-sources/ChangeLog @@ -1,6 +1,18 @@ # ChangeLog for sys-kernel/mips-sources # Copyright 2002-2004 Gentoo Foundation; Distributed under the GPL v2 -# $Header: /var/cvsroot/gentoo-x86/sys-kernel/mips-sources/ChangeLog,v 1.48 2004/07/13 09:28:43 kumba Exp $ +# $Header: /var/cvsroot/gentoo-x86/sys-kernel/mips-sources/ChangeLog,v 1.49 2004/07/23 01:54:38 kumba Exp $ + +*mips-sources-2.6.5-r4 (22 Jul 2004) + + 22 Jul 2004; Joshua Kinard <kumba@gentoo.org> + +files/CAN-2004-0495_0496-2.6-sparse.patch, + +files/CAN-2004-0497-2.6-attr_gid.patch, +files/CAN-2004-0596-2.6-eql.patch, + -mips-sources-2.6.4-r4.ebuild, +mips-sources-2.6.4-r5.ebuild, + -mips-sources-2.6.5-r3.ebuild, +mips-sources-2.6.5-r4.ebuild, + -mips-sources-2.6.6-r2.ebuild, +mips-sources-2.6.6-r3.ebuild, + -mips-sources-2.6.7-r1.ebuild, +mips-sources-2.6.7-r2.ebuild: + Added security patches for 2.6.x kernels for the following vulns: + CAN-2004-0495, CAN-2004-0496, CAN-2004-0497, & CAN-2004-0596. *mips-sources-2.4.26-r4 (13 Jul 2004) diff --git a/sys-kernel/mips-sources/Manifest b/sys-kernel/mips-sources/Manifest index 2f7c833cc149..31ac62f5c693 100644 --- a/sys-kernel/mips-sources/Manifest +++ b/sys-kernel/mips-sources/Manifest @@ -1,41 +1,44 @@ -MD5 1bc51ca8a4d4fe12de6aa60718c52bf2 mips-sources-2.6.5-r3.ebuild 3442 -MD5 5d26b3d99696abdc1254f059070a01b1 mips-sources-2.6.6-r2.ebuild 2929 -MD5 e586436895900cdc5f9affe6a2a49659 mips-sources-2.4.26-r4.ebuild 2159 -MD5 51be9f07387cd67fc1e0930ca22bfc68 mips-sources-2.6.7-r1.ebuild 2970 +MD5 1ecb6f1a34c40c2b40c85baa51d8c94d ChangeLog 17529 +MD5 ad25a2a0b6ade60c13ad8040f3c319c6 metadata.xml 378 MD5 45a85264645dca2b1b96dd9cea7214a4 mips-sources-2.4.25-r4.ebuild 2802 MD5 9cc9e13952d9f6cb99ab8cc83bf7ca1a mips-sources-2.4.26-r3.ebuild 2159 -MD5 8844236c0385231b34d54630f74377f1 mips-sources-2.6.4-r4.ebuild 3306 -MD5 f11f0b3f73f212f0c776e2423a418bc3 ChangeLog 16929 -MD5 ad25a2a0b6ade60c13ad8040f3c319c6 metadata.xml 378 -MD5 5674421c7e2c7e50e2509bed7d96c4d4 files/CAN-2004-0427-2.6-do_fork.patch 332 +MD5 7f9f0b9a1286a82e3dfd6ba8bde1984c mips-sources-2.6.4-r5.ebuild 3463 +MD5 32ec4576d091948ffbc7486be647fe33 mips-sources-2.6.5-r4.ebuild 3531 +MD5 872553ec0758055e9c8cffd1e1fa4b99 mips-sources-2.6.6-r3.ebuild 3086 +MD5 40e0ddafb10021b4b65b7a24ab65fa09 mips-sources-2.6.7-r2.ebuild 3070 +MD5 e586436895900cdc5f9affe6a2a49659 mips-sources-2.4.26-r4.ebuild 2159 +MD5 6f4bba5dda7a99d77b1564f5489fef6e files/CAN-2004-0075-2.6-vicam_usb.patch 1129 +MD5 21f3a4f186017d925067335e24db36a1 files/CAN-2004-0109-2.4-iso9660.patch 1877 MD5 31ec7b4310dd7be3e34aab0204f9b1e8 files/CAN-2004-0109-2.6-iso9660.patch 2072 -MD5 c65ca9f967d25e79aadfe387f7ce6fa3 files/mipscvs-2.6.x-no-page-align.patch 483 -MD5 1dd59d14a720c0c23e47e28d0b4fd6f9 files/CAN-2004-0228-cpufreq.patch 437 -MD5 de75cfa969ed092578d9ddda6c5be334 files/CAN-2004-0181-2.4-jfs_ext3.patch 1233 MD5 5bf9836a632a861728d33f9736bb7431 files/CAN-2004-0133-xfs_ext3.patch 427 +MD5 eaeda68a619caaddd5b8fdc5e7c39932 files/CAN-2004-0177-ext3_jbd.patch 384 +MD5 ac42024b6e6ee1e2165914db4b22a61c files/CAN-2004-0178-sbblaster.patch 424 +MD5 de75cfa969ed092578d9ddda6c5be334 files/CAN-2004-0181-2.4-jfs_ext3.patch 1233 +MD5 c8b7be9ee0da1415fa0274da5859aa62 files/CAN-2004-0181-2.6-jfs_ext3.patch 1366 +MD5 1dd59d14a720c0c23e47e28d0b4fd6f9 files/CAN-2004-0228-cpufreq.patch 437 +MD5 a92712e41465c49670ef7a54c2d16040 files/CAN-2004-0229-fb_copy_cmap.patch 471 MD5 d4a740ae56c2049247083af387a22a85 files/CAN-2004-0394-panic.patch 350 -MD5 95ba3093147f4188db0ea4949e4317cf files/mipscvs-2.4.25-makefile-inlinelimit.patch 1588 +MD5 c460ea130cb4ae84a5063ba044e3ce72 files/CAN-2004-0427-2.4-do_fork.patch 460 +MD5 5674421c7e2c7e50e2509bed7d96c4d4 files/CAN-2004-0427-2.6-do_fork.patch 332 MD5 5c6bf5770bf59976861382f45bdeb7ff files/digest-mips-sources-2.4.25-r4 217 MD5 098807e58d4f8bc7efcaea114ba28fcd files/digest-mips-sources-2.4.26-r3 218 -MD5 1e86c5a6d88da0ee787ddda716a86502 files/digest-mips-sources-2.4.26-r4 218 -MD5 db1aaa77e691906f3857e54e363c4ff4 files/mipscvs-2.6.5-unistd-linkage.patch 515 -MD5 a92712e41465c49670ef7a54c2d16040 files/CAN-2004-0229-fb_copy_cmap.patch 471 -MD5 eaeda68a619caaddd5b8fdc5e7c39932 files/CAN-2004-0177-ext3_jbd.patch 384 -MD5 497365345d8a39da49a8bd2495a17d8c files/digest-mips-sources-2.6.4-r4 299 -MD5 eb9f26d678449f22ce5b7c00762eeb91 files/digest-mips-sources-2.6.5-r3 299 -MD5 ff47ec7e8b4282773743aa192d3a73b6 files/digest-mips-sources-2.6.6-r2 299 -MD5 5b7a4b7f8c4baea56b4cd1332cb0948b files/digest-mips-sources-2.6.7-r1 299 +MD5 eb70acb35ba13daa4b1fda53cb61fc01 files/CAN-2004-0495_0496-2.6-sparse.patch 23861 +MD5 95708646470a95668e8789cd415844ed files/CAN-2004-0497-2.6-attr_gid.patch 846 +MD5 8204afea1d572b49a4a80d8da4eef0c9 files/CAN-2004-0596-2.6-eql.patch 1033 +MD5 497365345d8a39da49a8bd2495a17d8c files/digest-mips-sources-2.6.4-r5 299 MD5 fbb6766828584e454bf053286aad6207 files/mipscvs-2.4.25-makefile-fix.patch 428 -MD5 6f4bba5dda7a99d77b1564f5489fef6e files/CAN-2004-0075-2.6-vicam_usb.patch 1129 -MD5 008eff91c704bd23097666a1cd94ada3 files/mipscvs-2.6.5-swapbug-fix.patch 1329 -MD5 c8b7be9ee0da1415fa0274da5859aa62 files/CAN-2004-0181-2.6-jfs_ext3.patch 1366 -MD5 0f66013f643c79c97fda489618a4e2fd files/CAN-2004-0535-2.4-e1000.patch 476 +MD5 95ba3093147f4188db0ea4949e4317cf files/mipscvs-2.4.25-makefile-inlinelimit.patch 1588 +MD5 764740b749fd1f81313aa941c55000ac files/mipscvs-2.4.25-no-page-align.patch 1013 MD5 fbb6766828584e454bf053286aad6207 files/mipscvs-2.4.26-makefile-fix.patch 428 -MD5 c460ea130cb4ae84a5063ba044e3ce72 files/CAN-2004-0427-2.4-do_fork.patch 460 -MD5 dc18e982f8149588a291956481885a8c files/CAN-2004-0495-2.4-sparse.patch 17549 -MD5 21f3a4f186017d925067335e24db36a1 files/CAN-2004-0109-2.4-iso9660.patch 1877 +MD5 008eff91c704bd23097666a1cd94ada3 files/mipscvs-2.6.5-swapbug-fix.patch 1329 +MD5 db1aaa77e691906f3857e54e363c4ff4 files/mipscvs-2.6.5-unistd-linkage.patch 515 MD5 2802496e6b2dcc4e5ff19fac6826c7f7 files/mipscvs-2.6.7-maceisa_rtc_irq-fix.patch 339 -MD5 ac42024b6e6ee1e2165914db4b22a61c files/CAN-2004-0178-sbblaster.patch 424 +MD5 c65ca9f967d25e79aadfe387f7ce6fa3 files/mipscvs-2.6.x-no-page-align.patch 483 MD5 fd5b99bc2a9e4c7f9825c9aab6a76b52 files/misc-2.6-iptables_headers.patch 1786 -MD5 764740b749fd1f81313aa941c55000ac files/mipscvs-2.4.25-no-page-align.patch 1013 +MD5 dc18e982f8149588a291956481885a8c files/CAN-2004-0495-2.4-sparse.patch 17549 +MD5 0f66013f643c79c97fda489618a4e2fd files/CAN-2004-0535-2.4-e1000.patch 476 MD5 c91330cc5b4044b6f59696095c2dc0fb files/CAN-2004-0626-death_packet.patch 423 +MD5 1e86c5a6d88da0ee787ddda716a86502 files/digest-mips-sources-2.4.26-r4 218 +MD5 eb9f26d678449f22ce5b7c00762eeb91 files/digest-mips-sources-2.6.5-r4 299 +MD5 ff47ec7e8b4282773743aa192d3a73b6 files/digest-mips-sources-2.6.6-r3 299 +MD5 5b7a4b7f8c4baea56b4cd1332cb0948b files/digest-mips-sources-2.6.7-r2 299 diff --git a/sys-kernel/mips-sources/files/CAN-2004-0495_0496-2.6-sparse.patch b/sys-kernel/mips-sources/files/CAN-2004-0495_0496-2.6-sparse.patch new file mode 100644 index 000000000000..6f67f9fdc912 --- /dev/null +++ b/sys-kernel/mips-sources/files/CAN-2004-0495_0496-2.6-sparse.patch @@ -0,0 +1,911 @@ +# <plasmaroo@gentoo.org> +# This is a patch which should fix both CAN-2004-0495 and CAN-2004-0496 on 2.6... + +# * -0495 applies to 2.4 as well; use a separate patch for that. +# * -0496 is a 2.6 only issue which this patch addresses. + +--- 1.20/net/decnet/dn_dev.c 2004-07-21 14:50:27 -07:00 ++++ 1.21/net/decnet/dn_dev.c 2004-07-21 14:50:27 -07:00 +@@ -1294,35 +1294,43 @@ + * it as a compile time option. Probably you should use the + * rtnetlink interface instead. + */ +-int dnet_gifconf(struct net_device *dev, char *buf, int len) ++int dnet_gifconf(struct net_device *dev, char __user *buf, int len) + { + struct dn_dev *dn_db = (struct dn_dev *)dev->dn_ptr; + struct dn_ifaddr *ifa; +- struct ifreq *ifr = (struct ifreq *)buf; ++ char buffer[DN_IFREQ_SIZE]; ++ struct ifreq *ifr = (struct ifreq *)buffer; ++ struct sockaddr_dn *addr = (struct sockaddr_dn *)&ifr->ifr_addr; + int done = 0; + + if ((dn_db == NULL) || ((ifa = dn_db->ifa_list) == NULL)) + return 0; + + for(; ifa; ifa = ifa->ifa_next) { +- if (!ifr) { ++ if (!buf) { + done += sizeof(DN_IFREQ_SIZE); + continue; + } + if (len < DN_IFREQ_SIZE) + return done; +- memset(ifr, 0, DN_IFREQ_SIZE); ++ memset(buffer, 0, DN_IFREQ_SIZE); + + if (ifa->ifa_label) + strcpy(ifr->ifr_name, ifa->ifa_label); + else + strcpy(ifr->ifr_name, dev->name); + +- (*(struct sockaddr_dn *) &ifr->ifr_addr).sdn_family = AF_DECnet; +- (*(struct sockaddr_dn *) &ifr->ifr_addr).sdn_add.a_len = 2; +- (*(dn_address *)(*(struct sockaddr_dn *) &ifr->ifr_addr).sdn_add.a_addr) = ifa->ifa_local; ++ addr->sdn_family = AF_DECnet; ++ addr->sdn_add.a_len = 2; ++ memcpy(addr->sdn_add.a_addr, &ifa->ifa_local, ++ sizeof(dn_address)); + +- ifr = (struct ifreq *)((char *)ifr + DN_IFREQ_SIZE); ++ if (copy_to_user(buf, buffer, DN_IFREQ_SIZE)) { ++ done = -EFAULT; ++ break; ++ } ++ ++ buf += DN_IFREQ_SIZE; + len -= DN_IFREQ_SIZE; + done += DN_IFREQ_SIZE; + } +--- 1.90/drivers/net/wireless/airo.c 2004-07-21 14:48:16 -07:00 ++++ 1.91/drivers/net/wireless/airo.c 2004-07-21 14:48:16 -07:00 +@@ -4272,12 +4272,12 @@ + */ + + static ssize_t proc_read( struct file *file, +- char *buffer, ++ char __user *buffer, + size_t len, + loff_t *offset); + + static ssize_t proc_write( struct file *file, +- const char *buffer, ++ const char __user *buffer, + size_t len, + loff_t *offset ); + static int proc_close( struct inode *inode, struct file *file ); +@@ -4482,23 +4482,26 @@ + * to supply the data. + */ + static ssize_t proc_read( struct file *file, +- char *buffer, ++ char __user *buffer, + size_t len, + loff_t *offset ) + { +- int i; +- int pos; ++ loff_t pos = *offset; + struct proc_data *priv = (struct proc_data*)file->private_data; + +- if( !priv->rbuffer ) return -EINVAL; ++ if (!priv->rbuffer) ++ return -EINVAL; + +- pos = *offset; +- for( i = 0; i+pos < priv->readlen && i < len; i++ ) { +- if (put_user( priv->rbuffer[i+pos], buffer+i )) +- return -EFAULT; +- } +- *offset += i; +- return i; ++ if (pos < 0) ++ return -EINVAL; ++ if (pos >= priv->readlen) ++ return 0; ++ if (len > priv->readlen - pos) ++ len = priv->readlen - pos; ++ if (copy_to_user(buffer, priv->rbuffer + pos, len)) ++ return -EFAULT; ++ *offset = pos + len; ++ return len; + } + + /* +@@ -4506,28 +4509,26 @@ + * to supply the data. + */ + static ssize_t proc_write( struct file *file, +- const char *buffer, ++ const char __user *buffer, + size_t len, + loff_t *offset ) + { +- int i; +- int pos; ++ loff_t pos = *offset; + struct proc_data *priv = (struct proc_data*)file->private_data; + +- if ( !priv->wbuffer ) { ++ if (!priv->wbuffer) + return -EINVAL; +- } +- +- pos = *offset; + +- for( i = 0; i + pos < priv->maxwritelen && +- i < len; i++ ) { +- if (get_user( priv->wbuffer[i+pos], buffer + i )) +- return -EFAULT; +- } +- if ( i+pos > priv->writelen ) priv->writelen = i+file->f_pos; +- *offset += i; +- return i; ++ if (pos < 0) ++ return -EINVAL; ++ if (pos >= priv->maxwritelen) ++ return 0; ++ if (len > priv->maxwritelen - pos) ++ len = priv->maxwritelen - pos; ++ if (copy_from_user(priv->wbuffer + pos, buffer, len)) ++ return -EFAULT; ++ *offset = pos + len; ++ return len; + } + + static int proc_status_open( struct inode *inode, struct file *file ) { +--- 1.14/sound/oss/mpu401.c 2004-07-21 14:44:27 -07:00 ++++ 1.15/sound/oss/mpu401.c 2004-07-21 14:44:27 -07:00 +@@ -728,7 +728,7 @@ + return 0; + } + +-static int mpu401_ioctl(int dev, unsigned cmd, caddr_t arg) ++static int mpu401_ioctl(int dev, unsigned cmd, void __user *arg) + { + struct mpu_config *devc; + mpu_command_rec rec; +@@ -742,7 +742,7 @@ + printk(KERN_WARNING "mpu401: Intelligent mode not supported by the HW\n"); + return -EINVAL; + } +- if (get_user(val, (int *)arg)) ++ if (get_user(val, (int __user *)arg)) + return -EFAULT; + set_uart_mode(dev, devc, !val); + return 0; +@@ -772,8 +772,7 @@ + */ + } + +-static int mpu_synth_ioctl(int dev, +- unsigned int cmd, caddr_t arg) ++static int mpu_synth_ioctl(int dev, unsigned int cmd, void __user *arg) + { + int midi_dev; + struct mpu_config *devc; +@@ -789,8 +788,7 @@ + { + + case SNDCTL_SYNTH_INFO: +- if (copy_to_user((&((char *) arg)[0]), +- (char *) &mpu_synth_info[midi_dev], ++ if (copy_to_user(arg, &mpu_synth_info[midi_dev], + sizeof(struct synth_info))) + return -EFAULT; + return 0; +@@ -1508,17 +1506,19 @@ + return curr_ticks; + } + +-static int mpu_timer_ioctl(int dev, unsigned int command, caddr_t arg) ++static int mpu_timer_ioctl(int dev, unsigned int command, void __user *arg) + { + int midi_dev = sound_timer_devs[dev]->devlink; ++ int __user *p = (int __user *)arg; + + switch (command) + { + case SNDCTL_TMR_SOURCE: + { + int parm; +- +- parm = *(int *) arg; ++ ++ if (get_user(parm, p)) ++ return -EFAULT; + parm &= timer_caps; + + if (parm != 0) +@@ -1530,7 +1530,9 @@ + else if (timer_mode & TMR_MODE_SMPTE) + mpu_cmd(midi_dev, 0x3d, 0); /* Use SMPTE sync */ + } +- return (*(int *) arg = timer_mode); ++ if (put_user(timer_mode, p)) ++ return -EFAULT; ++ return timer_mode; + } + break; + +@@ -1554,11 +1556,13 @@ + case SNDCTL_TMR_TIMEBASE: + { + int val; +- +- val = *(int *) arg; ++ if (get_user(val, p)) ++ return -EFAULT; + if (val) + set_timebase(midi_dev, val); +- return (*(int *) arg = curr_timebase); ++ if (put_user(curr_timebase, p)) ++ return -EFAULT; ++ return curr_timebase; + } + break; + +@@ -1567,7 +1571,8 @@ + int val; + int ret; + +- val = *(int *) arg; ++ if (get_user(val, p)) ++ return -EFAULT; + + if (val) + { +@@ -1582,26 +1587,35 @@ + } + curr_tempo = val; + } +- return (*(int *) arg = curr_tempo); ++ if (put_user(curr_tempo, p)) ++ return -EFAULT; ++ return curr_tempo; + } + break; + + case SNDCTL_SEQ_CTRLRATE: + { + int val; ++ if (get_user(val, p)) ++ return -EFAULT; + +- val = *(int *) arg; + if (val != 0) /* Can't change */ + return -EINVAL; +- return (*(int *) arg = ((curr_tempo * curr_timebase) + 30) / 60); ++ val = ((curr_tempo * curr_timebase) + 30)/60; ++ if (put_user(val, p)) ++ return -EFAULT; ++ return val; + } + break; + + case SNDCTL_SEQ_GETTIME: +- return (*(int *) arg = curr_ticks); ++ if (put_user(curr_ticks, p)) ++ return -EFAULT; ++ return curr_ticks; + + case SNDCTL_TMR_METRONOME: +- metronome_mode = *(int *) arg; ++ if (get_user(metronome_mode, p)) ++ return -EFAULT; + setup_metronome(midi_dev); + return 0; + +--- 1.11/drivers/acpi/asus_acpi.c 2004-07-21 14:16:19 -07:00 ++++ 1.12/drivers/acpi/asus_acpi.c 2004-07-21 14:16:19 -07:00 +@@ -40,6 +40,7 @@ + #include <linux/proc_fs.h> + #include <acpi/acpi_drivers.h> + #include <acpi/acpi_bus.h> ++#include <asm/uaccess.h> + + #define ASUS_ACPI_VERSION "0.28" + +@@ -480,16 +481,31 @@ + return (hotk->status & ledmask) ? 1 : 0; + } + ++static int parse_arg(const char __user *buf, unsigned long count, int *val) ++{ ++ char s[32]; ++ if (!count) ++ return 0; ++ if (count > 31) ++ return -EINVAL; ++ if (copy_from_user(s, buf, count)) ++ return -EFAULT; ++ s[count] = 0; ++ if (sscanf(s, "%i", val) != 1) ++ return -EINVAL; ++ return count; ++} + + /* FIXME: kill extraneous args so it can be called independently */ + static int +-write_led(const char *buffer, unsigned long count, struct asus_hotk *hotk, ++write_led(const char __user *buffer, unsigned long count, struct asus_hotk *hotk, + char *ledname, int ledmask, int invert) + { + int value; + int led_out = 0; + +- if (sscanf(buffer, "%i", &value) == 1) ++ count = parse_arg(buffer, count, &value); ++ if (count > 0) + led_out = value ? 1 : 0; + + hotk->status = +@@ -518,7 +534,7 @@ + + + static int +-proc_write_mled(struct file *file, const char *buffer, ++proc_write_mled(struct file *file, const char __user *buffer, + unsigned long count, void *data) + { + struct asus_hotk *hotk = (struct asus_hotk *) data; +@@ -537,7 +553,7 @@ + } + + static int +-proc_write_wled(struct file *file, const char *buffer, ++proc_write_wled(struct file *file, const char __user *buffer, + unsigned long count, void *data) + { + struct asus_hotk *hotk = (struct asus_hotk *) data; +@@ -556,7 +572,7 @@ + } + + static int +-proc_write_tled(struct file *file, const char *buffer, ++proc_write_tled(struct file *file, const char __user *buffer, + unsigned long count, void *data) + { + struct asus_hotk *hotk = (struct asus_hotk *) data; +@@ -640,13 +656,14 @@ + + + static int +-proc_write_lcd(struct file *file, const char *buffer, ++proc_write_lcd(struct file *file, const char __user *buffer, + unsigned long count, void *data) + { + int value; + struct asus_hotk *hotk = (struct asus_hotk *) data; + +- if (sscanf(buffer, "%i", &value) == 1) ++ count = parse_arg(buffer, count, &value); ++ if (count > 0) + set_lcd_state(hotk, value); + return count; + } +@@ -707,17 +724,18 @@ + } + + static int +-proc_write_brn(struct file *file, const char *buffer, ++proc_write_brn(struct file *file, const char __user *buffer, + unsigned long count, void *data) + { + int value; + struct asus_hotk *hotk = (struct asus_hotk *) data; + +- if (sscanf(buffer, "%d", &value) == 1) { ++ count = parse_arg(buffer, count, &value); ++ if (count > 0) { + value = (0 < value) ? ((15 < value) ? 15 : value) : 0; + /* 0 <= value <= 15 */ + set_brightness(value, hotk); +- } else { ++ } else if (count < 0) { + printk(KERN_WARNING "Asus ACPI: Error reading user input\n"); + } + +@@ -756,17 +774,17 @@ + * simultaneously, so be warned. See the acpi4asus README for more info. + */ + static int +-proc_write_disp(struct file *file, const char *buffer, ++proc_write_disp(struct file *file, const char __user *buffer, + unsigned long count, void *data) + { + int value; + struct asus_hotk *hotk = (struct asus_hotk *) data; + +- if (sscanf(buffer, "%d", &value) == 1) ++ count = parse_arg(buffer, count, &value); ++ if (count > 0) + set_display(value, hotk); +- else { ++ else if (count < 0) + printk(KERN_WARNING "Asus ACPI: Error reading user input\n"); +- } + + return count; + } +@@ -774,7 +792,7 @@ + + typedef int (proc_readfunc)(char *page, char **start, off_t off, int count, + int *eof, void *data); +-typedef int (proc_writefunc)(struct file *file, const char *buffer, ++typedef int (proc_writefunc)(struct file *file, const char __user *buffer, + unsigned long count, void *data); + + static int +--- 1.30/sound/core/timer.c 2004-07-21 14:22:06 -07:00 ++++ 1.31/sound/core/timer.c 2004-07-21 14:22:06 -07:00 +@@ -1437,7 +1437,7 @@ + err = -ENODEV; + } + up(®ister_mutex); +- if (err >= 0 && copy_from_user(_gstatus, &gstatus, sizeof(gstatus))) ++ if (err >= 0 && copy_to_user(_gstatus, &gstatus, sizeof(gstatus))) + err = -EFAULT; + return err; + } +--- 1.11/sound/oss/pss.c 2004-07-21 14:25:23 -07:00 ++++ 1.12/sound/oss/pss.c 2004-07-21 14:25:23 -07:00 +@@ -453,20 +453,36 @@ + } + } + +-static void arg_to_volume_mono(unsigned int volume, int *aleft) ++static int set_volume_mono(unsigned __user *p, int *aleft) + { + int left; ++ unsigned volume; ++ if (get_user(volume, p)) ++ return -EFAULT; + +- left = volume & 0x00ff; ++ left = volume & 0xff; + if (left > 100) + left = 100; + *aleft = left; ++ return 0; + } + +-static void arg_to_volume_stereo(unsigned int volume, int *aleft, int *aright) ++static int set_volume_stereo(unsigned __user *p, int *aleft, int *aright) + { +- arg_to_volume_mono(volume, aleft); +- arg_to_volume_mono(volume >> 8, aright); ++ int left, right; ++ unsigned volume; ++ if (get_user(volume, p)) ++ return -EFAULT; ++ ++ left = volume & 0xff; ++ if (left > 100) ++ left = 100; ++ right = (volume >> 8) & 0xff; ++ if (right > 100) ++ right = 100; ++ *aleft = left; ++ *aright = right; ++ return 0; + } + + static int ret_vol_mono(int left) +@@ -479,7 +495,7 @@ + return ((right << 8) | left); + } + +-static int call_ad_mixer(pss_confdata *devc,unsigned int cmd, caddr_t arg) ++static int call_ad_mixer(pss_confdata *devc,unsigned int cmd, void __user *arg) + { + if (devc->ad_mixer_dev != NO_WSS_MIXER) + return mixer_devs[devc->ad_mixer_dev]->ioctl(devc->ad_mixer_dev, cmd, arg); +@@ -487,7 +503,7 @@ + return -EINVAL; + } + +-static int pss_mixer_ioctl (int dev, unsigned int cmd, caddr_t arg) ++static int pss_mixer_ioctl (int dev, unsigned int cmd, void __user *arg) + { + pss_confdata *devc = mixer_devs[dev]->devc; + int cmdf = cmd & 0xff; +@@ -513,33 +529,38 @@ + return call_ad_mixer(devc, cmd, arg); + else + { +- if (*(int *)arg != 0) ++ int v; ++ if (get_user(v, (int __user *)arg)) ++ return -EFAULT; ++ if (v != 0) + return -EINVAL; + return 0; + } + case SOUND_MIXER_VOLUME: +- arg_to_volume_stereo(*(unsigned int *)arg, &devc->mixer.volume_l, +- &devc->mixer.volume_r); ++ if (set_volume_stereo(arg, ++ &devc->mixer.volume_l, ++ &devc->mixer.volume_r)) ++ return -EFAULT; + set_master_volume(devc, devc->mixer.volume_l, + devc->mixer.volume_r); + return ret_vol_stereo(devc->mixer.volume_l, + devc->mixer.volume_r); + + case SOUND_MIXER_BASS: +- arg_to_volume_mono(*(unsigned int *)arg, +- &devc->mixer.bass); ++ if (set_volume_mono(arg, &devc->mixer.bass)) ++ return -EFAULT; + set_bass(devc, devc->mixer.bass); + return ret_vol_mono(devc->mixer.bass); + + case SOUND_MIXER_TREBLE: +- arg_to_volume_mono(*(unsigned int *)arg, +- &devc->mixer.treble); ++ if (set_volume_mono(arg, &devc->mixer.treble)) ++ return -EFAULT; + set_treble(devc, devc->mixer.treble); + return ret_vol_mono(devc->mixer.treble); + + case SOUND_MIXER_SYNTH: +- arg_to_volume_mono(*(unsigned int *)arg, +- &devc->mixer.synth); ++ if (set_volume_mono(arg, &devc->mixer.synth)) ++ return -EFAULT; + set_synth_volume(devc, devc->mixer.synth); + return ret_vol_mono(devc->mixer.synth); + +@@ -549,54 +570,67 @@ + } + else + { ++ int val, and_mask = 0, or_mask = 0; + /* + * Return parameters + */ + switch (cmdf) + { +- + case SOUND_MIXER_DEVMASK: + if (call_ad_mixer(devc, cmd, arg) == -EINVAL) +- *(int *)arg = 0; /* no mixer devices */ +- return (*(int *)arg |= SOUND_MASK_VOLUME | SOUND_MASK_BASS | SOUND_MASK_TREBLE | SOUND_MASK_SYNTH); ++ break; ++ and_mask = ~0; ++ or_mask = SOUND_MASK_VOLUME | SOUND_MASK_BASS | SOUND_MASK_TREBLE | SOUND_MASK_SYNTH; ++ break; + + case SOUND_MIXER_STEREODEVS: + if (call_ad_mixer(devc, cmd, arg) == -EINVAL) +- *(int *)arg = 0; /* no stereo devices */ +- return (*(int *)arg |= SOUND_MASK_VOLUME); ++ break; ++ and_mask = ~0; ++ or_mask = SOUND_MASK_VOLUME; ++ break; + + case SOUND_MIXER_RECMASK: + if (devc->ad_mixer_dev != NO_WSS_MIXER) + return call_ad_mixer(devc, cmd, arg); +- else +- return (*(int *)arg = 0); /* no record devices */ ++ break; + + case SOUND_MIXER_CAPS: + if (devc->ad_mixer_dev != NO_WSS_MIXER) + return call_ad_mixer(devc, cmd, arg); +- else +- return (*(int *)arg = SOUND_CAP_EXCL_INPUT); ++ or_mask = SOUND_CAP_EXCL_INPUT; ++ break; + + case SOUND_MIXER_RECSRC: + if (devc->ad_mixer_dev != NO_WSS_MIXER) + return call_ad_mixer(devc, cmd, arg); +- else +- return (*(int *)arg = 0); /* no record source */ ++ break; + + case SOUND_MIXER_VOLUME: +- return (*(int *)arg = ret_vol_stereo(devc->mixer.volume_l, devc->mixer.volume_r)); ++ or_mask = ret_vol_stereo(devc->mixer.volume_l, devc->mixer.volume_r); ++ break; + + case SOUND_MIXER_BASS: +- return (*(int *)arg = ret_vol_mono(devc->mixer.bass)); ++ or_mask = ret_vol_mono(devc->mixer.bass); ++ break; + + case SOUND_MIXER_TREBLE: +- return (*(int *)arg = ret_vol_mono(devc->mixer.treble)); ++ or_mask = ret_vol_mono(devc->mixer.treble); ++ break; + + case SOUND_MIXER_SYNTH: +- return (*(int *)arg = ret_vol_mono(devc->mixer.synth)); ++ or_mask = ret_vol_mono(devc->mixer.synth); ++ break; + default: + return -EINVAL; + } ++ if (get_user(val, (int __user *)arg)) ++ return -EFAULT; ++ val &= and_mask; ++ val |= or_mask; ++ if (put_user(val, (int __user *)arg)) ++ return -EFAULT; ++ return val; + } + } + +@@ -803,7 +837,7 @@ + return 0; + } + +-static int pss_coproc_ioctl(void *dev_info, unsigned int cmd, caddr_t arg, int local) ++static int pss_coproc_ioctl(void *dev_info, unsigned int cmd, void __user *arg, int local) + { + copr_buffer *buf; + copr_msg *mbuf; +--- 1.15/sound/oss/msnd_pinnacle.c 2004-07-21 14:51:56 -07:00 ++++ 1.16/sound/oss/msnd_pinnacle.c 2004-07-21 14:51:56 -07:00 +@@ -809,7 +809,7 @@ + + static __inline__ int pack_DARQ_to_DARF(register int bank) + { +- register int size, n, timeout = 3; ++ register int size, timeout = 3; + register WORD wTmp; + LPDAQD DAQD; + +@@ -830,13 +830,10 @@ + /* Read data from the head (unprotected bank 1 access okay + since this is only called inside an interrupt) */ + outb(HPBLKSEL_1, dev.io + HP_BLKS); +- if ((n = msnd_fifo_write( ++ msnd_fifo_write( + &dev.DARF, + (char *)(dev.base + bank * DAR_BUFF_SIZE), +- size, 0)) <= 0) { +- outb(HPBLKSEL_0, dev.io + HP_BLKS); +- return n; +- } ++ size); + outb(HPBLKSEL_0, dev.io + HP_BLKS); + + return 1; +@@ -858,21 +855,16 @@ + if (protect) { + /* Critical section: protect fifo in non-interrupt */ + spin_lock_irqsave(&dev.lock, flags); +- if ((n = msnd_fifo_read( ++ n = msnd_fifo_read( + &dev.DAPF, + (char *)(dev.base + bank_num * DAP_BUFF_SIZE), +- DAP_BUFF_SIZE, 0)) < 0) { +- spin_unlock_irqrestore(&dev.lock, flags); +- return n; +- } ++ DAP_BUFF_SIZE); + spin_unlock_irqrestore(&dev.lock, flags); + } else { +- if ((n = msnd_fifo_read( ++ n = msnd_fifo_read( + &dev.DAPF, + (char *)(dev.base + bank_num * DAP_BUFF_SIZE), +- DAP_BUFF_SIZE, 0)) < 0) { +- return n; +- } ++ DAP_BUFF_SIZE); + } + if (!n) + break; +@@ -899,30 +891,43 @@ + static int dsp_read(char *buf, size_t len) + { + int count = len; ++ char *page = (char *)__get_free_page(PAGE_SIZE); ++ ++ if (!page) ++ return -ENOMEM; + + while (count > 0) { +- int n; ++ int n, k; + unsigned long flags; + ++ k = PAGE_SIZE; ++ if (k > count) ++ k = count; ++ + /* Critical section: protect fifo in non-interrupt */ + spin_lock_irqsave(&dev.lock, flags); +- if ((n = msnd_fifo_read(&dev.DARF, buf, count, 1)) < 0) { +- printk(KERN_WARNING LOGNAME ": FIFO read error\n"); +- spin_unlock_irqrestore(&dev.lock, flags); +- return n; +- } ++ n = msnd_fifo_read(&dev.DARF, page, k); + spin_unlock_irqrestore(&dev.lock, flags); ++ if (copy_to_user(buf, page, n)) { ++ free_page((unsigned long)page); ++ return -EFAULT; ++ } + buf += n; + count -= n; + ++ if (n == k && count) ++ continue; ++ + if (!test_bit(F_READING, &dev.flags) && dev.mode & FMODE_READ) { + dev.last_recbank = -1; + if (chk_send_dsp_cmd(&dev, HDEX_RECORD_START) == 0) + set_bit(F_READING, &dev.flags); + } + +- if (dev.rec_ndelay) ++ if (dev.rec_ndelay) { ++ free_page((unsigned long)page); + return count == len ? -EAGAIN : len - count; ++ } + + if (count > 0) { + set_bit(F_READBLOCK, &dev.flags); +@@ -931,41 +936,57 @@ + get_rec_delay_jiffies(DAR_BUFF_SIZE))) + clear_bit(F_READING, &dev.flags); + clear_bit(F_READBLOCK, &dev.flags); +- if (signal_pending(current)) ++ if (signal_pending(current)) { ++ free_page((unsigned long)page); + return -EINTR; ++ } + } + } +- ++ free_page((unsigned long)page); + return len - count; + } + + static int dsp_write(const char *buf, size_t len) + { + int count = len; ++ char *page = (char *)__get_free_page(GFP_KERNEL); ++ ++ if (!page) ++ return -ENOMEM; + + while (count > 0) { +- int n; ++ int n, k; + unsigned long flags; + ++ k = PAGE_SIZE; ++ if (k > count) ++ k = count; ++ ++ if (copy_from_user(page, buf, k)) { ++ free_page((unsigned long)page); ++ return -EFAULT; ++ } ++ + /* Critical section: protect fifo in non-interrupt */ + spin_lock_irqsave(&dev.lock, flags); +- if ((n = msnd_fifo_write(&dev.DAPF, buf, count, 1)) < 0) { +- printk(KERN_WARNING LOGNAME ": FIFO write error\n"); +- spin_unlock_irqrestore(&dev.lock, flags); +- return n; +- } ++ n = msnd_fifo_write(&dev.DAPF, page, k); + spin_unlock_irqrestore(&dev.lock, flags); + buf += n; + count -= n; + ++ if (count && n == k) ++ continue; ++ + if (!test_bit(F_WRITING, &dev.flags) && (dev.mode & FMODE_WRITE)) { + dev.last_playbank = -1; + if (pack_DAPF_to_DAPQ(1) > 0) + set_bit(F_WRITING, &dev.flags); + } + +- if (dev.play_ndelay) ++ if (dev.play_ndelay) { ++ free_page((unsigned long)page); + return count == len ? -EAGAIN : len - count; ++ } + + if (count > 0) { + set_bit(F_WRITEBLOCK, &dev.flags); +@@ -973,11 +994,14 @@ + &dev.writeblock, + get_play_delay_jiffies(DAP_BUFF_SIZE)); + clear_bit(F_WRITEBLOCK, &dev.flags); +- if (signal_pending(current)) ++ if (signal_pending(current)) { ++ free_page((unsigned long)page); + return -EINTR; ++ } + } + } + ++ free_page((unsigned long)page); + return len - count; + } + +--- 1.2/sound/oss/msnd.h 2004-07-21 14:52:24 -07:00 ++++ 1.3/sound/oss/msnd.h 2004-07-21 14:52:24 -07:00 +@@ -266,8 +266,8 @@ + void msnd_fifo_free(msnd_fifo *f); + int msnd_fifo_alloc(msnd_fifo *f, size_t n); + void msnd_fifo_make_empty(msnd_fifo *f); +-int msnd_fifo_write(msnd_fifo *f, const char *buf, size_t len, int user); +-int msnd_fifo_read(msnd_fifo *f, char *buf, size_t len, int user); ++int msnd_fifo_write(msnd_fifo *f, const char *buf, size_t len); ++int msnd_fifo_read(msnd_fifo *f, char *buf, size_t len); + + int msnd_wait_TXDE(multisound_dev_t *dev); + int msnd_wait_HC0(multisound_dev_t *dev); +--- 1.8/sound/oss/msnd.c 2004-07-21 14:52:37 -07:00 ++++ 1.9/sound/oss/msnd.c 2004-07-21 14:52:37 -07:00 +@@ -139,13 +139,10 @@ + f->len = f->tail = f->head = 0; + } + +-int msnd_fifo_write(msnd_fifo *f, const char *buf, size_t len, int user) ++int msnd_fifo_write(msnd_fifo *f, const char *buf, size_t len) + { + int count = 0; + +- if (f->len == f->n) +- return 0; +- + while ((count < len) && (f->len != f->n)) { + + int nwritten; +@@ -161,11 +158,7 @@ + nwritten = len - count; + } + +- if (user) { +- if (copy_from_user(f->data + f->tail, buf, nwritten)) +- return -EFAULT; +- } else +- isa_memcpy_fromio(f->data + f->tail, (unsigned long) buf, nwritten); ++ isa_memcpy_fromio(f->data + f->tail, (unsigned long) buf, nwritten); + + count += nwritten; + buf += nwritten; +@@ -177,13 +170,10 @@ + return count; + } + +-int msnd_fifo_read(msnd_fifo *f, char *buf, size_t len, int user) ++int msnd_fifo_read(msnd_fifo *f, char *buf, size_t len) + { + int count = 0; + +- if (f->len == 0) +- return f->len; +- + while ((count < len) && (f->len > 0)) { + + int nread; +@@ -199,11 +189,7 @@ + nread = len - count; + } + +- if (user) { +- if (copy_to_user(buf, f->data + f->head, nread)) +- return -EFAULT; +- } else +- isa_memcpy_toio((unsigned long) buf, f->data + f->head, nread); ++ isa_memcpy_toio((unsigned long) buf, f->data + f->head, nread); + + count += nread; + buf += nread; diff --git a/sys-kernel/mips-sources/files/CAN-2004-0497-2.6-attr_gid.patch b/sys-kernel/mips-sources/files/CAN-2004-0497-2.6-attr_gid.patch new file mode 100644 index 000000000000..41b3196f84ea --- /dev/null +++ b/sys-kernel/mips-sources/files/CAN-2004-0497-2.6-attr_gid.patch @@ -0,0 +1,26 @@ +# This is a BitKeeper generated diff -Nru style patch. +# +# ChangeSet +# 2004/07/02 20:55:04-07:00 chrisw@osdl.org +# [PATCH] chown permission check fix for ATTR_GID +# +# SuSE discovered this problem with chown and ATTR_GID. Make sure user +# is authorized to change the group, CAN-2004-0497. +# +# fs/attr.c +# 2004/07/02 09:07:32-07:00 chrisw@osdl.org +2 -1 +# chown permission check fix for ATTR_GID +# +diff -Nru a/fs/attr.c b/fs/attr.c +--- a/fs/attr.c 2004-07-08 16:35:57 -07:00 ++++ b/fs/attr.c 2004-07-08 16:35:57 -07:00 +@@ -35,7 +35,8 @@ + + /* Make sure caller can chgrp. */ + if ((ia_valid & ATTR_GID) && +- (!in_group_p(attr->ia_gid) && attr->ia_gid != inode->i_gid) && ++ (current->fsuid != inode->i_uid || ++ (!in_group_p(attr->ia_gid) && attr->ia_gid != inode->i_gid)) && + !capable(CAP_CHOWN)) + goto error; + diff --git a/sys-kernel/mips-sources/files/CAN-2004-0596-2.6-eql.patch b/sys-kernel/mips-sources/files/CAN-2004-0596-2.6-eql.patch new file mode 100644 index 000000000000..3e20a2e41372 --- /dev/null +++ b/sys-kernel/mips-sources/files/CAN-2004-0596-2.6-eql.patch @@ -0,0 +1,46 @@ +--- 1.13/drivers/net/eql.c 2004-07-21 03:13:40 -07:00 ++++ 1.14/drivers/net/eql.c 2004-07-21 03:13:40 -07:00 +@@ -495,6 +495,8 @@ + return -EFAULT; + + slave_dev = dev_get_by_name(sc.slave_name); ++ if (!slave_dev) ++ return -ENODEV; + + ret = -EINVAL; + +@@ -527,11 +529,13 @@ + if (copy_from_user(&sc, scp, sizeof (slave_config_t))) + return -EFAULT; + +- eql = dev->priv; + slave_dev = dev_get_by_name(sc.slave_name); ++ if (!slave_dev) ++ return -ENODEV; + + ret = -EINVAL; + ++ eql = dev->priv; + spin_lock_bh(&eql->queue.lock); + if (eql_is_slave(slave_dev)) { + slave = __eql_find_slave_dev(&eql->queue, slave_dev); +--- 1.14/drivers/net/eql.c 2004-07-21 03:13:33 -07:00 ++++ 1.15/drivers/net/eql.c 2004-07-21 03:13:33 -07:00 +@@ -499,6 +499,8 @@ + return -ENODEV; + + ret = -EINVAL; ++ if (!slave_dev) ++ return ret; + + spin_lock_bh(&eql->queue.lock); + if (eql_is_slave(slave_dev)) { +@@ -534,6 +536,8 @@ + return -ENODEV; + + ret = -EINVAL; ++ if (!slave_dev) ++ return ret; + + eql = dev->priv; + spin_lock_bh(&eql->queue.lock); diff --git a/sys-kernel/mips-sources/files/digest-mips-sources-2.6.4-r4 b/sys-kernel/mips-sources/files/digest-mips-sources-2.6.4-r5 index 1a5fc819e2ad..1a5fc819e2ad 100644 --- a/sys-kernel/mips-sources/files/digest-mips-sources-2.6.4-r4 +++ b/sys-kernel/mips-sources/files/digest-mips-sources-2.6.4-r5 diff --git a/sys-kernel/mips-sources/files/digest-mips-sources-2.6.5-r3 b/sys-kernel/mips-sources/files/digest-mips-sources-2.6.5-r4 index c1a0ce95b671..c1a0ce95b671 100644 --- a/sys-kernel/mips-sources/files/digest-mips-sources-2.6.5-r3 +++ b/sys-kernel/mips-sources/files/digest-mips-sources-2.6.5-r4 diff --git a/sys-kernel/mips-sources/files/digest-mips-sources-2.6.6-r2 b/sys-kernel/mips-sources/files/digest-mips-sources-2.6.6-r3 index bc73ffb0e7fa..bc73ffb0e7fa 100644 --- a/sys-kernel/mips-sources/files/digest-mips-sources-2.6.6-r2 +++ b/sys-kernel/mips-sources/files/digest-mips-sources-2.6.6-r3 diff --git a/sys-kernel/mips-sources/files/digest-mips-sources-2.6.7-r1 b/sys-kernel/mips-sources/files/digest-mips-sources-2.6.7-r2 index 0b0e6e5494a9..0b0e6e5494a9 100644 --- a/sys-kernel/mips-sources/files/digest-mips-sources-2.6.7-r1 +++ b/sys-kernel/mips-sources/files/digest-mips-sources-2.6.7-r2 diff --git a/sys-kernel/mips-sources/mips-sources-2.6.4-r4.ebuild b/sys-kernel/mips-sources/mips-sources-2.6.4-r5.ebuild index 351bee5b3167..f2e7ded37be0 100644 --- a/sys-kernel/mips-sources/mips-sources-2.6.4-r4.ebuild +++ b/sys-kernel/mips-sources/mips-sources-2.6.4-r5.ebuild @@ -1,6 +1,6 @@ # Copyright 1999-2004 Gentoo Foundation # Distributed under the terms of the GNU General Public License v2 -# $Header: /var/cvsroot/gentoo-x86/sys-kernel/mips-sources/mips-sources-2.6.4-r4.ebuild,v 1.2 2004/07/15 03:53:30 agriffis Exp $ +# $Header: /var/cvsroot/gentoo-x86/sys-kernel/mips-sources/mips-sources-2.6.4-r5.ebuild,v 1.1 2004/07/23 01:54:38 kumba Exp $ # Version Data @@ -82,6 +82,9 @@ src_unpack() { epatch ${FILESDIR}/CAN-2004-0228-cpufreq.patch epatch ${FILESDIR}/CAN-2004-0229-fb_copy_cmap.patch epatch ${FILESDIR}/CAN-2004-0427-2.6-do_fork.patch + epatch ${FILESDIR}/CAN-2004-0495_0496-2.6-sparse.patch + epatch ${FILESDIR}/CAN-2004-0497-2.6-attr_gid.patch + epatch ${FILESDIR}/CAN-2004-0596-2.6-eql.patch epatch ${FILESDIR}/CAN-2004-0626-death_packet.patch eend diff --git a/sys-kernel/mips-sources/mips-sources-2.6.5-r3.ebuild b/sys-kernel/mips-sources/mips-sources-2.6.5-r4.ebuild index 4b7e94eb4be4..45f3b695cfba 100644 --- a/sys-kernel/mips-sources/mips-sources-2.6.5-r3.ebuild +++ b/sys-kernel/mips-sources/mips-sources-2.6.5-r4.ebuild @@ -1,6 +1,6 @@ # Copyright 1999-2004 Gentoo Foundation # Distributed under the terms of the GNU General Public License v2 -# $Header: /var/cvsroot/gentoo-x86/sys-kernel/mips-sources/mips-sources-2.6.5-r3.ebuild,v 1.2 2004/07/15 03:53:30 agriffis Exp $ +# $Header: /var/cvsroot/gentoo-x86/sys-kernel/mips-sources/mips-sources-2.6.5-r4.ebuild,v 1.1 2004/07/23 01:54:38 kumba Exp $ # Version Data @@ -84,11 +84,12 @@ src_unpack() { epatch ${FILESDIR}/CAN-2004-0228-cpufreq.patch epatch ${FILESDIR}/CAN-2004-0229-fb_copy_cmap.patch epatch ${FILESDIR}/CAN-2004-0427-2.6-do_fork.patch + epatch ${FILESDIR}/CAN-2004-0495_0496-2.6-sparse.patch + epatch ${FILESDIR}/CAN-2004-0497-2.6-attr_gid.patch + epatch ${FILESDIR}/CAN-2004-0596-2.6-eql.patch epatch ${FILESDIR}/CAN-2004-0626-death_packet.patch eend -# # Misc Fixes -# epatch ${FILESDIR}/misc-2.6-iptables_headers.patch # Cobalt Patches if [ "${PROFILE_ARCH}" = "cobalt" ]; then diff --git a/sys-kernel/mips-sources/mips-sources-2.6.6-r2.ebuild b/sys-kernel/mips-sources/mips-sources-2.6.6-r3.ebuild index 0f0e10c2f723..b499cb204c18 100644 --- a/sys-kernel/mips-sources/mips-sources-2.6.6-r2.ebuild +++ b/sys-kernel/mips-sources/mips-sources-2.6.6-r3.ebuild @@ -1,6 +1,6 @@ # Copyright 1999-2004 Gentoo Foundation # Distributed under the terms of the GNU General Public License v2 -# $Header: /var/cvsroot/gentoo-x86/sys-kernel/mips-sources/mips-sources-2.6.6-r2.ebuild,v 1.2 2004/07/15 03:53:30 agriffis Exp $ +# $Header: /var/cvsroot/gentoo-x86/sys-kernel/mips-sources/mips-sources-2.6.6-r3.ebuild,v 1.1 2004/07/23 01:54:38 kumba Exp $ # Version Data @@ -75,6 +75,9 @@ src_unpack() { # Security Fixes echo -e "" ebegin "Applying Security Fixes" + epatch ${FILESDIR}/CAN-2004-0495_0496-2.6-sparse.patch + epatch ${FILESDIR}/CAN-2004-0497-2.6-attr_gid.patch + epatch ${FILESDIR}/CAN-2004-0596-2.6-eql.patch epatch ${FILESDIR}/CAN-2004-0626-death_packet.patch eend diff --git a/sys-kernel/mips-sources/mips-sources-2.6.7-r1.ebuild b/sys-kernel/mips-sources/mips-sources-2.6.7-r2.ebuild index c0df4caad5e5..830598846e59 100644 --- a/sys-kernel/mips-sources/mips-sources-2.6.7-r1.ebuild +++ b/sys-kernel/mips-sources/mips-sources-2.6.7-r2.ebuild @@ -1,6 +1,6 @@ # Copyright 1999-2004 Gentoo Foundation # Distributed under the terms of the GNU General Public License v2 -# $Header: /var/cvsroot/gentoo-x86/sys-kernel/mips-sources/mips-sources-2.6.7-r1.ebuild,v 1.2 2004/07/15 03:53:30 agriffis Exp $ +# $Header: /var/cvsroot/gentoo-x86/sys-kernel/mips-sources/mips-sources-2.6.7-r2.ebuild,v 1.1 2004/07/23 01:54:38 kumba Exp $ # Version Data @@ -76,6 +76,8 @@ src_unpack() { # Security Fixes echo -e "" ebegin "Applying Security Fixes" + epatch ${FILESDIR}/CAN-2004-0497-2.6-attr_gid.patch + epatch ${FILESDIR}/CAN-2004-0596-2.6-eql.patch epatch ${FILESDIR}/CAN-2004-0626-death_packet.patch eend |