forked from pool/libica
053908a9ac
Major rework of package to conform to shared library policy, including being renamed from libica2 to libica. Additional bugfixes from previous version. Please also make me the maintainer of the package. OBS-URL: https://build.opensuse.org/request/show/484290 OBS-URL: https://build.opensuse.org/package/show/devel:openSUSE:Factory/libica?expand=0&rev=1
220 lines
6.1 KiB
C
220 lines
6.1 KiB
C
/* Copyright (c) International Business Machines Corp., 2001 */
|
|
/*
|
|
* linux/include/linux/icaioctl.h
|
|
*
|
|
*/
|
|
|
|
|
|
|
|
#ifndef _LINUX_ICAIOCTL_H_
|
|
#define _LINUX_ICAIOCTL_H_
|
|
|
|
enum _sizelimits {
|
|
ICA_DES_DATALENGTH_MIN = 8,
|
|
ICA_DES_DATALENGTH_MAX = 32 * 1024 * 1024 - 8,
|
|
ICA_SHA_DATALENGTH = 20,
|
|
ICA_SHA_BLOCKLENGTH = 64,
|
|
ICA_RSA_DATALENGTH_MIN = 256/8,
|
|
ICA_RSA_DATALENGTH_MAX = 2048/8
|
|
};
|
|
|
|
|
|
typedef struct _ica_rng_rec {
|
|
unsigned int nbytes;
|
|
char *buf;
|
|
} ica_rng_t;
|
|
|
|
|
|
// May have some porting issues here
|
|
|
|
typedef struct _ica_rsa_modexpo {
|
|
char *inputdata;
|
|
unsigned int inputdatalength;
|
|
char *outputdata;
|
|
unsigned int outputdatalength;
|
|
char *b_key;
|
|
char *n_modulus;
|
|
} ica_rsa_modexpo_t;
|
|
|
|
typedef ica_rsa_modexpo_t ica_rsa_modmult_t;
|
|
|
|
typedef struct _ica_rsa_modexpo_crt {
|
|
char *inputdata;
|
|
unsigned int inputdatalength;
|
|
char *outputdata;
|
|
unsigned int outputdatalength;
|
|
char *bp_key;
|
|
char *bq_key;
|
|
char *np_prime;
|
|
char *nq_prime;
|
|
char *u_mult_inv;
|
|
} ica_rsa_modexpo_crt_t;
|
|
|
|
typedef unsigned char ica_des_vector_t[8];
|
|
typedef unsigned char ica_des_key_t[8];
|
|
typedef ica_des_key_t ica_des_single_t[1];
|
|
typedef ica_des_single_t ica_des_triple_t[3];
|
|
|
|
enum _ica_mode_des {
|
|
DEVICA_MODE_DES_CBC = 0,
|
|
DEVICA_MODE_DES_ECB = 1
|
|
};
|
|
|
|
enum _ica_direction_des {
|
|
DEVICA_DIR_DES_ENCRYPT = 0,
|
|
DEVICA_DIR_DES_DECRYPT = 1
|
|
};
|
|
|
|
typedef struct _ica_des {
|
|
unsigned int mode;
|
|
unsigned int direction;
|
|
unsigned char *inputdata;
|
|
unsigned int inputdatalength;
|
|
ica_des_vector_t *iv;
|
|
ica_des_key_t *keys;
|
|
unsigned char *outputdata;
|
|
int outputdatalength;
|
|
} ica_des_t;
|
|
|
|
typedef struct _ica_desmac {
|
|
unsigned char *inputdata;
|
|
unsigned int inputdatalength;
|
|
ica_des_vector_t *iv;
|
|
ica_des_key_t *keys;
|
|
unsigned char *outputdata;
|
|
int outputdatalength;
|
|
} ica_desmac_t;
|
|
|
|
|
|
typedef unsigned char ica_sha1_result_t[ICA_SHA_DATALENGTH];
|
|
|
|
|
|
typedef struct _ica_sha1 {
|
|
unsigned char *inputdata;
|
|
unsigned int inputdatalength;
|
|
ica_sha1_result_t *outputdata;
|
|
ica_sha1_result_t *initialh;
|
|
} ica_sha1_t;
|
|
|
|
/* The following structs are used by conversion functions
|
|
on PowerPC 64 bit only. They should not be used by externel
|
|
applications. Should the non PPC specific structs change, these
|
|
structures may need to change as well. Also, new conversion
|
|
routines will need to be added to devica.c to deal with new
|
|
structs or structure members.
|
|
*/
|
|
#ifdef CONFIG_PPC64
|
|
typedef struct _ica_rng_rec_32 {
|
|
unsigned int nbytes;
|
|
unsigned int buf;
|
|
} ica_rng_t_32;
|
|
|
|
typedef struct _ica_des_32 {
|
|
unsigned int mode;
|
|
unsigned int direction;
|
|
unsigned int inputdata;
|
|
unsigned int inputdatalength;
|
|
unsigned int iv;
|
|
unsigned int keys;
|
|
unsigned int outputdata;
|
|
unsigned int outputdatalength;
|
|
} ica_des_t_32;
|
|
|
|
typedef struct _ica_sha1_32 {
|
|
unsigned int inputdata;
|
|
unsigned int inputdatalength;
|
|
unsigned int outputdata;
|
|
unsigned int initialh;
|
|
} ica_sha1_t_32;
|
|
|
|
typedef struct _ica_desmac_32 {
|
|
unsigned int inputdata;
|
|
unsigned int inputdatalength;
|
|
unsigned int iv;
|
|
unsigned int keys;
|
|
unsigned int outputdata;
|
|
int outputdatalength;
|
|
} ica_desmac_t_32;
|
|
|
|
typedef struct _ica_rsa_modexpo_crt_32 {
|
|
unsigned int inputdata;
|
|
unsigned int inputdatalength;
|
|
unsigned int outputdata;
|
|
unsigned int outputdatalength;
|
|
unsigned int bp_key;
|
|
unsigned int bq_key;
|
|
unsigned int np_prime;
|
|
unsigned int nq_prime;
|
|
unsigned int u_mult_inv;
|
|
} ica_rsa_modexpo_crt_t_32;
|
|
|
|
typedef struct _ica_rsa_modexpo_32 {
|
|
unsigned int inputdata;
|
|
unsigned int inputdatalength;
|
|
unsigned int outputdata;
|
|
unsigned int outputdatalength;
|
|
unsigned int b_key;
|
|
unsigned int n_modulus;
|
|
} ica_rsa_modexpo_t_32;
|
|
|
|
#endif
|
|
|
|
#define ICA_IOCTL_MAGIC '?' // NOTE: Need to allocate from linux folks
|
|
|
|
/*
|
|
* Note: Some platforms only use 8 bits to define the parameter size. As
|
|
* the macros in ioctl.h don't seem to mask off offending bits, they look
|
|
* a little unsafe. We should probably just not use the parameter size
|
|
* at all for these ioctls. I don't know if we'll ever run on any of those
|
|
* architectures, but seems easier just to not count on this feature.
|
|
*/
|
|
|
|
#define ICASETBIND _IOW(ICA_IOCTL_MAGIC, 0x01, int)
|
|
#define ICAGETBIND _IOR(ICA_IOCTL_MAGIC, 0x02, int)
|
|
#define ICAGETCOUNT _IOR(ICA_IOCTL_MAGIC, 0x03, int)
|
|
#define ICAGETID _IOR(ICA_IOCTL_MAGIC, 0x04, int)
|
|
#define ICARSAMODEXPO _IOC(_IOC_READ|_IOC_WRITE, ICA_IOCTL_MAGIC, 0x05, 0)
|
|
#define ICARSACRT _IOC(_IOC_READ|_IOC_WRITE, ICA_IOCTL_MAGIC, 0x06, 0)
|
|
#define ICARSAMODMULT _IOC(_IOC_READ|_IOC_WRITE, ICA_IOCTL_MAGIC, 0x07, 0)
|
|
#define ICADES _IOC(_IOC_READ|_IOC_WRITE, ICA_IOCTL_MAGIC, 0x08, 0)
|
|
#define ICADESMAC _IOC(_IOC_READ|_IOC_WRITE, ICA_IOCTL_MAGIC, 0x09, 0)
|
|
#define ICATDES _IOC(_IOC_READ|_IOC_WRITE, ICA_IOCTL_MAGIC, 0x0a, 0)
|
|
#define ICATDESSHA _IOC(_IOC_READ|_IOC_WRITE, ICA_IOCTL_MAGIC, 0x0b, 0)
|
|
#define ICATDESMAC _IOC(_IOC_READ|_IOC_WRITE, ICA_IOCTL_MAGIC, 0x0c, 0)
|
|
#define ICASHA1 _IOC(_IOC_READ|_IOC_WRITE, ICA_IOCTL_MAGIC, 0x0d, 0)
|
|
#define ICARNG _IOC(_IOC_READ, ICA_IOCTL_MAGIC, 0x0e, 0)
|
|
#define ICAGETVPD _IOC(_IOC_READ, ICA_IOCTL_MAGIC, 0x0f, 0)
|
|
|
|
#ifdef __KERNEL__
|
|
|
|
#ifndef assertk
|
|
#ifdef NDEBUG
|
|
# define assertk(expr) do {} while (0)
|
|
#else
|
|
# define assertk(expr) \
|
|
if(!(expr)) { \
|
|
printk( "Assertion failed! %s,%s,%s,line=%d\n", \
|
|
#expr,__FILE__,__FUNCTION__,__LINE__); \
|
|
}
|
|
#endif
|
|
#endif
|
|
|
|
|
|
struct ica_operations {
|
|
ssize_t (*read) (struct file *, char *, size_t, loff_t *, void *);
|
|
int (*ioctl) (struct inode *, struct file *, unsigned int, unsigned long, void *);
|
|
};
|
|
|
|
typedef struct ica_worker {
|
|
struct ica_operations *icaops;
|
|
void * private_data;
|
|
} ica_worker_t;
|
|
|
|
|
|
extern int ica_register_worker(int partitionnum, ica_worker_t *device);
|
|
extern int ica_unregister_worker(int partitionnum, ica_worker_t *device);
|
|
|
|
#endif /* __KERNEL__ */
|
|
|
|
#endif /* _LINUX_ICAIOCTL_H_ */
|