162306a36Sopenharmony_ci// SPDX-License-Identifier: GPL-2.0-only 262306a36Sopenharmony_ci/* 362306a36Sopenharmony_ci * Huawei HiNIC PCI Express Linux driver 462306a36Sopenharmony_ci * Copyright(c) 2017 Huawei Technologies Co., Ltd 562306a36Sopenharmony_ci */ 662306a36Sopenharmony_ci 762306a36Sopenharmony_ci#include <linux/kernel.h> 862306a36Sopenharmony_ci#include <linux/types.h> 962306a36Sopenharmony_ci#include <asm/byteorder.h> 1062306a36Sopenharmony_ci 1162306a36Sopenharmony_ci#include "hinic_common.h" 1262306a36Sopenharmony_ci 1362306a36Sopenharmony_ci/** 1462306a36Sopenharmony_ci * hinic_cpu_to_be32 - convert data to big endian 32 bit format 1562306a36Sopenharmony_ci * @data: the data to convert 1662306a36Sopenharmony_ci * @len: length of data to convert 1762306a36Sopenharmony_ci **/ 1862306a36Sopenharmony_civoid hinic_cpu_to_be32(void *data, int len) 1962306a36Sopenharmony_ci{ 2062306a36Sopenharmony_ci u32 *mem = data; 2162306a36Sopenharmony_ci int i; 2262306a36Sopenharmony_ci 2362306a36Sopenharmony_ci len = len / sizeof(u32); 2462306a36Sopenharmony_ci 2562306a36Sopenharmony_ci for (i = 0; i < len; i++) { 2662306a36Sopenharmony_ci *mem = cpu_to_be32(*mem); 2762306a36Sopenharmony_ci mem++; 2862306a36Sopenharmony_ci } 2962306a36Sopenharmony_ci} 3062306a36Sopenharmony_ci 3162306a36Sopenharmony_ci/** 3262306a36Sopenharmony_ci * hinic_be32_to_cpu - convert data from big endian 32 bit format 3362306a36Sopenharmony_ci * @data: the data to convert 3462306a36Sopenharmony_ci * @len: length of data to convert 3562306a36Sopenharmony_ci **/ 3662306a36Sopenharmony_civoid hinic_be32_to_cpu(void *data, int len) 3762306a36Sopenharmony_ci{ 3862306a36Sopenharmony_ci u32 *mem = data; 3962306a36Sopenharmony_ci int i; 4062306a36Sopenharmony_ci 4162306a36Sopenharmony_ci len = len / sizeof(u32); 4262306a36Sopenharmony_ci 4362306a36Sopenharmony_ci for (i = 0; i < len; i++) { 4462306a36Sopenharmony_ci *mem = be32_to_cpu(*mem); 4562306a36Sopenharmony_ci mem++; 4662306a36Sopenharmony_ci } 4762306a36Sopenharmony_ci} 4862306a36Sopenharmony_ci 4962306a36Sopenharmony_ci/** 5062306a36Sopenharmony_ci * hinic_set_sge - set dma area in scatter gather entry 5162306a36Sopenharmony_ci * @sge: scatter gather entry 5262306a36Sopenharmony_ci * @addr: dma address 5362306a36Sopenharmony_ci * @len: length of relevant data in the dma address 5462306a36Sopenharmony_ci **/ 5562306a36Sopenharmony_civoid hinic_set_sge(struct hinic_sge *sge, dma_addr_t addr, int len) 5662306a36Sopenharmony_ci{ 5762306a36Sopenharmony_ci sge->hi_addr = upper_32_bits(addr); 5862306a36Sopenharmony_ci sge->lo_addr = lower_32_bits(addr); 5962306a36Sopenharmony_ci sge->len = len; 6062306a36Sopenharmony_ci} 6162306a36Sopenharmony_ci 6262306a36Sopenharmony_ci/** 6362306a36Sopenharmony_ci * hinic_sge_to_dma - get dma address from scatter gather entry 6462306a36Sopenharmony_ci * @sge: scatter gather entry 6562306a36Sopenharmony_ci * 6662306a36Sopenharmony_ci * Return dma address of sg entry 6762306a36Sopenharmony_ci **/ 6862306a36Sopenharmony_cidma_addr_t hinic_sge_to_dma(struct hinic_sge *sge) 6962306a36Sopenharmony_ci{ 7062306a36Sopenharmony_ci return (dma_addr_t)((((u64)sge->hi_addr) << 32) | sge->lo_addr); 7162306a36Sopenharmony_ci} 72