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