代码拉取完成,页面将自动刷新
/*
* Copyright (C) 2019. Huawei Technologies Co.,Ltd.All rights reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
#ifndef __WD_EC_H
#define __WD_EC_H
#include <stdlib.h>
#include <errno.h>
#include <linux/types.h>
#include "wd.h"
#define SRC_ADDR_TABLE_NUM 48
#define SRC_DIF_TABLE_NUM 20
#define DST_ADDR_TABLE_NUM 26
#define DST_DIF_TABLE_NUM 17
#define WCRYPTO_EC_TBl_SIZE 4096
#define WCRYPTO_EC_CTX_MSG_NUM 256
#define WCRYPTO_EC_MAX_CTX 256
#define SRC_TAG_TBL_RESERVE_LEN 4
#define DST_TBL_RESERVE_LEN 6
#define DST_TAG_TBL_RESERVE_LEN 7
/* src data addr table, should be 64byte aligned.*/
struct src_tbl {
__u64 content[SRC_ADDR_TABLE_NUM];
};
/* src data dif table, should be 64byte aligned.*/
struct src_tag_tbl {
__u64 content[SRC_DIF_TABLE_NUM];
__u64 reserve[SRC_TAG_TBL_RESERVE_LEN];
};
/* dst data addr table, should be 64byte aligned.*/
struct dst_tbl {
__u64 content[DST_ADDR_TABLE_NUM];
__u64 reserve[DST_TBL_RESERVE_LEN];
};
/* dst data dif table, should be 64byte aligned.*/
struct dst_tag_tbl {
__u64 content[DST_DIF_TABLE_NUM];
__u64 reserve[DST_TAG_TBL_RESERVE_LEN];
};
struct wcrypto_ec_table {
struct src_tbl *src_addr;
__u64 src_addr_pa;
struct dst_tbl *dst_addr;
__u64 dst_addr_pa;
struct src_tag_tbl *src_tag_addr;
__u64 src_tag_addr_pa;
struct dst_tag_tbl *dst_tag_addr;
__u64 dst_tag_addr_pa;
__u8 *matrix;
__u64 matrix_pa;
};
enum wcrypto_ec_type {
WCRYPTO_EC_MPCC = 0,
WCRYPTO_EC_FLEXEC = 2,
};
enum wcrypto_ec_op_type {
WCRYPTO_EC_GENERATE,
WCRYPTO_EC_VALIDATE,
WCRYPTO_EC_UPDATE,
WCRYPTO_EC_RECONSTRUCT,
};
enum wcrypto_ec_alg_gran {
WCRYPTO_EC_ALG_BLK512B,
WCRYPTO_EC_ALG_BLK4K,
};
enum wcrypto_ec_cm_ctrl {
WCRYPTO_EC_NO_CM_LOAD,
WCRYPTO_EC_CM_LOAD,
};
enum wcrypto_ec_blksize {
WCRYPTO_EC_BLK_512 = 512,
WCRYPTO_EC_BLK_520 = 520,
WCRYPTO_EC_BLK_4096 = 4096,
WCRYPTO_EC_BLK_4104 = 4104,
WCRYPTO_EC_BLK_4160 = 4160,
};
struct dif_gen {
__u32 page_layout_gen_type:4;
__u32 grd_gen_type:4;
__u32 ver_gen_type:4;
__u32 app_gen_type:4;
__u32 ref_gen_type:4;
__u32 page_layout_pad_type:2;
__u32 reserved:10;
};
struct dif_verify {
__u16 page_layout_pad_type:2;
__u16 grd_verify_type:4;
__u16 ref_verify_type:4;
__u16 reserved:6;
};
struct dif_ctrl {
struct dif_gen gen;
struct dif_verify verify;
};
/**
* general dif structure
* @lba: lba for dif ref field
* @priv: private info for dif ref field
* @ver: 8bit version
* @app: 8bit application information field
* @ctrl: dif gen and verify ctrl info
*/
struct wcrypto_dif {
__u64 lba;
__u32 priv;
__u8 ver;
__u8 app;
struct dif_ctrl ctrl;
};
/**
* EC dif format of Warpdrive
* @src_dif: dif of in disk
* @dst_dif: dif of out disk
*/
struct wcrypto_ec_priv_data {
struct wcrypto_dif src_dif;
struct wcrypto_dif dst_dif;
};
/**
* different contexts for different users/threads
* @ec_type: denoted by enum wcrypto_ec_type
* @cb: call back functions of user
* @data_fmt: denoted by enum wcrypto_buff_type
* @ops: memory from user, it is given at ctx creating
*/
struct wcrypto_ec_ctx_setup {
enum wcrypto_ec_type ec_type;
wcrypto_cb cb;
__u16 data_fmt;
struct wd_mm_ops ops;
};
/**
* operational data per I/O operation
* @op_type: denoted by enum wcrypto_ec_op_type
* @status: I/O operation return status
* @coef_matrix: Coefficient matrix
* @in: Input address
* @out: Result address
* @coef_matrix_load: coef_matrix reload control, 0: do not load, 1: load
* @coef_matrix_len: length of loaded coe_matrix, equal to src_num
* @in_disk_num: number of source disks
* @out_disk_num: number of destination disks
* @alg_blk_size: algorithm granularity, denoted by enum wd_ec_alg_gran
* @block_size: denoted by enum wd_ec_blksize
* @block_num: number of sector
* @priv: private information for data extension
*/
struct wcrypto_ec_op_data {
enum wcrypto_ec_op_type op_type;
int status;
__u8 *coef_matrix;
void *in;
void *out;
__u8 coef_matrix_load;
__u8 coef_matrix_len;
__u8 in_disk_num;
__u8 out_disk_num;
__u8 alg_blk_size;
__u16 block_size;
__u16 block_num;
void *priv;
};
/**
* EC message format of Warpdrive
*@alg_type: denoted by enum wcrypto_type
*@ec_type: denoted by enum wcrypto_ec_type
*@op_type: denoted by enum wcrypto_ec_op_type
*@result: denoted by WD error code
*@usr_data: wcrypto_ec_tag
*@cid: ctx_id
*/
struct wcrypto_ec_msg {
__u8 alg_type;
__u8 ec_type;
__u8 op_type;
__u8 data_fmt;
__u8 result;
__u8 coef_matrix_load;
__u8 coef_matrix_len;
__u8 in_disk_num;
__u8 out_disk_num;
__u8 alg_blk_size;
__u16 block_size;
__u16 block_num;
__u32 cid;
__u8 *coef_matrix;
void *in;
void *out;
__u64 usr_data;
};
/**
* wcrypto_create_ec_ctx() - create a ec context on the wrapdrive queue.
* @q: wrapdrive queue, need requested by user.
* @setup:setup data of user
*/
void *wcrypto_create_ec_ctx(struct wd_queue *q,
struct wcrypto_ec_ctx_setup *setup);
/**
* wcrypto_do_ec() - syn/asynchronous flexec/mpcc operation
* @ctx: context of user
* @opdata: operational data
* @tag: asynchronous:uesr_tag; synchronous:NULL.
*/
int wcrypto_do_ec(void *ctx, struct wcrypto_ec_op_data *opdata, void *tag);
/**
* wcrypto_ec_poll() - poll operation for asynchronous operation
* @q:wrapdrive queue
* @num:how many respondings this poll has to get, 0 means get all finishings
*/
int wcrypto_ec_poll(struct wd_queue *q, int num);
/**
* wcrypto_del_ec_ctx() - free ec context
* @ctx: the context to be free
*/
void wcrypto_del_ec_ctx(void *ctx);
#endif
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。