summaryrefslogtreecommitdiff
path: root/arch/sparc/crypto/crop_devid.c
diff options
context:
space:
mode:
authorDavid S. Miller <davem@davemloft.net>2012-09-15 09:46:25 -0700
committerDavid S. Miller <davem@davemloft.net>2012-09-15 09:46:25 -0700
commit979e93ca24e8336acb660529676dcda6817d8a1f (patch)
tree40f854f3b7b0e3e333738cf699d0acfcbfef85bf /arch/sparc/crypto/crop_devid.c
parent71741680a9858a7fcba54acf5b321d185abef1e8 (diff)
downloadlwn-979e93ca24e8336acb660529676dcda6817d8a1f.tar.gz
lwn-979e93ca24e8336acb660529676dcda6817d8a1f.zip
sparc64: Add auto-loading mechanism to crypto-opcode drivers.
Just simply provide a device table containing an entry for sun4v cpus, the capability mask checks in the drivers themselves will take care of the rest. This makes the bootup logs on pre-T4 cpus slightly more verbose, with each driver indicating lack of support for the associated opcode(s). But this isn't too much of a real problem. I toyed with the idea of using explicit entries with compatability fields of "SPARC-T4", "SPARC-T5", etc. but all future cpus will have some subset of these opcodes available and this would just be one more pointless thing to do as each new cpu is released with a new string. Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'arch/sparc/crypto/crop_devid.c')
-rw-r--r--arch/sparc/crypto/crop_devid.c14
1 files changed, 14 insertions, 0 deletions
diff --git a/arch/sparc/crypto/crop_devid.c b/arch/sparc/crypto/crop_devid.c
new file mode 100644
index 000000000000..5f5724a0ae22
--- /dev/null
+++ b/arch/sparc/crypto/crop_devid.c
@@ -0,0 +1,14 @@
+#include <linux/module.h>
+#include <linux/of_device.h>
+
+/* This is a dummy device table linked into all of the crypto
+ * opcode drivers. It serves to trigger the module autoloading
+ * mechanisms in userspace which scan the OF device tree and
+ * load any modules which have device table entries that
+ * match OF device nodes.
+ */
+static const struct of_device_id crypto_opcode_match[] = {
+ { .name = "cpu", .compatible = "sun4v", },
+ {},
+};
+MODULE_DEVICE_TABLE(of, crypto_opcode_match);