drv_scsi_fw_funcs.c 1.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445
  1. /* QLogic FCoE Offload Driver
  2. * Copyright (c) 2016-2018 Cavium Inc.
  3. *
  4. * This software is available under the terms of the GNU General Public License
  5. * (GPL) Version 2, available from the file COPYING in the main directory of
  6. * this source tree.
  7. */
  8. #include "drv_scsi_fw_funcs.h"
  9. #define SCSI_NUM_SGES_IN_CACHE 0x4
  10. bool scsi_is_slow_sgl(u16 num_sges, bool small_mid_sge)
  11. {
  12. return (num_sges > SCSI_NUM_SGES_SLOW_SGL_THR && small_mid_sge);
  13. }
  14. void init_scsi_sgl_context(struct scsi_sgl_params *ctx_sgl_params,
  15. struct scsi_cached_sges *ctx_data_desc,
  16. struct scsi_sgl_task_params *sgl_task_params)
  17. {
  18. /* no need to check for sgl_task_params->sgl validity */
  19. u8 num_sges_to_init = sgl_task_params->num_sges >
  20. SCSI_NUM_SGES_IN_CACHE ? SCSI_NUM_SGES_IN_CACHE :
  21. sgl_task_params->num_sges;
  22. u8 sge_index;
  23. u32 val;
  24. val = cpu_to_le32(sgl_task_params->sgl_phys_addr.lo);
  25. ctx_sgl_params->sgl_addr.lo = val;
  26. val = cpu_to_le32(sgl_task_params->sgl_phys_addr.hi);
  27. ctx_sgl_params->sgl_addr.hi = val;
  28. val = cpu_to_le32(sgl_task_params->total_buffer_size);
  29. ctx_sgl_params->sgl_total_length = val;
  30. ctx_sgl_params->sgl_num_sges = cpu_to_le16(sgl_task_params->num_sges);
  31. for (sge_index = 0; sge_index < num_sges_to_init; sge_index++) {
  32. val = cpu_to_le32(sgl_task_params->sgl[sge_index].sge_addr.lo);
  33. ctx_data_desc->sge[sge_index].sge_addr.lo = val;
  34. val = cpu_to_le32(sgl_task_params->sgl[sge_index].sge_addr.hi);
  35. ctx_data_desc->sge[sge_index].sge_addr.hi = val;
  36. val = cpu_to_le32(sgl_task_params->sgl[sge_index].sge_len);
  37. ctx_data_desc->sge[sge_index].sge_len = val;
  38. }
  39. }