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