15b7a68c1d
Introduce two structures for the (DMA address, length) combination instead of using separate structure members for the DMA address and length. This patch fixes several Coverity complaints about 'cur_dsd' being used to write outside the bounds of structure members. Cc: Himanshu Madhani <hmadhani@marvell.com> Cc: Giridhar Malavali <gmalavali@marvell.com> Signed-off-by: Bart Van Assche <bvanassche@acm.org> Acked-by: Himanshu Madhani <hmadhani@marvell.com> Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com>
31 lines
674 B
C
31 lines
674 B
C
#ifndef _QLA_DSD_H_
|
|
#define _QLA_DSD_H_
|
|
|
|
/* 32-bit data segment descriptor (8 bytes) */
|
|
struct dsd32 {
|
|
__le32 address;
|
|
__le32 length;
|
|
};
|
|
|
|
static inline void append_dsd32(struct dsd32 **dsd, struct scatterlist *sg)
|
|
{
|
|
put_unaligned_le32(sg_dma_address(sg), &(*dsd)->address);
|
|
put_unaligned_le32(sg_dma_len(sg), &(*dsd)->length);
|
|
(*dsd)++;
|
|
}
|
|
|
|
/* 64-bit data segment descriptor (12 bytes) */
|
|
struct dsd64 {
|
|
__le64 address;
|
|
__le32 length;
|
|
} __packed;
|
|
|
|
static inline void append_dsd64(struct dsd64 **dsd, struct scatterlist *sg)
|
|
{
|
|
put_unaligned_le64(sg_dma_address(sg), &(*dsd)->address);
|
|
put_unaligned_le32(sg_dma_len(sg), &(*dsd)->length);
|
|
(*dsd)++;
|
|
}
|
|
|
|
#endif
|