aboutsummaryrefslogtreecommitdiff
path: root/drivers/block
diff options
context:
space:
mode:
authorOvidiu Panait <ovidiu.panait@windriver.com>2020-07-24 14:12:24 +0300
committerTom Rini <trini@konsulko.com>2020-08-06 18:08:22 -0400
commit365af27f0dec5013c9749ee397e9274ff32e06c4 (patch)
treef30390f63ca36da46132ecdb7eff5fc64b25d0bc /drivers/block
parentbf2fb81ad363e63b4695104a2cf554de9e4f141a (diff)
downloadu-boot-365af27f0dec5013c9749ee397e9274ff32e06c4.zip
u-boot-365af27f0dec5013c9749ee397e9274ff32e06c4.tar.gz
u-boot-365af27f0dec5013c9749ee397e9274ff32e06c4.tar.bz2
blkcache: Extend blkcache_init to cover CONFIG_NEEDS_MANUAL_RELOC
Extend manual relocation of block_cache list pointers to all platforms that enable CONFIG_NEEDS_MANUAL_RELOC. Remove m68k-specific checks and provide a single implementation that adds gd->reloc_off to the pre-relocation pointers. Acked-by: Angelo Dureghello <angelo.dureghello@timesys.com> Tested-by: Angelo Dureghello <angelo.dureghello@timesys.com> Reviewed-by: Simon Glass <sjg@chromium.org> Reviewed-by: Eric Nelson <eric@nelint.com> Signed-off-by: Ovidiu Panait <ovidiu.panait@windriver.com> [trini: Add guard around DECLARE_GLOBAL_DATA_PTR to avoid size growth] Signed-off-by: Tom Rini <trini@konsulko.com>
Diffstat (limited to 'drivers/block')
-rw-r--r--drivers/block/blkcache.c15
1 files changed, 9 insertions, 6 deletions
diff --git a/drivers/block/blkcache.c b/drivers/block/blkcache.c
index b6fc72f..eca6619 100644
--- a/drivers/block/blkcache.c
+++ b/drivers/block/blkcache.c
@@ -12,6 +12,10 @@
#include <linux/ctype.h>
#include <linux/list.h>
+#ifdef CONFIG_NEEDS_MANUAL_RELOC
+DECLARE_GLOBAL_DATA_PTR;
+#endif
+
struct block_cache_node {
struct list_head lh;
int iftype;
@@ -22,21 +26,20 @@ struct block_cache_node {
char *cache;
};
-#ifndef CONFIG_M68K
static LIST_HEAD(block_cache);
-#else
-static struct list_head block_cache;
-#endif
static struct block_cache_stats _stats = {
.max_blocks_per_entry = 8,
.max_entries = 32
};
-#ifdef CONFIG_M68K
+#ifdef CONFIG_NEEDS_MANUAL_RELOC
int blkcache_init(void)
{
- INIT_LIST_HEAD(&block_cache);
+ struct list_head *head = &block_cache;
+
+ head->next = (uintptr_t)head->next + gd->reloc_off;
+ head->prev = (uintptr_t)head->prev + gd->reloc_off;
return 0;
}