diff options
author | Christian Zoffoli <xmerlin@gentoo.org> | 2007-05-08 10:53:48 +0000 |
---|---|---|
committer | Christian Zoffoli <xmerlin@gentoo.org> | 2007-05-08 10:53:48 +0000 |
commit | ff2357f366c6c83d143588f2b81d5cad89b9c843 (patch) | |
tree | a8c03522f4b11753f303f1000d10fbbb21638082 /sys-cluster | |
parent | Push out a patch to work with different style of kernel version names, (diff) | |
download | gentoo-2-ff2357f366c6c83d143588f2b81d5cad89b9c843.tar.gz gentoo-2-ff2357f366c6c83d143588f2b81d5cad89b9c843.tar.bz2 gentoo-2-ff2357f366c6c83d143588f2b81d5cad89b9c843.zip |
Ebuild cleanup, add some new ebuild that compiles with newer kernels.
(Portage version: 2.1.2.2)
Diffstat (limited to 'sys-cluster')
-rw-r--r-- | sys-cluster/gfs-kernel/ChangeLog | 13 | ||||
-rw-r--r-- | sys-cluster/gfs-kernel/files/digest-gfs-kernel-1.02.00-r2 | 9 | ||||
-rw-r--r-- | sys-cluster/gfs-kernel/files/digest-gfs-kernel-1.03.00-r1 (renamed from sys-cluster/gfs-kernel/files/digest-gfs-kernel-1.03.00) | 0 | ||||
-rw-r--r-- | sys-cluster/gfs-kernel/files/digest-gfs-kernel-1.04.00 | 3 | ||||
-rw-r--r-- | sys-cluster/gfs-kernel/files/gfs-kernel-1.03.00-post-2.6.18.patch | 197 | ||||
-rw-r--r-- | sys-cluster/gfs-kernel/files/gfs-kernel-1.04.00-pre2.6.17-compilefix.patch | 643 | ||||
-rw-r--r-- | sys-cluster/gfs-kernel/gfs-kernel-1.02.00-r2.ebuild | 82 | ||||
-rw-r--r-- | sys-cluster/gfs-kernel/gfs-kernel-1.03.00-r1.ebuild (renamed from sys-cluster/gfs-kernel/gfs-kernel-1.03.00.ebuild) | 18 | ||||
-rw-r--r-- | sys-cluster/gfs-kernel/gfs-kernel-1.04.00.ebuild | 75 |
9 files changed, 1035 insertions, 5 deletions
diff --git a/sys-cluster/gfs-kernel/ChangeLog b/sys-cluster/gfs-kernel/ChangeLog index fc91c9f17a4c..0192f5291d80 100644 --- a/sys-cluster/gfs-kernel/ChangeLog +++ b/sys-cluster/gfs-kernel/ChangeLog @@ -1,6 +1,17 @@ # ChangeLog for sys-cluster/gfs-kernel # Copyright 1999-2007 Gentoo Foundation; Distributed under the GPL v2 -# $Header: /var/cvsroot/gentoo-x86/sys-cluster/gfs-kernel/ChangeLog,v 1.23 2007/04/26 06:35:54 dberkholz Exp $ +# $Header: /var/cvsroot/gentoo-x86/sys-cluster/gfs-kernel/ChangeLog,v 1.24 2007/05/08 10:53:48 xmerlin Exp $ + +*gfs-kernel-1.04.00 (08 May 2007) +*gfs-kernel-1.03.00-r1 (08 May 2007) +*gfs-kernel-1.02.00-r2 (08 May 2007) + + 08 May 2007; Christian Zoffoli <xmerlin@gentoo.org> + +files/gfs-kernel-1.03.00-post-2.6.18.patch, + +files/gfs-kernel-1.04.00-pre2.6.17-compilefix.patch, + +gfs-kernel-1.02.00-r2.ebuild, -gfs-kernel-1.03.00.ebuild, + +gfs-kernel-1.03.00-r1.ebuild, +gfs-kernel-1.04.00.ebuild: + Ebuild cleanup, add some new ebuild that compiles with newer kernels. 26 Apr 2007; Donnie Berkholz <dberkholz@gentoo.org>; metadata.xml: Update for cluster herd split to hp-cluster and ha-cluster. diff --git a/sys-cluster/gfs-kernel/files/digest-gfs-kernel-1.02.00-r2 b/sys-cluster/gfs-kernel/files/digest-gfs-kernel-1.02.00-r2 new file mode 100644 index 000000000000..7b137a3e5d96 --- /dev/null +++ b/sys-cluster/gfs-kernel/files/digest-gfs-kernel-1.02.00-r2 @@ -0,0 +1,9 @@ +MD5 131c34c8b66d8d7d74384839ed4091d0 cluster-1.02.00.tar.gz 1356451 +RMD160 e9c0cdd1f5a7542c8a4ea38ccf6d057767269dc5 cluster-1.02.00.tar.gz 1356451 +SHA256 de45885146f1481808f7a34af5e6b7e2042895a4e3844eaa6161f942345c7849 cluster-1.02.00.tar.gz 1356451 +MD5 67c38ef215cfccbafbfcd7d8e40867b4 gfs-kernel-1.02.00-20060714-cvs-part1.patch.gz 4919 +RMD160 9cd7c3df465a1c85fc59a57ee601f4b6b589284f gfs-kernel-1.02.00-20060714-cvs-part1.patch.gz 4919 +SHA256 39fb40d83cd4547a45ef00c11714392a7cc15b968b5c7aa05fd96eb63d9c7196 gfs-kernel-1.02.00-20060714-cvs-part1.patch.gz 4919 +MD5 916c21631d512bda65fcbdc43bcba1b5 gfs-kernel-1.02.00-20060714-cvs-part2.patch.gz 1086 +RMD160 bc10691dbdd4afb6d8fa8618f3b42d54792fb3bf gfs-kernel-1.02.00-20060714-cvs-part2.patch.gz 1086 +SHA256 7a6a7b531f9cd73a3b2ab46849372862d1903a9a0d879544ef60599762ad9ff6 gfs-kernel-1.02.00-20060714-cvs-part2.patch.gz 1086 diff --git a/sys-cluster/gfs-kernel/files/digest-gfs-kernel-1.03.00 b/sys-cluster/gfs-kernel/files/digest-gfs-kernel-1.03.00-r1 index 09fda78c7e81..09fda78c7e81 100644 --- a/sys-cluster/gfs-kernel/files/digest-gfs-kernel-1.03.00 +++ b/sys-cluster/gfs-kernel/files/digest-gfs-kernel-1.03.00-r1 diff --git a/sys-cluster/gfs-kernel/files/digest-gfs-kernel-1.04.00 b/sys-cluster/gfs-kernel/files/digest-gfs-kernel-1.04.00 new file mode 100644 index 000000000000..2f86eed7f8e5 --- /dev/null +++ b/sys-cluster/gfs-kernel/files/digest-gfs-kernel-1.04.00 @@ -0,0 +1,3 @@ +MD5 d1a0363109d0188959ec35b7d6ebfb67 cluster-1.04.00.tar.gz 1663798 +RMD160 5b241f38123c9ad65faf2a9eda7aa3e2dabee839 cluster-1.04.00.tar.gz 1663798 +SHA256 6f4b48e67383681ea6ad6e2907b56e755049816186375c4f2bcb9482da31c2c2 cluster-1.04.00.tar.gz 1663798 diff --git a/sys-cluster/gfs-kernel/files/gfs-kernel-1.03.00-post-2.6.18.patch b/sys-cluster/gfs-kernel/files/gfs-kernel-1.03.00-post-2.6.18.patch new file mode 100644 index 000000000000..8fbb53effe00 --- /dev/null +++ b/sys-cluster/gfs-kernel/files/gfs-kernel-1.03.00-post-2.6.18.patch @@ -0,0 +1,197 @@ +diff -uNr cluster-1.03.00.orig/gfs-kernel/src/dlm/lock_dlm.h cluster-1.03.00/gfs-kernel/src/dlm/lock_dlm.h +--- cluster-1.03.00.orig/gfs-kernel/src/dlm/lock_dlm.h 2006-07-12 23:58:29.000000000 +0200 ++++ cluster-1.03.00/gfs-kernel/src/dlm/lock_dlm.h 2007-03-09 21:00:27.000000000 +0100 +@@ -24,7 +24,7 @@ + #include <linux/socket.h> + #include <linux/kthread.h> + #include <net/sock.h> +-#include <linux/lm_interface.h> ++#include "lm_interface.h" + #include <cluster/cnxman.h> + #include <cluster/service.h> + #include <cluster/dlm.h> +diff -uNr cluster-1.03.00.orig/gfs-kernel/src/gfs/gfs.h cluster-1.03.00/gfs-kernel/src/gfs/gfs.h +--- cluster-1.03.00.orig/gfs-kernel/src/gfs/gfs.h 2006-08-16 23:52:45.000000000 +0200 ++++ cluster-1.03.00/gfs-kernel/src/gfs/gfs.h 2007-03-09 21:46:50.000000000 +0100 +@@ -16,7 +16,7 @@ + + #define GFS_RELEASE_NAME "1.03.00" + +-#include <linux/lm_interface.h> ++#include "lm_interface.h" + #include <linux/gfs_ondisk.h> + + #include "fixed_div64.h" +@@ -67,8 +67,8 @@ + + #define get_v2sdp(sb) ((struct gfs_sbd *)(sb)->s_fs_info) + #define set_v2sdp(sb, sdp) (sb)->s_fs_info = (sdp) +-#define get_v2ip(inode) ((struct gfs_inode *)(inode)->u.generic_ip) +-#define set_v2ip(inode, ip) (inode)->u.generic_ip = (ip) ++#define get_v2ip(inode) ((struct gfs_inode *)(inode)->i_private) ++#define set_v2ip(inode, ip) (inode)->i_private = (ip) + #define get_v2fp(file) ((struct gfs_file *)(file)->private_data) + #define set_v2fp(file, fp) (file)->private_data = (fp) + #define get_v2bd(bh) ((struct gfs_bufdata *)(bh)->b_private) +diff -uNr cluster-1.03.00.orig/gfs-kernel/src/gfs/inode.c cluster-1.03.00/gfs-kernel/src/gfs/inode.c +--- cluster-1.03.00.orig/gfs-kernel/src/gfs/inode.c 2005-09-18 05:01:24.000000000 +0200 ++++ cluster-1.03.00/gfs-kernel/src/gfs/inode.c 2007-03-09 21:48:37.000000000 +0100 +@@ -97,7 +97,6 @@ + inode->i_mtime.tv_sec = ip->i_di.di_mtime; + inode->i_ctime.tv_sec = ip->i_di.di_ctime; + inode->i_atime.tv_nsec = inode->i_mtime.tv_nsec = inode->i_ctime.tv_nsec = 0; +- inode->i_blksize = PAGE_SIZE; + inode->i_blocks = ip->i_di.di_blocks << + (ip->i_sbd->sd_sb.sb_bsize_shift - GFS_BASIC_BLOCK_SHIFT); + inode->i_generation = ip->i_di.di_header.mh_incarn; +diff -uNr cluster-1.03.00.orig/gfs-kernel/src/gfs/ops_inode.c cluster-1.03.00/gfs-kernel/src/gfs/ops_inode.c +--- cluster-1.03.00.orig/gfs-kernel/src/gfs/ops_inode.c 2006-08-16 16:40:54.000000000 +0200 ++++ cluster-1.03.00/gfs-kernel/src/gfs/ops_inode.c 2007-03-09 21:50:15.000000000 +0100 +@@ -171,22 +171,22 @@ + parent = dget_parent(dentry); + + if (gfs_filecmp(&dentry->d_name, "@hostname", 9)) +- new = lookup_one_len(system_utsname.nodename, ++ new = lookup_one_len(init_utsname()->nodename, + parent, +- strlen(system_utsname.nodename)); ++ strlen(init_utsname()->nodename)); + else if (gfs_filecmp(&dentry->d_name, "@nodeid", 7)) + new = lookup_one_len(buf, + parent, + sprintf(buf, "%s%i", "node", + get_my_nodeid())); + else if (gfs_filecmp(&dentry->d_name, "@mach", 5)) +- new = lookup_one_len(system_utsname.machine, ++ new = lookup_one_len(init_utsname()->machine, + parent, +- strlen(system_utsname.machine)); ++ strlen(init_utsname()->machine)); + else if (gfs_filecmp(&dentry->d_name, "@os", 3)) +- new = lookup_one_len(system_utsname.sysname, ++ new = lookup_one_len(init_utsname()->sysname, + parent, +- strlen(system_utsname.sysname)); ++ strlen(init_utsname()->sysname)); + else if (gfs_filecmp(&dentry->d_name, "@uid", 4)) + new = lookup_one_len(buf, + parent, +@@ -199,8 +199,8 @@ + new = lookup_one_len(buf, + parent, + sprintf(buf, "%s_%s", +- system_utsname.machine, +- system_utsname.sysname)); ++ init_utsname()->machine, ++ init_utsname()->sysname)); + else if (gfs_filecmp(&dentry->d_name, "@jid", 4)) + new = lookup_one_len(buf, + parent, +@@ -235,22 +235,22 @@ + parent = dget_parent(dentry); + + if (gfs_filecmp(&dentry->d_name, "{hostname}", 10)) +- new = lookup_one_len(system_utsname.nodename, ++ new = lookup_one_len(init_utsname()->nodename, + parent, +- strlen(system_utsname.nodename)); ++ strlen(init_utsname()->nodename)); + else if (gfs_filecmp(&dentry->d_name, "{nodeid}", 8)) + new = lookup_one_len(buf, + parent, + sprintf(buf, "%s%i", "node", + get_my_nodeid())); + else if (gfs_filecmp(&dentry->d_name, "{mach}", 6)) +- new = lookup_one_len(system_utsname.machine, ++ new = lookup_one_len(init_utsname()->machine, + parent, +- strlen(system_utsname.machine)); ++ strlen(init_utsname()->machine)); + else if (gfs_filecmp(&dentry->d_name, "{os}", 4)) +- new = lookup_one_len(system_utsname.sysname, ++ new = lookup_one_len(init_utsname()->sysname, + parent, +- strlen(system_utsname.sysname)); ++ strlen(init_utsname()->sysname)); + else if (gfs_filecmp(&dentry->d_name, "{uid}", 5)) + new = lookup_one_len(buf, + parent, +@@ -263,8 +263,8 @@ + new = lookup_one_len(buf, + parent, + sprintf(buf, "%s_%s", +- system_utsname.machine, +- system_utsname.sysname)); ++ init_utsname()->machine, ++ init_utsname()->sysname)); + else if (gfs_filecmp(&dentry->d_name, "{jid}", 5)) + new = lookup_one_len(buf, + parent, +diff -uNr cluster-1.03.00.orig/gfs-kernel/src/gulm/gulm.h cluster-1.03.00/gfs-kernel/src/gulm/gulm.h +--- cluster-1.03.00.orig/gfs-kernel/src/gulm/gulm.h 2006-08-16 23:53:36.000000000 +0200 ++++ cluster-1.03.00/gfs-kernel/src/gulm/gulm.h 2007-03-09 21:03:23.000000000 +0100 +@@ -24,7 +24,6 @@ + #include <linux/slab.h> + #include <linux/spinlock.h> + #include <asm/atomic.h> +-#include <linux/config.h> + #include <linux/version.h> + #include <linux/smp_lock.h> + #include <linux/list.h> +@@ -73,7 +72,7 @@ + /* Divide x by y. Round up if there is a remainder. */ + #define DIV_RU(x, y) (((x) + (y) - 1) / (y)) + +-#include <linux/lm_interface.h> ++#include "lm_interface.h" + + #include "gulm_prints.h" + +diff -uNr cluster-1.03.00.orig/gfs-kernel/src/gulm/gulm_fs.c cluster-1.03.00/gfs-kernel/src/gulm/gulm_fs.c +--- cluster-1.03.00.orig/gfs-kernel/src/gulm/gulm_fs.c 2005-03-04 21:08:00.000000000 +0100 ++++ cluster-1.03.00/gfs-kernel/src/gulm/gulm_fs.c 2007-03-09 21:06:14.000000000 +0100 +@@ -258,7 +258,7 @@ + if (hostdata != NULL && strlen (hostdata) > 0) { + strncpy (gulm_cm.myName, hostdata, 64); + } else { +- strncpy (gulm_cm.myName, system_utsname.nodename, 64); ++ strncpy (gulm_cm.myName, init_utsname()->nodename, 64); + } + gulm_cm.myName[63] = '\0'; + +diff -uNr cluster-1.03.00.orig/gfs-kernel/src/gulm/handler.h cluster-1.03.00/gfs-kernel/src/gulm/handler.h +--- cluster-1.03.00.orig/gfs-kernel/src/gulm/handler.h 2004-06-24 10:53:28.000000000 +0200 ++++ cluster-1.03.00/gfs-kernel/src/gulm/handler.h 2007-03-09 21:00:13.000000000 +0100 +@@ -13,7 +13,7 @@ + + #ifndef __handler_c__ + #define __handler_c__ +-#include <linux/lm_interface.h> ++#include "lm_interface.h" + + struct callback_qu_s { + struct completion startup; +diff -uNr cluster-1.03.00.orig/gfs-kernel/src/harness/main.c cluster-1.03.00/gfs-kernel/src/harness/main.c +--- cluster-1.03.00.orig/gfs-kernel/src/harness/main.c 2006-08-16 23:53:01.000000000 +0200 ++++ cluster-1.03.00/gfs-kernel/src/harness/main.c 2007-03-09 20:58:29.000000000 +0100 +@@ -19,7 +19,7 @@ + #include <linux/sched.h> + #include <linux/kmod.h> + #include <linux/fs.h> +-#include <linux/lm_interface.h> ++#include "lm_interface.h" + + #define RELEASE_NAME "1.03.00" + +diff -uNr cluster-1.03.00.orig/gfs-kernel/src/nolock/main.c cluster-1.03.00/gfs-kernel/src/nolock/main.c +--- cluster-1.03.00.orig/gfs-kernel/src/nolock/main.c 2006-08-16 23:53:20.000000000 +0200 ++++ cluster-1.03.00/gfs-kernel/src/nolock/main.c 2007-03-09 20:59:52.000000000 +0100 +@@ -18,7 +18,7 @@ + #include <linux/types.h> + #include <linux/fs.h> + #include <linux/smp_lock.h> +-#include <linux/lm_interface.h> ++#include "lm_interface.h" + + #define RELEASE_NAME "1.03.00" + diff --git a/sys-cluster/gfs-kernel/files/gfs-kernel-1.04.00-pre2.6.17-compilefix.patch b/sys-cluster/gfs-kernel/files/gfs-kernel-1.04.00-pre2.6.17-compilefix.patch new file mode 100644 index 000000000000..db0c13287cf9 --- /dev/null +++ b/sys-cluster/gfs-kernel/files/gfs-kernel-1.04.00-pre2.6.17-compilefix.patch @@ -0,0 +1,643 @@ +diff -uNr cluster-1.04.00.orig/gfs-kernel/src/gfs/diaper.c cluster-1.04.00/gfs-kernel/src/gfs/diaper.c +--- cluster-1.04.00.orig/gfs-kernel/src/gfs/diaper.c 2007-02-23 21:57:29.000000000 +0100 ++++ cluster-1.04.00/gfs-kernel/src/gfs/diaper.c 2007-03-09 18:50:02.000000000 +0100 +@@ -363,7 +363,7 @@ + if (!diaper) + goto fail_remove; + +- mutex_lock(&diaper->bd_mutex); ++ down(&diaper->bd_sem); + if (!diaper->bd_openers) { + diaper->bd_disk = gd; + diaper->bd_contains = diaper; +@@ -372,7 +372,7 @@ + } else + printk("GFS: diaper: reopening\n"); + diaper->bd_openers++; +- mutex_unlock(&diaper->bd_mutex); ++ up(&diaper->bd_sem); + + dh->dh_mempool = mempool_create(512, + mempool_alloc_slab, mempool_free_slab, +@@ -395,14 +395,14 @@ + mempool_destroy(dh->dh_mempool); + + fail_bdput: +- mutex_lock(&diaper->bd_mutex); ++ down(&diaper->bd_sem); + if (!--diaper->bd_openers) { + invalidate_bdev(diaper, 1); + diaper->bd_contains = NULL; + diaper->bd_disk = NULL; + } else + printk("GFS: diaper: not closed\n"); +- mutex_unlock(&diaper->bd_mutex); ++ up(&diaper->bd_sem); + bdput(diaper); + + fail_remove: +@@ -438,14 +438,14 @@ + + mempool_destroy(dh->dh_mempool); + +- mutex_lock(&diaper->bd_mutex); ++ down(&diaper->bd_sem); + if (!--diaper->bd_openers) { + invalidate_bdev(diaper, 1); + diaper->bd_contains = NULL; + diaper->bd_disk = NULL; + } else + printk("GFS: diaper: not closed\n"); +- mutex_unlock(&diaper->bd_mutex); ++ up(&diaper->bd_sem); + + bdput(diaper); + del_gendisk(gd); +diff -uNr cluster-1.04.00.orig/gfs-kernel/src/gfs/gfs.h cluster-1.04.00/gfs-kernel/src/gfs/gfs.h +--- cluster-1.04.00.orig/gfs-kernel/src/gfs/gfs.h 2007-02-27 20:53:00.000000000 +0100 ++++ cluster-1.04.00/gfs-kernel/src/gfs/gfs.h 2007-03-09 18:50:02.000000000 +0100 +@@ -67,8 +67,8 @@ + + #define get_v2sdp(sb) ((struct gfs_sbd *)(sb)->s_fs_info) + #define set_v2sdp(sb, sdp) (sb)->s_fs_info = (sdp) +-#define get_v2ip(inode) ((struct gfs_inode *)(inode)->i_private) +-#define set_v2ip(inode, ip) (inode)->i_private = (ip) ++#define get_v2ip(inode) ((struct gfs_inode *)(inode)->u.generic_ip) ++#define set_v2ip(inode, ip) (inode)->u.generic_ip = (ip) + #define get_v2fp(file) ((struct gfs_file *)(file)->private_data) + #define set_v2fp(file, fp) (file)->private_data = (fp) + #define get_v2bd(bh) ((struct gfs_bufdata *)(bh)->b_private) +diff -uNr cluster-1.04.00.orig/gfs-kernel/src/gfs/glock.c cluster-1.04.00/gfs-kernel/src/gfs/glock.c +--- cluster-1.04.00.orig/gfs-kernel/src/gfs/glock.c 2007-02-07 16:25:05.000000000 +0100 ++++ cluster-1.04.00/gfs-kernel/src/gfs/glock.c 2007-03-09 18:50:02.000000000 +0100 +@@ -38,7 +38,7 @@ + + struct greedy { + struct gfs_holder gr_gh; +- struct delayed_work gr_work; ++ struct work_struct gr_work; + }; + + typedef void (*glock_examiner) (struct gfs_glock * gl); +@@ -1747,9 +1747,9 @@ + */ + + static void +-greedy_work(struct work_struct *work) ++greedy_work(void *data) + { +- struct greedy *gr = container_of(work, struct greedy, gr_work.work); ++ struct greedy *gr = (struct greedy *)data; + struct gfs_holder *gh = &gr->gr_gh; + struct gfs_glock *gl = gh->gh_gl; + struct gfs_glock_operations *glops = gl->gl_ops; +@@ -1804,7 +1804,7 @@ + gfs_holder_init(gl, 0, 0, gh); + set_bit(HIF_GREEDY, &gh->gh_iflags); + gh->gh_owner = NULL; +- INIT_DELAYED_WORK(&gr->gr_work, greedy_work); ++ INIT_WORK(&gr->gr_work, greedy_work, gr); + + set_bit(GLF_SKIP_WAITERS2, &gl->gl_flags); + schedule_delayed_work(&gr->gr_work, time); +diff -uNr cluster-1.04.00.orig/gfs-kernel/src/gfs/inode.c cluster-1.04.00/gfs-kernel/src/gfs/inode.c +--- cluster-1.04.00.orig/gfs-kernel/src/gfs/inode.c 2007-02-07 16:25:05.000000000 +0100 ++++ cluster-1.04.00/gfs-kernel/src/gfs/inode.c 2007-03-09 18:50:02.000000000 +0100 +@@ -97,6 +97,7 @@ + inode->i_mtime.tv_sec = ip->i_di.di_mtime; + inode->i_ctime.tv_sec = ip->i_di.di_ctime; + inode->i_atime.tv_nsec = inode->i_mtime.tv_nsec = inode->i_ctime.tv_nsec = 0; ++ inode->i_blksize = PAGE_SIZE; + inode->i_blocks = ip->i_di.di_blocks << + (ip->i_sbd->sd_sb.sb_bsize_shift - GFS_BASIC_BLOCK_SHIFT); + inode->i_generation = ip->i_di.di_header.mh_incarn; +diff -uNr cluster-1.04.00.orig/gfs-kernel/src/gfs/ops_file.c cluster-1.04.00/gfs-kernel/src/gfs/ops_file.c +--- cluster-1.04.00.orig/gfs-kernel/src/gfs/ops_file.c 2007-02-07 16:25:05.000000000 +0100 ++++ cluster-1.04.00/gfs-kernel/src/gfs/ops_file.c 2007-03-09 18:50:02.000000000 +0100 +@@ -74,10 +74,9 @@ + }; + + typedef ssize_t(*do_rw_t) (struct file * file, +- char *buf, +- size_t size, loff_t * offset, +- struct kiocb *iocb, +- unsigned int num_gh, struct gfs_holder * ghs); ++ char *buf, ++ size_t size, loff_t * offset, ++ unsigned int num_gh, struct gfs_holder * ghs); + + /** + * gfs_llseek - seek to a location in a file +@@ -130,7 +129,7 @@ + + static ssize_t + walk_vm_hard(struct file *file, char *buf, size_t size, loff_t *offset, +- struct kiocb *iocb, do_rw_t operation) ++ do_rw_t operation) + { + struct gfs_holder *ghs; + unsigned int num_gh = 0; +@@ -179,7 +178,7 @@ + gfs_assert(get_v2sdp(sb), x == num_gh,); + } + +- count = operation(file, buf, size, offset, iocb, num_gh, ghs); ++ count = operation(file, buf, size, offset, num_gh, ghs); + + while (num_gh--) + gfs_holder_uninit(&ghs[num_gh]); +@@ -205,7 +204,7 @@ + + static ssize_t + walk_vm(struct file *file, char *buf, size_t size, loff_t *offset, +- struct kiocb *iocb, do_rw_t operation) ++ do_rw_t operation) + { + if (current->mm) { + struct super_block *sb = file->f_dentry->d_inode->i_sb; +@@ -232,11 +231,11 @@ + + { + struct gfs_holder gh; +- return operation(file, buf, size, offset, iocb, 0, &gh); ++ return operation(file, buf, size, offset, 0, &gh); + } + + do_locks: +- return walk_vm_hard(file, buf, size, offset, iocb, operation); ++ return walk_vm_hard(file, buf, size, offset, operation); + } + + /** +@@ -251,8 +250,7 @@ + */ + + static ssize_t +-do_read_readi(struct file *file, char *buf, size_t size, loff_t *offset, +- struct kiocb *iocb) ++do_read_readi(struct file *file, char *buf, size_t size, loff_t *offset) + { + struct gfs_inode *ip = get_v2ip(file->f_mapping->host); + ssize_t count = 0; +@@ -293,8 +291,7 @@ + + static ssize_t + do_read_direct(struct file *file, char *buf, size_t size, loff_t *offset, +- struct kiocb *iocb, +- unsigned int num_gh, struct gfs_holder *ghs) ++ unsigned int num_gh, struct gfs_holder *ghs) + { + struct inode *inode = file->f_mapping->host; + struct gfs_inode *ip = get_v2ip(inode); +@@ -327,18 +324,10 @@ + if (((*offset) & mask) || (((unsigned long)buf) & mask)) + goto out_gunlock; + +- count = do_read_readi(file, buf, size & ~mask, offset, iocb); +- } +- else { +- if (!iocb) +- count = do_sync_read(file, buf, size, offset); +- else { +- struct iovec local_iov = { .iov_base = buf, .iov_len = size}; +- +- count = generic_file_aio_read(iocb, &local_iov, 1, *offset); +- iocb->ki_pos = *offset; +- } ++ count = do_read_readi(file, buf, size & ~mask, offset); + } ++ else ++ count = generic_file_read(file, buf, size, offset); + + error = 0; + +@@ -367,8 +356,7 @@ + + static ssize_t + do_read_buf(struct file *file, char *buf, size_t size, loff_t *offset, +- struct kiocb *iocb, +- unsigned int num_gh, struct gfs_holder *ghs) ++ unsigned int num_gh, struct gfs_holder *ghs) + { + struct gfs_inode *ip = get_v2ip(file->f_mapping->host); + ssize_t count = 0; +@@ -382,17 +370,9 @@ + + if (gfs_is_jdata(ip) || + (gfs_is_stuffed(ip) && !test_bit(GIF_PAGED, &ip->i_flags))) +- count = do_read_readi(file, buf, size, offset, iocb); +- else { +- if (!iocb) { +- count = do_sync_read(file, buf, size, offset); +- } else { +- struct iovec local_iov = { .iov_base = buf, .iov_len = size}; +- +- count = generic_file_aio_read(iocb, &local_iov, 1, *offset); +- iocb->ki_pos = *offset; +- } +- } ++ count = do_read_readi(file, buf, size, offset); ++ else ++ count = generic_file_read(file, buf, size, offset); + + gfs_glock_dq_m(num_gh + 1, ghs); + +@@ -402,18 +382,6 @@ + return (count) ? count : error; + } + +-static ssize_t +-__gfs_read(struct file *file, char *buf, size_t size, loff_t *offset, +- struct kiocb *iocb) +-{ +- atomic_inc(&get_v2sdp(file->f_mapping->host->i_sb)->sd_ops_file); +- +- if (file->f_flags & O_DIRECT) +- return walk_vm(file, buf, size, offset, iocb, do_read_direct); +- else +- return walk_vm(file, buf, size, offset, iocb, do_read_buf); +-} +- + /** + * gfs_read - Read bytes from a file + * @file: The file to read from +@@ -429,21 +397,12 @@ + static ssize_t + gfs_read(struct file *file, char *buf, size_t size, loff_t *offset) + { +- return(__gfs_read(file, buf, size, offset, NULL)); +-} +- +-/* +- * gfs_aio_read: match with vfs generic_file_aio_read as: +- * (struct kiocb *iocb, char __user *buf, size_t count, loff_t pos) +- */ +-static ssize_t +-gfs_aio_read(struct kiocb *iocb, const struct iovec *iov, unsigned long count, +- loff_t pos) +-{ +- struct file *filp = iocb->ki_filp; ++ atomic_inc(&get_v2sdp(file->f_mapping->host->i_sb)->sd_ops_file); + +- BUG_ON(iocb->ki_pos != pos); +- return(__gfs_read(filp, iov->iov_base, iov->iov_len, &iocb->ki_pos, iocb)); ++ if (file->f_flags & O_DIRECT) ++ return walk_vm(file, buf, size, offset, do_read_direct); ++ else ++ return walk_vm(file, buf, size, offset, do_read_buf); + } + + /** +@@ -478,41 +437,6 @@ + } + + /** +- * gfs_file_aio_write_nolock - Call vfs aio layer to write bytes to a file +- * @file: The file to write to +- * @buf: The buffer to copy from +- * @size: The amount of data requested +- * @offset: The offset in the file to write +- * @iocb: The io control block. If NULL, a temporary one will be used. +- * +- * Returns: The number of bytes written, errno on failure +- */ +-static ssize_t +-gfs_file_aio_write_nolock(struct file *file, char *buf, size_t size, +- loff_t *offset, struct kiocb *iocb) +-{ +- struct iovec local_iov = { .iov_base = buf, .iov_len = size }; +- struct kiocb local_iocb, *kiocb = NULL; +- ssize_t count; +- +- if (!iocb) { +- init_sync_kiocb(&local_iocb, file); +- local_iocb.ki_nr_segs = 1; +- kiocb = &local_iocb; +- } +- else +- kiocb = iocb; +- +- kiocb->ki_pos = *offset; +- count = generic_file_aio_write_nolock(kiocb, &local_iov, kiocb->ki_nr_segs, +- kiocb->ki_pos); +- *offset = kiocb->ki_pos; +- if (kiocb == &local_iocb && count == -EIOCBQUEUED) +- count = wait_on_sync_kiocb(kiocb); +- return count; +-} +- +-/** + * do_write_direct_alloc - Write bytes to a file + * @file: The file to write to + * @buf: The buffer to copy from +@@ -525,13 +449,13 @@ + */ + + static ssize_t +-do_write_direct_alloc(struct file *file, char *buf, size_t size, loff_t *offset, +- struct kiocb *iocb) ++do_write_direct_alloc(struct file *file, char *buf, size_t size, loff_t *offset) + { + struct inode *inode = file->f_mapping->host; + struct gfs_inode *ip = get_v2ip(inode); + struct gfs_sbd *sdp = ip->i_sbd; + struct gfs_alloc *al = NULL; ++ struct iovec local_iov = { .iov_base = buf, .iov_len = size }; + struct buffer_head *dibh; + unsigned int data_blocks, ind_blocks; + ssize_t count; +@@ -584,7 +508,7 @@ + goto fail_end_trans; + } + +- count = gfs_file_aio_write_nolock(file, buf, size, offset, iocb); ++ count = generic_file_write_nolock(file, &local_iov, 1, offset); + if (count < 0) { + error = count; + goto fail_end_trans; +@@ -652,7 +576,6 @@ + + static ssize_t + do_write_direct(struct file *file, char *buf, size_t size, loff_t *offset, +- struct kiocb *iocb, + unsigned int num_gh, struct gfs_holder *ghs) + { + struct gfs_inode *ip = get_v2ip(file->f_mapping->host); +@@ -723,19 +646,13 @@ + if (alloc_required) { + set_bit(GFF_DID_DIRECT_ALLOC, &fp->f_flags); + +- /* for asynchronous IO, the buffer can not be splitted */ +- if (iocb) { +- count = do_write_direct_alloc(file, buf, size, offset, iocb); +- goto out_iocb_write; +- } +- + /* split large writes into smaller atomic transactions */ + while (size) { + s = gfs_tune_get(sdp, gt_max_atomic_write); + if (s > size) + s = size; + +- error = do_write_direct_alloc(file, buf, s, offset, iocb); ++ error = do_write_direct_alloc(file, buf, s, offset); + if (error < 0) + goto out_gunlock; + +@@ -744,6 +661,7 @@ + count += error; + } + } else { ++ struct iovec local_iov = { .iov_base = buf, .iov_len = size }; + struct gfs_holder t_gh; + + clear_bit(GFF_DID_DIRECT_ALLOC, &fp->f_flags); +@@ -752,17 +670,17 @@ + if (error) + goto out_gunlock; + +- count = gfs_file_aio_write_nolock(file, buf, size, offset, iocb); ++ count = generic_file_write_nolock(file, &local_iov, 1, offset); ++ + gfs_glock_dq_uninit(&t_gh); + } + +-out_iocb_write: + error = 0; + +-out_gunlock: ++ out_gunlock: + gfs_glock_dq_m(num_gh + 1, ghs); + +-out: ++ out: + gfs_holder_uninit(&ghs[num_gh]); + + return (count) ? count : error; +@@ -781,8 +699,7 @@ + */ + + static ssize_t +-do_do_write_buf(struct file *file, char *buf, size_t size, loff_t *offset, +- struct kiocb *iocb) ++do_do_write_buf(struct file *file, char *buf, size_t size, loff_t *offset) + { + struct inode *inode = file->f_mapping->host; + struct gfs_inode *ip = get_v2ip(inode); +@@ -860,7 +777,7 @@ + (gfs_is_stuffed(ip) && !test_bit(GIF_PAGED, &ip->i_flags) && + *offset + size <= sdp->sd_sb.sb_bsize - sizeof(struct gfs_dinode))) { + +- count = gfs_writei(ip, buf, *offset, size, gfs_copy_from_user, iocb); ++ count = gfs_writei(ip, buf, *offset, size, gfs_copy_from_user,NULL); + if (count < 0) { + error = count; + goto fail_end_trans; +@@ -875,7 +792,9 @@ + } + *offset += count; + } else { +- count = gfs_file_aio_write_nolock(file, buf, size, offset, iocb); ++ struct iovec local_iov = { .iov_base = buf, .iov_len = size }; ++ ++ count = generic_file_write_nolock(file, &local_iov, 1, offset); + if (count < 0) { + error = count; + goto fail_end_trans; +@@ -950,9 +869,8 @@ + + static ssize_t + do_write_buf(struct file *file, +- char *buf, size_t size, loff_t *offset, +- struct kiocb *iocb, +- unsigned int num_gh, struct gfs_holder *ghs) ++ char *buf, size_t size, loff_t *offset, ++ unsigned int num_gh, struct gfs_holder *ghs) + { + struct gfs_inode *ip = get_v2ip(file->f_mapping->host); + struct gfs_sbd *sdp = ip->i_sbd; +@@ -989,7 +907,7 @@ + if (s > size) + s = size; + +- error = do_do_write_buf(file, buf, s, offset, iocb); ++ error = do_do_write_buf(file, buf, s, offset); + if (error < 0) + goto out_gunlock; + +@@ -1022,7 +940,7 @@ + */ + + static ssize_t +-__gfs_write(struct file *file, const char *buf, size_t size, loff_t *offset, struct kiocb *iocb) ++gfs_write(struct file *file, const char *buf, size_t size, loff_t *offset) + { + struct inode *inode = file->f_mapping->host; + ssize_t count; +@@ -1036,32 +954,14 @@ + + mutex_lock(&inode->i_mutex); + if (file->f_flags & O_DIRECT) +- count = walk_vm(file, (char *)buf, size, offset, iocb, do_write_direct); ++ count = walk_vm(file, (char *)buf, size, offset, do_write_direct); + else +- count = walk_vm(file, (char *)buf, size, offset, iocb, do_write_buf); ++ count = walk_vm(file, (char *)buf, size, offset, do_write_buf); + mutex_unlock(&inode->i_mutex); + + return count; + } + +-static ssize_t +-gfs_write(struct file *file, const char *buf, size_t size, loff_t *offset) +-{ +- return(__gfs_write(file, buf, size, offset, NULL)); +-} +- +-static ssize_t +-gfs_aio_write(struct kiocb *iocb, const struct iovec *iov, unsigned long segs, +- loff_t pos) +-{ +- struct file *file = iocb->ki_filp; +- +- BUG_ON(iocb->ki_pos != pos); +- +- return(__gfs_write(file, iov->iov_base, iov->iov_len, &iocb->ki_pos, +- iocb)); +-} +- + /** + * filldir_reg_func - Report a directory entry to the caller of gfs_dir_read() + * @opaque: opaque data used by the function +@@ -1565,13 +1465,12 @@ + + if (sdp->sd_args.ar_localflocks) { + if (IS_GETLK(cmd)) { +- struct file_lock tmp; +- int ret; ++ struct file_lock *tmp; + lock_kernel(); +- ret = posix_test_lock(file, fl, &tmp); ++ tmp = posix_test_lock(file, fl); + fl->fl_type = F_UNLCK; +- if (ret) +- memcpy(fl, &tmp, sizeof(struct file_lock)); ++ if (tmp) ++ memcpy(fl, tmp, sizeof(struct file_lock)); + unlock_kernel(); + return 0; + } else { +@@ -1747,8 +1646,6 @@ + .llseek = gfs_llseek, + .read = gfs_read, + .write = gfs_write, +- .aio_read = gfs_aio_read, +- .aio_write = gfs_aio_write, + .ioctl = gfs_ioctl, + .mmap = gfs_mmap, + .open = gfs_open, +diff -uNr cluster-1.04.00.orig/gfs-kernel/src/gfs/ops_inode.c cluster-1.04.00/gfs-kernel/src/gfs/ops_inode.c +--- cluster-1.04.00.orig/gfs-kernel/src/gfs/ops_inode.c 2007-02-07 16:25:05.000000000 +0100 ++++ cluster-1.04.00/gfs-kernel/src/gfs/ops_inode.c 2007-03-09 18:50:02.000000000 +0100 +@@ -171,22 +171,22 @@ + parent = dget_parent(dentry); + + if (gfs_filecmp(&dentry->d_name, "@hostname", 9)) +- new = lookup_one_len(init_utsname()->nodename, ++ new = lookup_one_len(system_utsname.nodename, + parent, +- strlen(init_utsname()->nodename)); ++ strlen(system_utsname.nodename)); + else if (gfs_filecmp(&dentry->d_name, "@nodeid", 7)) + new = lookup_one_len(buf, + parent, + sprintf(buf, "%s%i", "node", + get_my_nodeid())); + else if (gfs_filecmp(&dentry->d_name, "@mach", 5)) +- new = lookup_one_len(init_utsname()->machine, ++ new = lookup_one_len(system_utsname.machine, + parent, +- strlen(init_utsname()->machine)); ++ strlen(system_utsname.machine)); + else if (gfs_filecmp(&dentry->d_name, "@os", 3)) +- new = lookup_one_len(init_utsname()->sysname, ++ new = lookup_one_len(system_utsname.sysname, + parent, +- strlen(init_utsname()->sysname)); ++ strlen(system_utsname.sysname)); + else if (gfs_filecmp(&dentry->d_name, "@uid", 4)) + new = lookup_one_len(buf, + parent, +@@ -199,8 +199,8 @@ + new = lookup_one_len(buf, + parent, + sprintf(buf, "%s_%s", +- init_utsname()->machine, +- init_utsname()->sysname)); ++ system_utsname.machine, ++ system_utsname.sysname)); + else if (gfs_filecmp(&dentry->d_name, "@jid", 4)) + new = lookup_one_len(buf, + parent, +@@ -235,22 +235,22 @@ + parent = dget_parent(dentry); + + if (gfs_filecmp(&dentry->d_name, "{hostname}", 10)) +- new = lookup_one_len(init_utsname()->nodename, ++ new = lookup_one_len(system_utsname.nodename, + parent, +- strlen(init_utsname()->nodename)); ++ strlen(system_utsname.nodename)); + else if (gfs_filecmp(&dentry->d_name, "{nodeid}", 8)) + new = lookup_one_len(buf, + parent, + sprintf(buf, "%s%i", "node", + get_my_nodeid())); + else if (gfs_filecmp(&dentry->d_name, "{mach}", 6)) +- new = lookup_one_len(init_utsname()->machine, ++ new = lookup_one_len(system_utsname.machine, + parent, +- strlen(init_utsname()->machine)); ++ strlen(system_utsname.machine)); + else if (gfs_filecmp(&dentry->d_name, "{os}", 4)) +- new = lookup_one_len(init_utsname()->sysname, ++ new = lookup_one_len(system_utsname.sysname, + parent, +- strlen(init_utsname()->sysname)); ++ strlen(system_utsname.sysname)); + else if (gfs_filecmp(&dentry->d_name, "{uid}", 5)) + new = lookup_one_len(buf, + parent, +@@ -263,8 +263,8 @@ + new = lookup_one_len(buf, + parent, + sprintf(buf, "%s_%s", +- init_utsname()->machine, +- init_utsname()->sysname)); ++ system_utsname.machine, ++ system_utsname.sysname)); + else if (gfs_filecmp(&dentry->d_name, "{jid}", 5)) + new = lookup_one_len(buf, + parent, +diff -uNr cluster-1.04.00.orig/gfs-kernel/src/nolock/main.c cluster-1.04.00/gfs-kernel/src/nolock/main.c +--- cluster-1.04.00.orig/gfs-kernel/src/nolock/main.c 2007-02-27 20:53:41.000000000 +0100 ++++ cluster-1.04.00/gfs-kernel/src/nolock/main.c 2007-03-09 18:50:02.000000000 +0100 +@@ -244,14 +244,13 @@ + struct lm_lockname *name, + struct file *file, struct file_lock *fl) + { +- struct file_lock tmp; +- int ret; ++ struct file_lock *tmp; + + lock_kernel(); +- ret = posix_test_lock(file, fl, &tmp); ++ tmp = posix_test_lock(file, fl); + fl->fl_type = F_UNLCK; +- if (ret) +- memcpy(fl, &tmp, sizeof(struct file_lock)); ++ if (tmp) ++ memcpy(fl, tmp, sizeof(struct file_lock)); + unlock_kernel(); + + return 0; diff --git a/sys-cluster/gfs-kernel/gfs-kernel-1.02.00-r2.ebuild b/sys-cluster/gfs-kernel/gfs-kernel-1.02.00-r2.ebuild new file mode 100644 index 000000000000..6209a2fd552e --- /dev/null +++ b/sys-cluster/gfs-kernel/gfs-kernel-1.02.00-r2.ebuild @@ -0,0 +1,82 @@ +# Copyright 1999-2007 Gentoo Foundation +# Distributed under the terms of the GNU General Public License v2 +# $Header: /var/cvsroot/gentoo-x86/sys-cluster/gfs-kernel/gfs-kernel-1.02.00-r2.ebuild,v 1.1 2007/05/08 10:53:48 xmerlin Exp $ + +inherit eutils linux-mod linux-info + +CLUSTER_RELEASE="1.02.00" +MY_P="cluster-${CLUSTER_RELEASE}" +CVS_RELEASE="20060714" + +DESCRIPTION="GFS kernel module" +HOMEPAGE="http://sources.redhat.com/cluster/" +SRC_URI="ftp://sources.redhat.com/pub/cluster/releases/${MY_P}.tar.gz + mirror://gentoo/${PN/headers/kernel}-${PV}-${CVS_RELEASE}-cvs-part1.patch.gz + mirror://gentoo/${PN/headers/kernel}-${PV}-${CVS_RELEASE}-cvs-part2.patch.gz + http://dev.gentoo.org/~xmerlin/gfs/${PN/headers/kernel}-${PV}-${CVS_RELEASE}-cvs-part1.patch.gz + http://dev.gentoo.org/~xmerlin/gfs/${PN/headers/kernel}-${PV}-${CVS_RELEASE}-cvs-part2.patch.gz + " + +LICENSE="GPL-2" +SLOT="0" +KEYWORDS="~amd64 ~ppc ~x86" + +IUSE="" + +DEPEND=">=virtual/linux-sources-2.6.16 + =sys-cluster/dlm-headers-${CLUSTER_RELEASE}* + =sys-cluster/cman-headers-${CLUSTER_RELEASE}*" + +RDEPEND="" + +S="${WORKDIR}/${MY_P}/${PN}" + +pkg_setup() { + linux-mod_pkg_setup + case ${KV_FULL} in + 2.2.*|2.4.*) die "${P} supports only 2.6 kernels";; + esac +} + +src_unpack() { + unpack ${A} + cd ${S} + + epatch ${WORKDIR}/gfs-kernel-1.02.00-20060714-cvs-part1.patch || die + if kernel_is 2 6; then + if [ "$KV_PATCH" -gt "16" ] ; then + epatch ${WORKDIR}/gfs-kernel-1.02.00-20060714-cvs-part2.patch || die + fi + + if [ "$KV_PATCH" -ge "18" ] ; then + epatch ${FILESDIR}/${PN}-1.03.00-post-2.6.18.patch || die + + sed -i \ + -e 's|version.h|utsrelease.h|g' \ + configure \ + || die "sed failed" + fi + fi + + epatch ${FILESDIR}/${PN/headers/kernel}-${PV}-${CVS_RELEASE}-cvs-compile.patch || die +} + +src_compile() { + set_arch_to_kernel + + ./configure --kernel_src=${KERNEL_DIR} --verbose || die "configure problem" + emake || die "compile problem" +} + +src_install() { + emake DESTDIR=${D} module_dir=${D}/lib/modules/${KV_FULL} install || die "install problem" + rm -f ${D}/usr/include/linux/* || die +} + +pkg_postinst() { + linux-mod_pkg_postinst + + einfo "" + einfo "Please remember to re-emerge ${PN} when you upgrade your kernel!" + einfo "" +} diff --git a/sys-cluster/gfs-kernel/gfs-kernel-1.03.00.ebuild b/sys-cluster/gfs-kernel/gfs-kernel-1.03.00-r1.ebuild index 81275ef53e3a..17d66b930200 100644 --- a/sys-cluster/gfs-kernel/gfs-kernel-1.03.00.ebuild +++ b/sys-cluster/gfs-kernel/gfs-kernel-1.03.00-r1.ebuild @@ -1,10 +1,11 @@ # Copyright 1999-2007 Gentoo Foundation # Distributed under the terms of the GNU General Public License v2 -# $Header: /var/cvsroot/gentoo-x86/sys-cluster/gfs-kernel/gfs-kernel-1.03.00.ebuild,v 1.6 2007/03/03 00:00:09 xmerlin Exp $ +# $Header: /var/cvsroot/gentoo-x86/sys-cluster/gfs-kernel/gfs-kernel-1.03.00-r1.ebuild,v 1.1 2007/05/08 10:53:48 xmerlin Exp $ inherit eutils linux-mod linux-info -MY_P="cluster-${PV}" +CLUSTER_RELEASE="1.03.00" +MY_P="cluster-${CLUSTER_RELEASE}" DESCRIPTION="GFS kernel module" HOMEPAGE="http://sources.redhat.com/cluster/" @@ -17,8 +18,8 @@ KEYWORDS="~amd64 ~ppc ~x86" IUSE="" DEPEND=">=virtual/linux-sources-2.6.16 - >=sys-cluster/dlm-headers-1.03.00 - >=sys-cluster/cman-headers-1.03.00" + =sys-cluster/dlm-headers-${CLUSTER_RELEASE}* + =sys-cluster/cman-headers-${CLUSTER_RELEASE}*" RDEPEND="" @@ -39,6 +40,15 @@ src_unpack() { if [ "$KV_PATCH" -lt "17" ] ; then epatch ${FILESDIR}/gfs-kernel-1.03.00-pre2.6.17-compilefix.patch || die fi + + if [ "$KV_PATCH" -ge "18" ] ; then + epatch ${FILESDIR}/${P}-post-2.6.18.patch || die + + sed -i \ + -e 's|version.h|utsrelease.h|g' \ + configure \ + || die "sed failed" + fi fi } diff --git a/sys-cluster/gfs-kernel/gfs-kernel-1.04.00.ebuild b/sys-cluster/gfs-kernel/gfs-kernel-1.04.00.ebuild new file mode 100644 index 000000000000..dbba1b328965 --- /dev/null +++ b/sys-cluster/gfs-kernel/gfs-kernel-1.04.00.ebuild @@ -0,0 +1,75 @@ +# Copyright 1999-2007 Gentoo Foundation +# Distributed under the terms of the GNU General Public License v2 +# $Header: /var/cvsroot/gentoo-x86/sys-cluster/gfs-kernel/gfs-kernel-1.04.00.ebuild,v 1.1 2007/05/08 10:53:48 xmerlin Exp $ + +inherit eutils linux-mod linux-info + +CLUSTER_RELEASE="1.04.00" +MY_P="cluster-${CLUSTER_RELEASE}" + +DESCRIPTION="GFS kernel module" +HOMEPAGE="http://sources.redhat.com/cluster/" +SRC_URI="ftp://sources.redhat.com/pub/cluster/releases/${MY_P}.tar.gz" + +LICENSE="GPL-2" +SLOT="0" +KEYWORDS="~amd64 ~ppc ~x86" + +IUSE="" + +DEPEND=">=virtual/linux-sources-2.6.17 + =sys-cluster/dlm-headers-${CLUSTER_RELEASE}* + =sys-cluster/cman-headers-${CLUSTER_RELEASE}*" + +RDEPEND="" + +S="${WORKDIR}/${MY_P}/${PN}" + +pkg_setup() { + linux-mod_pkg_setup + case ${KV_FULL} in + 2.2.*|2.4.*) die "${P} supports only 2.6 kernels";; + esac +} + +src_unpack() { + unpack ${A} + cd ${S} + + if kernel_is 2 6; then + #if [ "$KV_PATCH" -lt "17" ] ; then + # epatch ${FILESDIR}/gfs-kernel-1.04.00-pre2.6.17-compilefix.patch || die + #fi + if [ "$KV_PATCH" -lt "18" ] ; then + sed -i \ + -e 's|utsrelease.h|version.h|g' \ + configure \ + || die "sed failed" + + sed -i \ + -e 's|init_utsname()->nodename|system_utsname.nodename|g' \ + src/gulm/gulm_fs.c \ + || die "sed failed" + fi + fi +} + +src_compile() { + set_arch_to_kernel + + ./configure --kernel_src=${KERNEL_DIR} --verbose || die "configure problem" + emake || die "compile problem" +} + +src_install() { + emake DESTDIR=${D} module_dir=${D}/lib/modules/${KV_FULL} install || die "install problem" + rm -f ${D}/usr/include/linux/* || die +} + +pkg_postinst() { + linux-mod_pkg_postinst + + einfo "" + einfo "Please remember to re-emerge ${PN} when you upgrade your kernel!" + einfo "" +} |