4
* Copyright (C) 2010 Stefan Walter
6
* This program is free software; you can redistribute it and/or modify
7
* it under the terms of the GNU Lesser General Public License as
8
* published by the Free Software Foundation; either version 2.1 of
9
* the License, or (at your option) any later version.
11
* This program is distributed in the hope that it will be useful, but
12
* WITHOUT ANY WARRANTY; without even the implied warranty of
13
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14
* Lesser General Public License for more details.
16
* You should have received a copy of the GNU Lesser General Public
17
* License along with this program; if not, write to the Free Software
18
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
33
defined_rv_to_string (CK_RV rv)
35
#define GKM_X(rv) case rv: return #rv;
38
/* These are not really errors, or not current */
41
GKM_X (CKR_FUNCTION_NOT_PARALLEL)
42
GKM_X (CKR_SESSION_PARALLEL_NOT_SUPPORTED)
44
GKM_X (CKR_FUNCTION_CANCELED)
45
GKM_X (CKR_HOST_MEMORY)
46
GKM_X (CKR_SLOT_ID_INVALID)
47
GKM_X (CKR_GENERAL_ERROR)
48
GKM_X (CKR_FUNCTION_FAILED)
49
GKM_X (CKR_ARGUMENTS_BAD)
50
GKM_X (CKR_NEED_TO_CREATE_THREADS)
52
GKM_X (CKR_ATTRIBUTE_READ_ONLY)
53
GKM_X (CKR_ATTRIBUTE_SENSITIVE)
54
GKM_X (CKR_ATTRIBUTE_TYPE_INVALID)
55
GKM_X (CKR_ATTRIBUTE_VALUE_INVALID)
56
GKM_X (CKR_DATA_INVALID)
57
GKM_X (CKR_DATA_LEN_RANGE)
58
GKM_X (CKR_DEVICE_ERROR)
59
GKM_X (CKR_DEVICE_MEMORY)
60
GKM_X (CKR_DEVICE_REMOVED)
61
GKM_X (CKR_ENCRYPTED_DATA_INVALID)
62
GKM_X (CKR_ENCRYPTED_DATA_LEN_RANGE)
63
GKM_X (CKR_FUNCTION_NOT_SUPPORTED)
64
GKM_X (CKR_KEY_HANDLE_INVALID)
65
GKM_X (CKR_KEY_SIZE_RANGE)
66
GKM_X (CKR_KEY_TYPE_INCONSISTENT)
67
GKM_X (CKR_KEY_NOT_NEEDED)
68
GKM_X (CKR_KEY_CHANGED)
69
GKM_X (CKR_KEY_NEEDED)
70
GKM_X (CKR_KEY_INDIGESTIBLE)
71
GKM_X (CKR_KEY_FUNCTION_NOT_PERMITTED)
72
GKM_X (CKR_KEY_NOT_WRAPPABLE)
73
GKM_X (CKR_KEY_UNEXTRACTABLE)
74
GKM_X (CKR_MECHANISM_INVALID)
75
GKM_X (CKR_MECHANISM_PARAM_INVALID)
76
GKM_X (CKR_OBJECT_HANDLE_INVALID)
77
GKM_X (CKR_OPERATION_ACTIVE)
78
GKM_X (CKR_OPERATION_NOT_INITIALIZED)
79
GKM_X (CKR_PIN_INCORRECT)
80
GKM_X (CKR_PIN_INVALID)
81
GKM_X (CKR_PIN_LEN_RANGE)
82
GKM_X (CKR_PIN_EXPIRED)
83
GKM_X (CKR_PIN_LOCKED)
84
GKM_X (CKR_SESSION_CLOSED)
85
GKM_X (CKR_SESSION_COUNT)
86
GKM_X (CKR_SESSION_HANDLE_INVALID)
87
GKM_X (CKR_SESSION_READ_ONLY)
88
GKM_X (CKR_SESSION_EXISTS)
89
GKM_X (CKR_SESSION_READ_ONLY_EXISTS)
90
GKM_X (CKR_SESSION_READ_WRITE_SO_EXISTS)
91
GKM_X (CKR_SIGNATURE_INVALID)
92
GKM_X (CKR_SIGNATURE_LEN_RANGE)
93
GKM_X (CKR_TEMPLATE_INCOMPLETE)
94
GKM_X (CKR_TEMPLATE_INCONSISTENT)
95
GKM_X (CKR_TOKEN_NOT_PRESENT)
96
GKM_X (CKR_TOKEN_NOT_RECOGNIZED)
97
GKM_X (CKR_TOKEN_WRITE_PROTECTED)
98
GKM_X (CKR_UNWRAPPING_KEY_HANDLE_INVALID)
99
GKM_X (CKR_UNWRAPPING_KEY_SIZE_RANGE)
100
GKM_X (CKR_UNWRAPPING_KEY_TYPE_INCONSISTENT)
101
GKM_X (CKR_USER_ALREADY_LOGGED_IN)
102
GKM_X (CKR_USER_NOT_LOGGED_IN)
103
GKM_X (CKR_USER_PIN_NOT_INITIALIZED)
104
GKM_X (CKR_USER_TYPE_INVALID)
105
GKM_X (CKR_USER_ANOTHER_ALREADY_LOGGED_IN)
106
GKM_X (CKR_USER_TOO_MANY_TYPES)
107
GKM_X (CKR_WRAPPED_KEY_INVALID)
108
GKM_X (CKR_WRAPPED_KEY_LEN_RANGE)
109
GKM_X (CKR_WRAPPING_KEY_HANDLE_INVALID)
110
GKM_X (CKR_WRAPPING_KEY_SIZE_RANGE)
111
GKM_X (CKR_WRAPPING_KEY_TYPE_INCONSISTENT)
112
GKM_X (CKR_RANDOM_SEED_NOT_SUPPORTED)
113
GKM_X (CKR_RANDOM_NO_RNG)
114
GKM_X (CKR_DOMAIN_PARAMS_INVALID)
115
GKM_X (CKR_BUFFER_TOO_SMALL)
116
GKM_X (CKR_SAVED_STATE_INVALID)
117
GKM_X (CKR_INFORMATION_SENSITIVE)
118
GKM_X (CKR_STATE_UNSAVEABLE)
119
GKM_X (CKR_CRYPTOKI_NOT_INITIALIZED)
120
GKM_X (CKR_CRYPTOKI_ALREADY_INITIALIZED)
121
GKM_X (CKR_MUTEX_BAD)
122
GKM_X (CKR_MUTEX_NOT_LOCKED)
123
GKM_X (CKR_FUNCTION_REJECTED)
132
rv_to_string (CK_RV rv)
134
gchar *string = g_strdup (defined_rv_to_string (rv));
136
string = g_strdup_printf ("0x%08lx", (gulong)rv);
141
gck_assertion_message_cmprv (const gchar *domain, const gchar *file, gint line,
142
const gchar *func, const gchar *expr,
143
CK_RV arg1, const gchar *cmp, CK_RV arg2)
146
a1 = rv_to_string (arg1);
147
a2 = rv_to_string (arg2);
148
s = g_strdup_printf ("assertion failed (%s): (%s %s %s)", expr, a1, cmp, a2);
151
g_assertion_message (domain, file, line, func, s);
156
gck_assertion_message_cmpulong (const gchar *domain, const gchar *file, gint line,
157
const gchar *func, const gchar *expr,
158
CK_ULONG arg1, const gchar *cmp, CK_ULONG arg2)
161
s = g_strdup_printf ("assertion failed (%s): (0x%08llx %s 0x%08llx)", expr,
162
(long long unsigned)arg1, cmp, (long long unsigned)arg2);
163
g_assertion_message (domain, file, line, func, s);