Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
Kernel
提交
53d412fc
K
Kernel
项目概览
openeuler
/
Kernel
1 年多 前同步成功
通知
8
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
K
Kernel
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
提交
53d412fc
编写于
7月 24, 2007
作者:
J
Jens Axboe
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
infiniband: sg chaining support
Signed-off-by:
N
Jens Axboe
<
jens.axboe@oracle.com
>
上级
51cf2249
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
47 addition
and
38 deletion
+47
-38
drivers/infiniband/hw/ipath/ipath_dma.c
drivers/infiniband/hw/ipath/ipath_dma.c
+6
-4
drivers/infiniband/ulp/iser/iser_memory.c
drivers/infiniband/ulp/iser/iser_memory.c
+41
-34
未找到文件。
drivers/infiniband/hw/ipath/ipath_dma.c
浏览文件 @
53d412fc
...
@@ -30,6 +30,7 @@
...
@@ -30,6 +30,7 @@
* SOFTWARE.
* SOFTWARE.
*/
*/
#include <linux/scatterlist.h>
#include <rdma/ib_verbs.h>
#include <rdma/ib_verbs.h>
#include "ipath_verbs.h"
#include "ipath_verbs.h"
...
@@ -96,17 +97,18 @@ static void ipath_dma_unmap_page(struct ib_device *dev,
...
@@ -96,17 +97,18 @@ static void ipath_dma_unmap_page(struct ib_device *dev,
BUG_ON
(
!
valid_dma_direction
(
direction
));
BUG_ON
(
!
valid_dma_direction
(
direction
));
}
}
static
int
ipath_map_sg
(
struct
ib_device
*
dev
,
struct
scatterlist
*
sg
,
int
nents
,
static
int
ipath_map_sg
(
struct
ib_device
*
dev
,
struct
scatterlist
*
sg
l
,
enum
dma_data_direction
direction
)
int
nents
,
enum
dma_data_direction
direction
)
{
{
struct
scatterlist
*
sg
;
u64
addr
;
u64
addr
;
int
i
;
int
i
;
int
ret
=
nents
;
int
ret
=
nents
;
BUG_ON
(
!
valid_dma_direction
(
direction
));
BUG_ON
(
!
valid_dma_direction
(
direction
));
for
(
i
=
0
;
i
<
nents
;
i
++
)
{
for
_each_sg
(
sgl
,
sg
,
nents
,
i
)
{
addr
=
(
u64
)
page_address
(
sg
[
i
].
page
);
addr
=
(
u64
)
page_address
(
sg
->
page
);
/* TODO: handle highmem pages */
/* TODO: handle highmem pages */
if
(
!
addr
)
{
if
(
!
addr
)
{
ret
=
0
;
ret
=
0
;
...
...
drivers/infiniband/ulp/iser/iser_memory.c
浏览文件 @
53d412fc
...
@@ -124,17 +124,19 @@ static int iser_start_rdma_unaligned_sg(struct iscsi_iser_cmd_task *iser_ctask,
...
@@ -124,17 +124,19 @@ static int iser_start_rdma_unaligned_sg(struct iscsi_iser_cmd_task *iser_ctask,
if
(
cmd_dir
==
ISER_DIR_OUT
)
{
if
(
cmd_dir
==
ISER_DIR_OUT
)
{
/* copy the unaligned sg the buffer which is used for RDMA */
/* copy the unaligned sg the buffer which is used for RDMA */
struct
scatterlist
*
sg
=
(
struct
scatterlist
*
)
data
->
buf
;
struct
scatterlist
*
sgl
=
(
struct
scatterlist
*
)
data
->
buf
;
struct
scatterlist
*
sg
;
int
i
;
int
i
;
char
*
p
,
*
from
;
char
*
p
,
*
from
;
for
(
p
=
mem
,
i
=
0
;
i
<
data
->
size
;
i
++
)
{
p
=
mem
;
from
=
kmap_atomic
(
sg
[
i
].
page
,
KM_USER0
);
for_each_sg
(
sgl
,
sg
,
data
->
size
,
i
)
{
from
=
kmap_atomic
(
sg
->
page
,
KM_USER0
);
memcpy
(
p
,
memcpy
(
p
,
from
+
sg
[
i
].
offset
,
from
+
sg
->
offset
,
sg
[
i
].
length
);
sg
->
length
);
kunmap_atomic
(
from
,
KM_USER0
);
kunmap_atomic
(
from
,
KM_USER0
);
p
+=
sg
[
i
].
length
;
p
+=
sg
->
length
;
}
}
}
}
...
@@ -176,7 +178,7 @@ void iser_finalize_rdma_unaligned_sg(struct iscsi_iser_cmd_task *iser_ctask,
...
@@ -176,7 +178,7 @@ void iser_finalize_rdma_unaligned_sg(struct iscsi_iser_cmd_task *iser_ctask,
if
(
cmd_dir
==
ISER_DIR_IN
)
{
if
(
cmd_dir
==
ISER_DIR_IN
)
{
char
*
mem
;
char
*
mem
;
struct
scatterlist
*
sg
;
struct
scatterlist
*
sg
l
,
*
sg
;
unsigned
char
*
p
,
*
to
;
unsigned
char
*
p
,
*
to
;
unsigned
int
sg_size
;
unsigned
int
sg_size
;
int
i
;
int
i
;
...
@@ -184,16 +186,17 @@ void iser_finalize_rdma_unaligned_sg(struct iscsi_iser_cmd_task *iser_ctask,
...
@@ -184,16 +186,17 @@ void iser_finalize_rdma_unaligned_sg(struct iscsi_iser_cmd_task *iser_ctask,
/* copy back read RDMA to unaligned sg */
/* copy back read RDMA to unaligned sg */
mem
=
mem_copy
->
copy_buf
;
mem
=
mem_copy
->
copy_buf
;
sg
=
(
struct
scatterlist
*
)
iser_ctask
->
data
[
ISER_DIR_IN
].
buf
;
sg
l
=
(
struct
scatterlist
*
)
iser_ctask
->
data
[
ISER_DIR_IN
].
buf
;
sg_size
=
iser_ctask
->
data
[
ISER_DIR_IN
].
size
;
sg_size
=
iser_ctask
->
data
[
ISER_DIR_IN
].
size
;
for
(
p
=
mem
,
i
=
0
;
i
<
sg_size
;
i
++
){
p
=
mem
;
to
=
kmap_atomic
(
sg
[
i
].
page
,
KM_SOFTIRQ0
);
for_each_sg
(
sgl
,
sg
,
sg_size
,
i
)
{
memcpy
(
to
+
sg
[
i
].
offset
,
to
=
kmap_atomic
(
sg
->
page
,
KM_SOFTIRQ0
);
memcpy
(
to
+
sg
->
offset
,
p
,
p
,
sg
[
i
].
length
);
sg
->
length
);
kunmap_atomic
(
to
,
KM_SOFTIRQ0
);
kunmap_atomic
(
to
,
KM_SOFTIRQ0
);
p
+=
sg
[
i
].
length
;
p
+=
sg
->
length
;
}
}
}
}
...
@@ -224,7 +227,8 @@ static int iser_sg_to_page_vec(struct iser_data_buf *data,
...
@@ -224,7 +227,8 @@ static int iser_sg_to_page_vec(struct iser_data_buf *data,
struct
iser_page_vec
*
page_vec
,
struct
iser_page_vec
*
page_vec
,
struct
ib_device
*
ibdev
)
struct
ib_device
*
ibdev
)
{
{
struct
scatterlist
*
sg
=
(
struct
scatterlist
*
)
data
->
buf
;
struct
scatterlist
*
sgl
=
(
struct
scatterlist
*
)
data
->
buf
;
struct
scatterlist
*
sg
;
u64
first_addr
,
last_addr
,
page
;
u64
first_addr
,
last_addr
,
page
;
int
end_aligned
;
int
end_aligned
;
unsigned
int
cur_page
=
0
;
unsigned
int
cur_page
=
0
;
...
@@ -232,24 +236,25 @@ static int iser_sg_to_page_vec(struct iser_data_buf *data,
...
@@ -232,24 +236,25 @@ static int iser_sg_to_page_vec(struct iser_data_buf *data,
int
i
;
int
i
;
/* compute the offset of first element */
/* compute the offset of first element */
page_vec
->
offset
=
(
u64
)
sg
[
0
].
offset
&
~
MASK_4K
;
page_vec
->
offset
=
(
u64
)
sg
l
[
0
].
offset
&
~
MASK_4K
;
for
(
i
=
0
;
i
<
data
->
dma_nents
;
i
++
)
{
for
_each_sg
(
sgl
,
sg
,
data
->
dma_nents
,
i
)
{
unsigned
int
dma_len
=
ib_sg_dma_len
(
ibdev
,
&
sg
[
i
]
);
unsigned
int
dma_len
=
ib_sg_dma_len
(
ibdev
,
sg
);
total_sz
+=
dma_len
;
total_sz
+=
dma_len
;
first_addr
=
ib_sg_dma_address
(
ibdev
,
&
sg
[
i
]
);
first_addr
=
ib_sg_dma_address
(
ibdev
,
sg
);
last_addr
=
first_addr
+
dma_len
;
last_addr
=
first_addr
+
dma_len
;
end_aligned
=
!
(
last_addr
&
~
MASK_4K
);
end_aligned
=
!
(
last_addr
&
~
MASK_4K
);
/* continue to collect page fragments till aligned or SG ends */
/* continue to collect page fragments till aligned or SG ends */
while
(
!
end_aligned
&&
(
i
+
1
<
data
->
dma_nents
))
{
while
(
!
end_aligned
&&
(
i
+
1
<
data
->
dma_nents
))
{
sg
=
sg_next
(
sg
);
i
++
;
i
++
;
dma_len
=
ib_sg_dma_len
(
ibdev
,
&
sg
[
i
]
);
dma_len
=
ib_sg_dma_len
(
ibdev
,
sg
);
total_sz
+=
dma_len
;
total_sz
+=
dma_len
;
last_addr
=
ib_sg_dma_address
(
ibdev
,
&
sg
[
i
]
)
+
dma_len
;
last_addr
=
ib_sg_dma_address
(
ibdev
,
sg
)
+
dma_len
;
end_aligned
=
!
(
last_addr
&
~
MASK_4K
);
end_aligned
=
!
(
last_addr
&
~
MASK_4K
);
}
}
...
@@ -284,25 +289,26 @@ static int iser_sg_to_page_vec(struct iser_data_buf *data,
...
@@ -284,25 +289,26 @@ static int iser_sg_to_page_vec(struct iser_data_buf *data,
static
unsigned
int
iser_data_buf_aligned_len
(
struct
iser_data_buf
*
data
,
static
unsigned
int
iser_data_buf_aligned_len
(
struct
iser_data_buf
*
data
,
struct
ib_device
*
ibdev
)
struct
ib_device
*
ibdev
)
{
{
struct
scatterlist
*
sg
;
struct
scatterlist
*
sg
l
,
*
sg
;
u64
end_addr
,
next_addr
;
u64
end_addr
,
next_addr
;
int
i
,
cnt
;
int
i
,
cnt
;
unsigned
int
ret_len
=
0
;
unsigned
int
ret_len
=
0
;
sg
=
(
struct
scatterlist
*
)
data
->
buf
;
sg
l
=
(
struct
scatterlist
*
)
data
->
buf
;
for
(
cnt
=
0
,
i
=
0
;
i
<
data
->
dma_nents
;
i
++
,
cnt
++
)
{
cnt
=
0
;
for_each_sg
(
sgl
,
sg
,
data
->
dma_nents
,
i
)
{
/* iser_dbg("Checking sg iobuf [%d]: phys=0x%08lX "
/* iser_dbg("Checking sg iobuf [%d]: phys=0x%08lX "
"offset: %ld sz: %ld\n", i,
"offset: %ld sz: %ld\n", i,
(unsigned long)page_to_phys(sg
[i].
page),
(unsigned long)page_to_phys(sg
->
page),
(unsigned long)sg
[i].
offset,
(unsigned long)sg
->
offset,
(unsigned long)sg
[i].
length); */
(unsigned long)sg
->
length); */
end_addr
=
ib_sg_dma_address
(
ibdev
,
&
sg
[
i
]
)
+
end_addr
=
ib_sg_dma_address
(
ibdev
,
sg
)
+
ib_sg_dma_len
(
ibdev
,
&
sg
[
i
]
);
ib_sg_dma_len
(
ibdev
,
sg
);
/* iser_dbg("Checking sg iobuf end address "
/* iser_dbg("Checking sg iobuf end address "
"0x%08lX\n", end_addr); */
"0x%08lX\n", end_addr); */
if
(
i
+
1
<
data
->
dma_nents
)
{
if
(
i
+
1
<
data
->
dma_nents
)
{
next_addr
=
ib_sg_dma_address
(
ibdev
,
&
sg
[
i
+
1
]
);
next_addr
=
ib_sg_dma_address
(
ibdev
,
sg_next
(
sg
)
);
/* are i, i+1 fragments of the same page? */
/* are i, i+1 fragments of the same page? */
if
(
end_addr
==
next_addr
)
if
(
end_addr
==
next_addr
)
continue
;
continue
;
...
@@ -322,15 +328,16 @@ static unsigned int iser_data_buf_aligned_len(struct iser_data_buf *data,
...
@@ -322,15 +328,16 @@ static unsigned int iser_data_buf_aligned_len(struct iser_data_buf *data,
static
void
iser_data_buf_dump
(
struct
iser_data_buf
*
data
,
static
void
iser_data_buf_dump
(
struct
iser_data_buf
*
data
,
struct
ib_device
*
ibdev
)
struct
ib_device
*
ibdev
)
{
{
struct
scatterlist
*
sg
=
(
struct
scatterlist
*
)
data
->
buf
;
struct
scatterlist
*
sgl
=
(
struct
scatterlist
*
)
data
->
buf
;
struct
scatterlist
*
sg
;
int
i
;
int
i
;
for
(
i
=
0
;
i
<
data
->
dma_nents
;
i
++
)
for
_each_sg
(
sgl
,
sg
,
data
->
dma_nents
,
i
)
iser_err
(
"sg[%d] dma_addr:0x%lX page:0x%p "
iser_err
(
"sg[%d] dma_addr:0x%lX page:0x%p "
"off:0x%x sz:0x%x dma_len:0x%x
\n
"
,
"off:0x%x sz:0x%x dma_len:0x%x
\n
"
,
i
,
(
unsigned
long
)
ib_sg_dma_address
(
ibdev
,
&
sg
[
i
]
),
i
,
(
unsigned
long
)
ib_sg_dma_address
(
ibdev
,
sg
),
sg
[
i
].
page
,
sg
[
i
].
offset
,
sg
->
page
,
sg
->
offset
,
sg
[
i
].
length
,
ib_sg_dma_len
(
ibdev
,
&
sg
[
i
]
));
sg
->
length
,
ib_sg_dma_len
(
ibdev
,
sg
));
}
}
static
void
iser_dump_page_vec
(
struct
iser_page_vec
*
page_vec
)
static
void
iser_dump_page_vec
(
struct
iser_page_vec
*
page_vec
)
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录