drivers: crypto: rsa_mod_exp: Add manual relocation for ops->mod_exp()
authorT Karthik Reddy <t.karthik.reddy@xilinx.com>
Sat, 16 Mar 2019 09:53:02 +0000 (15:23 +0530)
committerMichal Simek <michal.simek@xilinx.com>
Thu, 24 Oct 2019 11:37:02 +0000 (13:37 +0200)
This patch adds manual relocation for Modular Exponentiation if
CONFIG_NEEDS_MANUAL_RELOC is enabled.

Signed-off-by: T Karthik Reddy <t.karthik.reddy@xilinx.com>
Signed-off-by: Siva Durga Prasad Paladugu <siva.durga.paladugu@xilinx.com>
Signed-off-by: Michal Simek <michal.simek@xilinx.com>
drivers/crypto/rsa_mod_exp/mod_exp_uclass.c

index 93deaa7f51e6e2b7528f027c0be28bc737e0b88e..e91fe644580b8b778aa88c7b18dff18ba76f42cb 100644 (file)
 #include <asm/io.h>
 #include <linux/list.h>
 
 #include <asm/io.h>
 #include <linux/list.h>
 
+#if !defined(USE_HOSTCC) && defined(CONFIG_NEEDS_MANUAL_RELOC)
+DECLARE_GLOBAL_DATA_PTR;
+#endif
+
 int rsa_mod_exp(struct udevice *dev, const uint8_t *sig, uint32_t sig_len,
                struct key_prop *node, uint8_t *out)
 {
 int rsa_mod_exp(struct udevice *dev, const uint8_t *sig, uint32_t sig_len,
                struct key_prop *node, uint8_t *out)
 {
-       const struct mod_exp_ops *ops = device_get_ops(dev);
+       struct mod_exp_ops *ops = (struct mod_exp_ops *)device_get_ops(dev);
+
+#if !defined(USE_HOSTCC) && defined(CONFIG_NEEDS_MANUAL_RELOC)
+       static bool done;
+
+       if (!done) {
+               done = true;
+               ops->mod_exp += gd->reloc_off;
+       }
+#endif
 
        if (!ops->mod_exp)
                return -ENOSYS;
 
        if (!ops->mod_exp)
                return -ENOSYS;