|
Packit |
8681c6 |
/*
|
|
Packit |
8681c6 |
* COPYRIGHT (c) International Business Machines Corp. 2001-2017
|
|
Packit |
8681c6 |
*
|
|
Packit |
8681c6 |
* This program is provided under the terms of the Common Public License,
|
|
Packit |
8681c6 |
* version 1.0 (CPL-1.0). Any use, reproduction or distribution for this
|
|
Packit |
8681c6 |
* software constitutes recipient's acceptance of CPL-1.0 terms which can be
|
|
Packit |
8681c6 |
* found in the file LICENSE file or at
|
|
Packit |
8681c6 |
* https://opensource.org/licenses/cpl1.0.php
|
|
Packit |
8681c6 |
*/
|
|
Packit |
8681c6 |
|
|
Packit |
8681c6 |
// File: hwf_obj.c
|
|
Packit |
8681c6 |
//
|
|
Packit |
8681c6 |
// Hardware Feature Object functions
|
|
Packit |
8681c6 |
|
|
Packit |
8681c6 |
#include <pthread.h>
|
|
Packit |
8681c6 |
#include <stdlib.h>
|
|
Packit |
8681c6 |
|
|
Packit |
8681c6 |
#include <string.h> // for memcmp() et al
|
|
Packit |
8681c6 |
|
|
Packit |
8681c6 |
#include "pkcs11types.h"
|
|
Packit |
8681c6 |
#include "defs.h"
|
|
Packit |
8681c6 |
#include "host_defs.h"
|
|
Packit |
8681c6 |
#include "h_extern.h"
|
|
Packit |
8681c6 |
#include "trace.h"
|
|
Packit |
8681c6 |
|
|
Packit |
8681c6 |
#include "tok_spec_struct.h"
|
|
Packit |
8681c6 |
|
|
Packit |
8681c6 |
|
|
Packit |
8681c6 |
// hwf_object_check_required_attributes()
|
|
Packit |
8681c6 |
//
|
|
Packit |
8681c6 |
// Check required common attributes for hardware feature objects
|
|
Packit |
8681c6 |
//
|
|
Packit |
8681c6 |
CK_RV hwf_object_check_required_attributes(TEMPLATE *tmpl, CK_ULONG mode)
|
|
Packit |
8681c6 |
{
|
|
Packit |
8681c6 |
CK_ATTRIBUTE *attr = NULL;
|
|
Packit |
8681c6 |
CK_BBOOL found;
|
|
Packit |
8681c6 |
|
|
Packit |
8681c6 |
found = template_attribute_find(tmpl, CKA_HW_FEATURE_TYPE, &attr);
|
|
Packit |
8681c6 |
if (!found) {
|
|
Packit |
8681c6 |
if (mode == MODE_CREATE) {
|
|
Packit |
8681c6 |
TRACE_ERROR("%s\n", ock_err(ERR_TEMPLATE_INCOMPLETE));
|
|
Packit |
8681c6 |
return CKR_TEMPLATE_INCOMPLETE;
|
|
Packit |
8681c6 |
}
|
|
Packit |
8681c6 |
}
|
|
Packit |
8681c6 |
|
|
Packit |
8681c6 |
return template_check_required_base_attributes(tmpl, mode);
|
|
Packit |
8681c6 |
}
|
|
Packit |
8681c6 |
|
|
Packit |
8681c6 |
CK_RV clock_check_required_attributes(TEMPLATE *tmpl, CK_ULONG mode)
|
|
Packit |
8681c6 |
{
|
|
Packit |
8681c6 |
CK_ATTRIBUTE *attr = NULL;
|
|
Packit |
8681c6 |
CK_BBOOL found;
|
|
Packit |
8681c6 |
|
|
Packit |
8681c6 |
if (mode == MODE_CREATE) {
|
|
Packit |
8681c6 |
found = template_attribute_find(tmpl, CKA_VALUE, &attr);
|
|
Packit |
8681c6 |
if (!found) {
|
|
Packit |
8681c6 |
TRACE_ERROR("%s\n", ock_err(ERR_TEMPLATE_INCOMPLETE));
|
|
Packit |
8681c6 |
return CKR_TEMPLATE_INCOMPLETE;
|
|
Packit |
8681c6 |
}
|
|
Packit |
8681c6 |
}
|
|
Packit |
8681c6 |
|
|
Packit |
8681c6 |
return hwf_object_check_required_attributes(tmpl, mode);
|
|
Packit |
8681c6 |
}
|
|
Packit |
8681c6 |
|
|
Packit |
8681c6 |
CK_RV counter_check_required_attributes(TEMPLATE *tmpl, CK_ULONG mode)
|
|
Packit |
8681c6 |
{
|
|
Packit |
8681c6 |
CK_ATTRIBUTE *attr = NULL;
|
|
Packit |
8681c6 |
CK_BBOOL found;
|
|
Packit |
8681c6 |
|
|
Packit |
8681c6 |
if (mode == MODE_CREATE) {
|
|
Packit |
8681c6 |
found = template_attribute_find(tmpl, CKA_VALUE, &attr);
|
|
Packit |
8681c6 |
if (!found) {
|
|
Packit |
8681c6 |
TRACE_ERROR("%s\n", ock_err(ERR_TEMPLATE_INCOMPLETE));
|
|
Packit |
8681c6 |
return CKR_TEMPLATE_INCOMPLETE;
|
|
Packit |
8681c6 |
}
|
|
Packit |
8681c6 |
|
|
Packit |
8681c6 |
found = template_attribute_find(tmpl, CKA_HAS_RESET, &attr);
|
|
Packit |
8681c6 |
if (!found) {
|
|
Packit |
8681c6 |
TRACE_ERROR("%s\n", ock_err(ERR_TEMPLATE_INCOMPLETE));
|
|
Packit |
8681c6 |
return CKR_TEMPLATE_INCOMPLETE;
|
|
Packit |
8681c6 |
}
|
|
Packit |
8681c6 |
|
|
Packit |
8681c6 |
found = template_attribute_find(tmpl, CKA_RESET_ON_INIT, &attr);
|
|
Packit |
8681c6 |
if (!found) {
|
|
Packit |
8681c6 |
TRACE_ERROR("%s\n", ock_err(ERR_TEMPLATE_INCOMPLETE));
|
|
Packit |
8681c6 |
return CKR_TEMPLATE_INCOMPLETE;
|
|
Packit |
8681c6 |
}
|
|
Packit |
8681c6 |
}
|
|
Packit |
8681c6 |
|
|
Packit |
8681c6 |
return hwf_object_check_required_attributes(tmpl, mode);
|
|
Packit |
8681c6 |
}
|
|
Packit |
8681c6 |
|
|
Packit |
8681c6 |
|
|
Packit |
8681c6 |
// hwf_object_set_default_attributes()
|
|
Packit |
8681c6 |
//
|
|
Packit |
8681c6 |
CK_RV hwf_object_set_default_attributes(TEMPLATE *tmpl, CK_ULONG mode)
|
|
Packit |
8681c6 |
{
|
|
Packit |
8681c6 |
#if 0
|
|
Packit |
8681c6 |
CK_ATTRIBUTE *local_attr = NULL;
|
|
Packit |
8681c6 |
|
|
Packit |
8681c6 |
local_attr =
|
|
Packit |
8681c6 |
(CK_ATTRIBUTE *) malloc(sizeof(CK_ATTRIBUTE) + sizeof(CK_BBOOL));
|
|
Packit |
8681c6 |
|
|
Packit |
8681c6 |
if (!local_attr) {
|
|
Packit |
8681c6 |
TRACE_ERROR("%s\n", ock_err(ERR_HOST_MEMORY));
|
|
Packit |
8681c6 |
return CKR_HOST_MEMORY;
|
|
Packit |
8681c6 |
}
|
|
Packit |
8681c6 |
|
|
Packit |
8681c6 |
local_attr->type = CKA_LOCAL;
|
|
Packit |
8681c6 |
local_attr->ulValueLen = sizeof(CK_BBOOL);
|
|
Packit |
8681c6 |
local_attr->pValue = (CK_BYTE *) local_attr + sizeof(CK_ATTRIBUTE);
|
|
Packit |
8681c6 |
*(CK_BBOOL *) local_attr->pValue = FALSE;
|
|
Packit |
8681c6 |
|
|
Packit |
8681c6 |
template_update_attribute(tmpl, local_attr);
|
|
Packit |
8681c6 |
#endif
|
|
Packit |
8681c6 |
UNUSED(tmpl);
|
|
Packit |
8681c6 |
UNUSED(mode);
|
|
Packit |
8681c6 |
|
|
Packit |
8681c6 |
return CKR_OK;
|
|
Packit |
8681c6 |
}
|
|
Packit |
8681c6 |
|
|
Packit |
8681c6 |
|
|
Packit |
8681c6 |
// hwf_object_validate_attribute()
|
|
Packit |
8681c6 |
//
|
|
Packit |
8681c6 |
CK_RV hwf_validate_attribute(TEMPLATE *tmpl, CK_ATTRIBUTE *attr,
|
|
Packit |
8681c6 |
CK_ULONG mode)
|
|
Packit |
8681c6 |
{
|
|
Packit |
8681c6 |
switch (attr->type) {
|
|
Packit |
8681c6 |
case CKA_HW_FEATURE_TYPE:
|
|
Packit |
8681c6 |
if (mode == MODE_CREATE)
|
|
Packit |
8681c6 |
return CKR_OK;
|
|
Packit |
8681c6 |
|
|
Packit |
8681c6 |
TRACE_ERROR("%s\n", ock_err(ERR_ATTRIBUTE_READ_ONLY));
|
|
Packit |
8681c6 |
return CKR_ATTRIBUTE_READ_ONLY;
|
|
Packit |
8681c6 |
default:
|
|
Packit |
8681c6 |
return template_validate_base_attribute(tmpl, attr, mode);
|
|
Packit |
8681c6 |
}
|
|
Packit |
8681c6 |
|
|
Packit Service |
8aa27d |
TRACE_ERROR("%s: %lx\n", ock_err(ERR_ATTRIBUTE_TYPE_INVALID), attr->type);
|
|
Packit |
8681c6 |
return CKR_ATTRIBUTE_TYPE_INVALID;
|
|
Packit |
8681c6 |
}
|
|
Packit |
8681c6 |
|
|
Packit |
8681c6 |
//
|
|
Packit |
8681c6 |
//
|
|
Packit |
8681c6 |
CK_RV clock_validate_attribute(TEMPLATE *tmpl, CK_ATTRIBUTE *attr,
|
|
Packit |
8681c6 |
CK_ULONG mode)
|
|
Packit |
8681c6 |
{
|
|
Packit |
8681c6 |
UNUSED(mode);
|
|
Packit |
8681c6 |
|
|
Packit |
8681c6 |
switch (attr->type) {
|
|
Packit |
8681c6 |
case CKA_VALUE:
|
|
Packit |
8681c6 |
return CKR_OK;
|
|
Packit |
8681c6 |
default:
|
|
Packit |
8681c6 |
return hwf_validate_attribute(tmpl, attr, mode);
|
|
Packit |
8681c6 |
}
|
|
Packit |
8681c6 |
}
|
|
Packit |
8681c6 |
|
|
Packit |
8681c6 |
//
|
|
Packit |
8681c6 |
//
|
|
Packit |
8681c6 |
CK_RV counter_validate_attribute(TEMPLATE *tmpl, CK_ATTRIBUTE *attr,
|
|
Packit |
8681c6 |
CK_ULONG mode)
|
|
Packit |
8681c6 |
{
|
|
Packit |
8681c6 |
switch (attr->type) {
|
|
Packit |
8681c6 |
case CKA_VALUE:
|
|
Packit |
8681c6 |
/* Fall Through */
|
|
Packit |
8681c6 |
case CKA_HAS_RESET:
|
|
Packit |
8681c6 |
/* Fall Through */
|
|
Packit |
8681c6 |
case CKA_RESET_ON_INIT:
|
|
Packit |
8681c6 |
TRACE_ERROR("%s\n", ock_err(ERR_ATTRIBUTE_READ_ONLY));
|
|
Packit |
8681c6 |
return CKR_ATTRIBUTE_READ_ONLY;
|
|
Packit |
8681c6 |
default:
|
|
Packit |
8681c6 |
return hwf_validate_attribute(tmpl, attr, mode);
|
|
Packit |
8681c6 |
}
|
|
Packit |
8681c6 |
}
|
|
Packit |
8681c6 |
|
|
Packit |
8681c6 |
|
|
Packit |
8681c6 |
CK_RV clock_set_default_attributes(TEMPLATE *tmpl, CK_ULONG mode)
|
|
Packit |
8681c6 |
{
|
|
Packit |
8681c6 |
CK_RV rc;
|
|
Packit |
8681c6 |
CK_ATTRIBUTE *value_attr;
|
|
Packit |
8681c6 |
|
|
Packit |
8681c6 |
rc = hwf_object_set_default_attributes(tmpl, mode);
|
|
Packit |
8681c6 |
if (rc != CKR_OK)
|
|
Packit |
8681c6 |
return rc;
|
|
Packit |
8681c6 |
|
|
Packit |
8681c6 |
value_attr = (CK_ATTRIBUTE *) malloc(sizeof(CK_ATTRIBUTE));
|
|
Packit |
8681c6 |
|
|
Packit |
8681c6 |
if (!value_attr) {
|
|
Packit |
8681c6 |
TRACE_ERROR("%s\n", ock_err(ERR_HOST_MEMORY));
|
|
Packit |
8681c6 |
return CKR_HOST_MEMORY;
|
|
Packit |
8681c6 |
}
|
|
Packit |
8681c6 |
|
|
Packit |
8681c6 |
value_attr->type = CKA_VALUE;
|
|
Packit |
8681c6 |
value_attr->ulValueLen = 0;
|
|
Packit |
8681c6 |
value_attr->pValue = NULL;
|
|
Packit |
8681c6 |
|
|
Packit |
8681c6 |
template_update_attribute(tmpl, value_attr);
|
|
Packit |
8681c6 |
|
|
Packit |
8681c6 |
return CKR_OK;
|
|
Packit |
8681c6 |
}
|
|
Packit |
8681c6 |
|
|
Packit |
8681c6 |
CK_RV counter_set_default_attributes(TEMPLATE *tmpl, CK_ULONG mode)
|
|
Packit |
8681c6 |
{
|
|
Packit |
8681c6 |
CK_RV rc;
|
|
Packit |
8681c6 |
CK_ATTRIBUTE *value_attr;
|
|
Packit |
8681c6 |
CK_ATTRIBUTE *hasreset_attr;
|
|
Packit |
8681c6 |
CK_ATTRIBUTE *resetoninit_attr;
|
|
Packit |
8681c6 |
|
|
Packit |
8681c6 |
rc = hwf_object_set_default_attributes(tmpl, mode);
|
|
Packit |
8681c6 |
if (rc != CKR_OK)
|
|
Packit |
8681c6 |
return rc;
|
|
Packit |
8681c6 |
|
|
Packit |
8681c6 |
value_attr = (CK_ATTRIBUTE *) malloc(sizeof(CK_ATTRIBUTE));
|
|
Packit |
8681c6 |
hasreset_attr =
|
|
Packit |
8681c6 |
(CK_ATTRIBUTE *) malloc(sizeof(CK_ATTRIBUTE) + sizeof(CK_BBOOL));
|
|
Packit |
8681c6 |
resetoninit_attr =
|
|
Packit |
8681c6 |
(CK_ATTRIBUTE *) malloc(sizeof(CK_ATTRIBUTE) + sizeof(CK_BBOOL));
|
|
Packit |
8681c6 |
|
|
Packit |
8681c6 |
if (!value_attr || !hasreset_attr || !resetoninit_attr) {
|
|
Packit |
8681c6 |
if (value_attr)
|
|
Packit |
8681c6 |
free(value_attr);
|
|
Packit |
8681c6 |
if (hasreset_attr)
|
|
Packit |
8681c6 |
free(hasreset_attr);
|
|
Packit |
8681c6 |
if (resetoninit_attr)
|
|
Packit |
8681c6 |
free(resetoninit_attr);
|
|
Packit |
8681c6 |
TRACE_ERROR("%s\n", ock_err(ERR_HOST_MEMORY));
|
|
Packit |
8681c6 |
return CKR_HOST_MEMORY;
|
|
Packit |
8681c6 |
}
|
|
Packit |
8681c6 |
|
|
Packit |
8681c6 |
value_attr->type = CKA_VALUE;
|
|
Packit |
8681c6 |
value_attr->ulValueLen = 0;
|
|
Packit |
8681c6 |
value_attr->pValue = NULL;
|
|
Packit |
8681c6 |
|
|
Packit |
8681c6 |
hasreset_attr->type = CKA_HAS_RESET;
|
|
Packit |
8681c6 |
hasreset_attr->ulValueLen = sizeof(CK_BBOOL);
|
|
Packit |
8681c6 |
hasreset_attr->pValue = (CK_BYTE *) hasreset_attr + sizeof(CK_ATTRIBUTE);
|
|
Packit |
8681c6 |
*(CK_BBOOL *) hasreset_attr->pValue = FALSE;
|
|
Packit |
8681c6 |
|
|
Packit |
8681c6 |
/* Hmm... Not sure if we should be setting this here. */
|
|
Packit |
8681c6 |
resetoninit_attr->type = CKA_RESET_ON_INIT;
|
|
Packit |
8681c6 |
resetoninit_attr->ulValueLen = sizeof(CK_BBOOL);
|
|
Packit |
8681c6 |
resetoninit_attr->pValue =
|
|
Packit |
8681c6 |
(CK_BYTE *) resetoninit_attr + sizeof(CK_ATTRIBUTE);
|
|
Packit |
8681c6 |
*(CK_BBOOL *) resetoninit_attr->pValue = FALSE;
|
|
Packit |
8681c6 |
|
|
Packit |
8681c6 |
template_update_attribute(tmpl, value_attr);
|
|
Packit |
8681c6 |
template_update_attribute(tmpl, hasreset_attr);
|
|
Packit |
8681c6 |
template_update_attribute(tmpl, resetoninit_attr);
|
|
Packit |
8681c6 |
|
|
Packit |
8681c6 |
return CKR_OK;
|
|
Packit |
8681c6 |
}
|