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

Reply via email to