summaryrefslogtreecommitdiffstats
path: root/meta-networking/recipes-extended/iscsitarget/files/build_with_updated_bio_struct_of_linux_v4.3_and_above.patch
diff options
context:
space:
mode:
authorJagadeesh Krishnanjanappa <jkrishnanjanappa@mvista.com>2016-04-10 09:35:27 +0530
committerJoe MacDonald <joe_macdonald@mentor.com>2016-04-29 11:57:47 -0400
commit37c8e1f9909610be7a80074e379ef5c8290bc206 (patch)
tree25736c832fd0edd0723d820f71ce3104491c7607 /meta-networking/recipes-extended/iscsitarget/files/build_with_updated_bio_struct_of_linux_v4.3_and_above.patch
parenteba63b3b2e6fcc83d03f6d09f833152ae9c9ee83 (diff)
downloadmeta-openembedded-37c8e1f9909610be7a80074e379ef5c8290bc206.tar.gz
iscsitarget: resolve build error with linux kernel 4.3 and above
1. test_bit was used to return true boolean value, if BIO_UPTODATE bit of bio->bi_flags is set. But the same job can be done by checking bio->bi_error, implemented in linux kernel 4.3 and above. If bio->bi_error is set, then it denotes error. Ref: https://github.com/torvalds/linux/commit/4246a0b63bd8f56a1469b12eafeb875b1041a451 It solves below build error: -- snip -- iscsitarget-1.4.20.3+svn502/kernel/block-io.c:40:19: error: 'BIO_UPTODATE' undeclared (first use in this function) error = test_bit(BIO_UPTODATE, &bio->bi_flags) ? error : -EIO; -- CUT -- 2. bio can always be filled to a maximum value of BIO_MAX_PAGES, so no need to check for min value for linux kernel 4.3 and above. Ref: https://github.com/torvalds/linux/commit/b54ffb73cadcdcff9cc1ae0e11f502407e3e2e4c It solves below build error: -- snip -- iscsitarget-1.4.20.3+svn502/kernel/block-io.c:80:15: error: implicit declaration of function 'bio_get_nr_vecs' [-Werror=implicit-function-declaration] max_pages = bio_get_nr_vecs(bio_data->bdev); -- CUT -- 3. Remove unwanted explicit setting of CFLAGS and CC flags. Setting them in oe_runmake command, will override CFLAGS mentioned in iscsitarget Makefile and resulting in a below error: -- snip -- In file included from iscsid.c:38:0: iscsid.h:38:19: fatal error: iet_u.h: No such file or directory compilation terminated. In file included from conn.c:15:0: iscsid.h:38:19: fatal error: iet_u.h: No such file or directory compilation terminated. -- CUT -- Signed-off-by: Jagadeesh Krishnanjanappa <jkrishnanjanappa@mvista.com> Signed-off-by: Martin Jansa <Martin.Jansa@gmail.com> Signed-off-by: Joe MacDonald <joe_macdonald@mentor.com>
Diffstat (limited to 'meta-networking/recipes-extended/iscsitarget/files/build_with_updated_bio_struct_of_linux_v4.3_and_above.patch')
-rw-r--r--meta-networking/recipes-extended/iscsitarget/files/build_with_updated_bio_struct_of_linux_v4.3_and_above.patch75
1 files changed, 75 insertions, 0 deletions
diff --git a/meta-networking/recipes-extended/iscsitarget/files/build_with_updated_bio_struct_of_linux_v4.3_and_above.patch b/meta-networking/recipes-extended/iscsitarget/files/build_with_updated_bio_struct_of_linux_v4.3_and_above.patch
new file mode 100644
index 000000000..0e8b792af
--- /dev/null
+++ b/meta-networking/recipes-extended/iscsitarget/files/build_with_updated_bio_struct_of_linux_v4.3_and_above.patch
@@ -0,0 +1,75 @@
11. test_bit was used to return true boolean value, if
2 BIO_UPTODATE bit of bio->bi_flags is set. But the same
3 job can be done by checking bio->bi_error, implemented in
4 linux kernel 4.3 and above. If bio->bi_error is set, then
5 it denotes error.
6
7Ref: https://github.com/torvalds/linux/commit/4246a0b63bd8f56a1469b12eafeb875b1041a451
8
9It solves below build error:
10-- snip --
11iscsitarget-1.4.20.3+svn502/kernel/block-io.c:40:19: error: 'BIO_UPTODATE' undeclared (first use in this function)
12 error = test_bit(BIO_UPTODATE, &bio->bi_flags) ? error : -EIO;
13-- CUT --
14
152. bio can always be filled to a maximum value of BIO_MAX_PAGES,
16 so no need to check for min value for linux kernel 4.3 and above.
17
18Ref: https://github.com/torvalds/linux/commit/b54ffb73cadcdcff9cc1ae0e11f502407e3e2e4c
19
20It solves below build error:
21-- snip --
22iscsitarget-1.4.20.3+svn502/kernel/block-io.c:80:15: error: implicit declaration of function 'bio_get_nr_vecs' [-Werror=implicit-function-declaration]
23 max_pages = bio_get_nr_vecs(bio_data->bdev);
24-- CUT --
25
26Upstream-Status: Pending
27
28Signed-off-by: Jagadeesh Krishnanjanappa <jkrishnanjanappa@mvista.com>
29
30diff -Naurp iscsitarget-1.4.20.3+svn502_org/kernel/block-io.c iscsitarget-1.4.20.3+svn502/kernel/block-io.c
31--- iscsitarget-1.4.20.3+svn502_org/kernel/block-io.c 2016-04-01 09:07:12.891810059 +0530
32+++ iscsitarget-1.4.20.3+svn502/kernel/block-io.c 2016-04-01 09:15:59.076469313 +0530
33@@ -33,7 +33,11 @@ static void blockio_bio_endio(struct bio
34 {
35 struct tio_work *tio_work = bio->bi_private;
36
37+#if LINUX_VERSION_CODE >= KERNEL_VERSION(4, 3, 0)
38+ error = bio->bi_error ? -EIO : error;
39+#else
40 error = test_bit(BIO_UPTODATE, &bio->bi_flags) ? error : -EIO;
41+#endif /* LINUX_VERSION_CODE >= KERNEL_VERSION(4, 3, 0) */
42
43 if (error)
44 atomic_set(&tio_work->error, error);
45@@ -61,6 +65,10 @@ blockio_make_request(struct iet_volume *
46 u32 size = tio->size;
47 u32 tio_index = 0;
48
49+#if LINUX_VERSION_CODE >= KERNEL_VERSION(4, 3, 0)
50+ int err = 0;
51+ loff_t ppos = tio->offset;
52+#else
53 int max_pages = 1;
54 int err = 0;
55
56@@ -69,6 +77,7 @@ blockio_make_request(struct iet_volume *
57 /* Calculate max_pages for bio_alloc (memory saver) */
58 if (bdev_q)
59 max_pages = bio_get_nr_vecs(bio_data->bdev);
60+#endif /* LINUX_VERSION_CODE >= KERNEL_VERSION(4, 3, 0) */
61
62 tio_work = kzalloc(sizeof (*tio_work), GFP_KERNEL);
63 if (!tio_work)
64@@ -80,7 +89,11 @@ blockio_make_request(struct iet_volume *
65
66 /* Main processing loop, allocate and fill all bios */
67 while (size && tio_index < tio->pg_cnt) {
68+#if LINUX_VERSION_CODE >= KERNEL_VERSION(4, 3, 0)
69+ bio = bio_alloc(GFP_KERNEL, BIO_MAX_PAGES);
70+#else
71 bio = bio_alloc(GFP_KERNEL, min(max_pages, BIO_MAX_PAGES));
72+#endif /* LINUX_VERSION_CODE >= KERNEL_VERSION(4, 3, 0) */
73 if (!bio) {
74 err = -ENOMEM;
75 goto out;