18c2ecf20Sopenharmony_ci// SPDX-License-Identifier: GPL-2.0-only 28c2ecf20Sopenharmony_ci/* 38c2ecf20Sopenharmony_ci * Huawei HiNIC PCI Express Linux driver 48c2ecf20Sopenharmony_ci * Copyright(c) 2017 Huawei Technologies Co., Ltd 58c2ecf20Sopenharmony_ci */ 68c2ecf20Sopenharmony_ci 78c2ecf20Sopenharmony_ci#include <linux/kernel.h> 88c2ecf20Sopenharmony_ci#include <linux/types.h> 98c2ecf20Sopenharmony_ci#include <asm/byteorder.h> 108c2ecf20Sopenharmony_ci 118c2ecf20Sopenharmony_ci#include "hinic_common.h" 128c2ecf20Sopenharmony_ci 138c2ecf20Sopenharmony_ci/** 148c2ecf20Sopenharmony_ci * hinic_cpu_to_be32 - convert data to big endian 32 bit format 158c2ecf20Sopenharmony_ci * @data: the data to convert 168c2ecf20Sopenharmony_ci * @len: length of data to convert 178c2ecf20Sopenharmony_ci **/ 188c2ecf20Sopenharmony_civoid hinic_cpu_to_be32(void *data, int len) 198c2ecf20Sopenharmony_ci{ 208c2ecf20Sopenharmony_ci u32 *mem = data; 218c2ecf20Sopenharmony_ci int i; 228c2ecf20Sopenharmony_ci 238c2ecf20Sopenharmony_ci len = len / sizeof(u32); 248c2ecf20Sopenharmony_ci 258c2ecf20Sopenharmony_ci for (i = 0; i < len; i++) { 268c2ecf20Sopenharmony_ci *mem = cpu_to_be32(*mem); 278c2ecf20Sopenharmony_ci mem++; 288c2ecf20Sopenharmony_ci } 298c2ecf20Sopenharmony_ci} 308c2ecf20Sopenharmony_ci 318c2ecf20Sopenharmony_ci/** 328c2ecf20Sopenharmony_ci * hinic_be32_to_cpu - convert data from big endian 32 bit format 338c2ecf20Sopenharmony_ci * @data: the data to convert 348c2ecf20Sopenharmony_ci * @len: length of data to convert 358c2ecf20Sopenharmony_ci **/ 368c2ecf20Sopenharmony_civoid hinic_be32_to_cpu(void *data, int len) 378c2ecf20Sopenharmony_ci{ 388c2ecf20Sopenharmony_ci u32 *mem = data; 398c2ecf20Sopenharmony_ci int i; 408c2ecf20Sopenharmony_ci 418c2ecf20Sopenharmony_ci len = len / sizeof(u32); 428c2ecf20Sopenharmony_ci 438c2ecf20Sopenharmony_ci for (i = 0; i < len; i++) { 448c2ecf20Sopenharmony_ci *mem = be32_to_cpu(*mem); 458c2ecf20Sopenharmony_ci mem++; 468c2ecf20Sopenharmony_ci } 478c2ecf20Sopenharmony_ci} 488c2ecf20Sopenharmony_ci 498c2ecf20Sopenharmony_ci/** 508c2ecf20Sopenharmony_ci * hinic_set_sge - set dma area in scatter gather entry 518c2ecf20Sopenharmony_ci * @sge: scatter gather entry 528c2ecf20Sopenharmony_ci * @addr: dma address 538c2ecf20Sopenharmony_ci * @len: length of relevant data in the dma address 548c2ecf20Sopenharmony_ci **/ 558c2ecf20Sopenharmony_civoid hinic_set_sge(struct hinic_sge *sge, dma_addr_t addr, int len) 568c2ecf20Sopenharmony_ci{ 578c2ecf20Sopenharmony_ci sge->hi_addr = upper_32_bits(addr); 588c2ecf20Sopenharmony_ci sge->lo_addr = lower_32_bits(addr); 598c2ecf20Sopenharmony_ci sge->len = len; 608c2ecf20Sopenharmony_ci} 618c2ecf20Sopenharmony_ci 628c2ecf20Sopenharmony_ci/** 638c2ecf20Sopenharmony_ci * hinic_sge_to_dma - get dma address from scatter gather entry 648c2ecf20Sopenharmony_ci * @sge: scatter gather entry 658c2ecf20Sopenharmony_ci * 668c2ecf20Sopenharmony_ci * Return dma address of sg entry 678c2ecf20Sopenharmony_ci **/ 688c2ecf20Sopenharmony_cidma_addr_t hinic_sge_to_dma(struct hinic_sge *sge) 698c2ecf20Sopenharmony_ci{ 708c2ecf20Sopenharmony_ci return (dma_addr_t)((((u64)sge->hi_addr) << 32) | sge->lo_addr); 718c2ecf20Sopenharmony_ci} 72