diff options
author | Neil Horman <nhorman@tuxdriver.com> | 2008-08-05 02:13:08 -0400 |
---|---|---|
committer | Herbert Xu <herbert@gondor.apana.org.au> | 2008-08-29 01:50:02 -0400 |
commit | ccb778e1841ce04b4c10b39f0dd2558ab2c6dcd4 (patch) | |
tree | d15c704e38e731391fdb8bf8db1922aff893acd7 /crypto/proc.c | |
parent | 5be5e667a9a5d8d5553e009e67bc692d95e5916a (diff) |
crypto: api - Add fips_enable flag
Add the ability to turn FIPS-compliant mode on or off at boot
In order to be FIPS compliant, several check may need to be preformed that may
be construed as unusefull in a non-compliant mode. This patch allows us to set
a kernel flag incating that we are running in a fips-compliant mode from boot
up. It also exports that mode information to user space via a sysctl
(/proc/sys/crypto/fips_enabled).
Tested successfully by me.
Signed-off-by: Neil Horman <nhorman@tuxdriver.com>
Signed-off-by: Herbert Xu <herbert@gondor.apana.org.au>
Diffstat (limited to 'crypto/proc.c')
-rw-r--r-- | crypto/proc.c | 47 |
1 files changed, 47 insertions, 0 deletions
diff --git a/crypto/proc.c b/crypto/proc.c index 1d616adead0d..37a13d05636d 100644 --- a/crypto/proc.c +++ b/crypto/proc.c | |||
@@ -19,8 +19,53 @@ | |||
19 | #include <linux/rwsem.h> | 19 | #include <linux/rwsem.h> |
20 | #include <linux/proc_fs.h> | 20 | #include <linux/proc_fs.h> |
21 | #include <linux/seq_file.h> | 21 | #include <linux/seq_file.h> |
22 | #include <linux/sysctl.h> | ||
22 | #include "internal.h" | 23 | #include "internal.h" |
23 | 24 | ||
25 | #ifdef CONFIG_CRYPTO_FIPS | ||
26 | static struct ctl_table crypto_sysctl_table[] = { | ||
27 | { | ||
28 | .ctl_name = CTL_UNNUMBERED, | ||
29 | .procname = "fips_enabled", | ||
30 | .data = &fips_enabled, | ||
31 | .maxlen = sizeof(int), | ||
32 | .mode = 0444, | ||
33 | .proc_handler = &proc_dointvec | ||
34 | }, | ||
35 | { | ||
36 | .ctl_name = 0, | ||
37 | }, | ||
38 | }; | ||
39 | |||
40 | static struct ctl_table crypto_dir_table[] = { | ||
41 | { | ||
42 | .ctl_name = CTL_UNNUMBERED, | ||
43 | .procname = "crypto", | ||
44 | .mode = 0555, | ||
45 | .child = crypto_sysctl_table | ||
46 | }, | ||
47 | { | ||
48 | .ctl_name = 0, | ||
49 | }, | ||
50 | }; | ||
51 | |||
52 | static struct ctl_table_header *crypto_sysctls; | ||
53 | |||
54 | static void crypto_proc_fips_init(void) | ||
55 | { | ||
56 | crypto_sysctls = register_sysctl_table(crypto_dir_table); | ||
57 | } | ||
58 | |||
59 | static void crypto_proc_fips_exit(void) | ||
60 | { | ||
61 | if (crypto_sysctls) | ||
62 | unregister_sysctl_table(crypto_sysctls); | ||
63 | } | ||
64 | #else | ||
65 | #define crypto_proc_fips_init() | ||
66 | #define crypto_proc_fips_exit() | ||
67 | #endif | ||
68 | |||
24 | static void *c_start(struct seq_file *m, loff_t *pos) | 69 | static void *c_start(struct seq_file *m, loff_t *pos) |
25 | { | 70 | { |
26 | down_read(&crypto_alg_sem); | 71 | down_read(&crypto_alg_sem); |
@@ -106,9 +151,11 @@ static const struct file_operations proc_crypto_ops = { | |||
106 | void __init crypto_init_proc(void) | 151 | void __init crypto_init_proc(void) |
107 | { | 152 | { |
108 | proc_create("crypto", 0, NULL, &proc_crypto_ops); | 153 | proc_create("crypto", 0, NULL, &proc_crypto_ops); |
154 | crypto_proc_fips_init(); | ||
109 | } | 155 | } |
110 | 156 | ||
111 | void __exit crypto_exit_proc(void) | 157 | void __exit crypto_exit_proc(void) |
112 | { | 158 | { |
159 | crypto_proc_fips_exit(); | ||
113 | remove_proc_entry("crypto", NULL); | 160 | remove_proc_entry("crypto", NULL); |
114 | } | 161 | } |