On 03/03/2017 12:18 AM, Hillf Danton wrote:
On March 03, 2017 5:45 AM Laura Abbott wrote:
+static struct sg_table *dup_sg_table(struct sg_table *table) +{
- struct sg_table *new_table;
- int ret, i;
- struct scatterlist *sg, *new_sg;
- new_table = kzalloc(sizeof(*new_table), GFP_KERNEL);
- if (!new_table)
return ERR_PTR(-ENOMEM);
- ret = sg_alloc_table(new_table, table->nents, GFP_KERNEL);
- if (ret) {
kfree(table);
Free new table?
return ERR_PTR(-ENOMEM);
- }
- new_sg = new_table->sgl;
- for_each_sg(table->sgl, sg, table->nents, i) {
memcpy(new_sg, sg, sizeof(*sg));
sg->dma_address = 0;
new_sg = sg_next(new_sg);
- }
Do we need a helper, sg_copy_table(dst_table, src_table)?
- return new_table;
+}
Yes, that would probably be good since I've seen this code elsewhere.
Thanks, Laura