avr32: use dlmalloc for DMA buffers
Signed-off-by: Andreas Bießmann <andreas.devel@googlemail.com>
This commit is contained in:
parent
5745f8c4fd
commit
dbdb5abd07
|
|
@ -14,7 +14,12 @@ enum dma_data_direction {
|
||||||
DMA_TO_DEVICE = 1,
|
DMA_TO_DEVICE = 1,
|
||||||
DMA_FROM_DEVICE = 2,
|
DMA_FROM_DEVICE = 2,
|
||||||
};
|
};
|
||||||
extern void *dma_alloc_coherent(size_t len, unsigned long *handle);
|
|
||||||
|
static inline void *dma_alloc_coherent(size_t len, unsigned long *handle)
|
||||||
|
{
|
||||||
|
*handle = (unsigned long)memalign(ARCH_DMA_MINALIGN, len);
|
||||||
|
return (void *)*handle;
|
||||||
|
}
|
||||||
|
|
||||||
static inline unsigned long dma_map_single(volatile void *vaddr, size_t len,
|
static inline unsigned long dma_map_single(volatile void *vaddr, size_t len,
|
||||||
enum dma_data_direction dir)
|
enum dma_data_direction dir)
|
||||||
|
|
|
||||||
|
|
@ -45,50 +45,6 @@ int cpu_mmc_init(bd_t *bd)
|
||||||
return atmel_mci_init((void *)ATMEL_BASE_MMCI);
|
return atmel_mci_init((void *)ATMEL_BASE_MMCI);
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef CONFIG_SYS_DMA_ALLOC_LEN
|
|
||||||
#include <asm/arch/cacheflush.h>
|
|
||||||
#include <asm/io.h>
|
|
||||||
|
|
||||||
static unsigned long dma_alloc_start;
|
|
||||||
static unsigned long dma_alloc_end;
|
|
||||||
static unsigned long dma_alloc_brk;
|
|
||||||
|
|
||||||
static void dma_alloc_init(void)
|
|
||||||
{
|
|
||||||
unsigned long monitor_addr;
|
|
||||||
|
|
||||||
monitor_addr = CONFIG_SYS_MONITOR_BASE + gd->reloc_off;
|
|
||||||
dma_alloc_end = monitor_addr - CONFIG_SYS_MALLOC_LEN;
|
|
||||||
dma_alloc_start = dma_alloc_end - CONFIG_SYS_DMA_ALLOC_LEN;
|
|
||||||
dma_alloc_brk = dma_alloc_start;
|
|
||||||
|
|
||||||
printf("DMA: Using memory from 0x%08lx to 0x%08lx\n",
|
|
||||||
dma_alloc_start, dma_alloc_end);
|
|
||||||
|
|
||||||
invalidate_dcache_range((unsigned long)cached(dma_alloc_start),
|
|
||||||
dma_alloc_end);
|
|
||||||
}
|
|
||||||
|
|
||||||
void *dma_alloc_coherent(size_t len, unsigned long *handle)
|
|
||||||
{
|
|
||||||
unsigned long paddr = dma_alloc_brk;
|
|
||||||
|
|
||||||
if (dma_alloc_brk + len > dma_alloc_end)
|
|
||||||
return NULL;
|
|
||||||
|
|
||||||
dma_alloc_brk = ((paddr + len + CONFIG_SYS_DCACHE_LINESZ - 1)
|
|
||||||
& ~(CONFIG_SYS_DCACHE_LINESZ - 1));
|
|
||||||
|
|
||||||
*handle = paddr;
|
|
||||||
return uncached(paddr);
|
|
||||||
}
|
|
||||||
#else
|
|
||||||
static inline void dma_alloc_init(void)
|
|
||||||
{
|
|
||||||
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
static int init_baudrate(void)
|
static int init_baudrate(void)
|
||||||
{
|
{
|
||||||
gd->baudrate = getenv_ulong("baudrate", 10, CONFIG_BAUDRATE);
|
gd->baudrate = getenv_ulong("baudrate", 10, CONFIG_BAUDRATE);
|
||||||
|
|
@ -180,12 +136,6 @@ void board_init_f(ulong board_type)
|
||||||
/* Reserve memory for malloc() */
|
/* Reserve memory for malloc() */
|
||||||
addr -= CONFIG_SYS_MALLOC_LEN;
|
addr -= CONFIG_SYS_MALLOC_LEN;
|
||||||
|
|
||||||
#ifdef CONFIG_SYS_DMA_ALLOC_LEN
|
|
||||||
/* Reserve DMA memory (must be cache aligned) */
|
|
||||||
addr &= ~(CONFIG_SYS_DCACHE_LINESZ - 1);
|
|
||||||
addr -= CONFIG_SYS_DMA_ALLOC_LEN;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifdef CONFIG_LCD
|
#ifdef CONFIG_LCD
|
||||||
#ifdef CONFIG_FB_ADDR
|
#ifdef CONFIG_FB_ADDR
|
||||||
printf("LCD: Frame buffer allocated at preset 0x%08x\n",
|
printf("LCD: Frame buffer allocated at preset 0x%08x\n",
|
||||||
|
|
@ -264,7 +214,6 @@ void board_init_r(gd_t *new_gd, ulong dest_addr)
|
||||||
/* The malloc area is right below the monitor image in RAM */
|
/* The malloc area is right below the monitor image in RAM */
|
||||||
mem_malloc_init(CONFIG_SYS_MONITOR_BASE + gd->reloc_off -
|
mem_malloc_init(CONFIG_SYS_MONITOR_BASE + gd->reloc_off -
|
||||||
CONFIG_SYS_MALLOC_LEN, CONFIG_SYS_MALLOC_LEN);
|
CONFIG_SYS_MALLOC_LEN, CONFIG_SYS_MALLOC_LEN);
|
||||||
dma_alloc_init();
|
|
||||||
|
|
||||||
enable_interrupts();
|
enable_interrupts();
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -143,7 +143,6 @@
|
||||||
#define CONFIG_SYS_INIT_SP_ADDR (CONFIG_SYS_INTRAM_BASE + CONFIG_SYS_INTRAM_SIZE)
|
#define CONFIG_SYS_INIT_SP_ADDR (CONFIG_SYS_INTRAM_BASE + CONFIG_SYS_INTRAM_SIZE)
|
||||||
|
|
||||||
#define CONFIG_SYS_MALLOC_LEN (256*1024)
|
#define CONFIG_SYS_MALLOC_LEN (256*1024)
|
||||||
#define CONFIG_SYS_DMA_ALLOC_LEN (16384)
|
|
||||||
|
|
||||||
/* Allow 4MB for the kernel run-time image */
|
/* Allow 4MB for the kernel run-time image */
|
||||||
#define CONFIG_SYS_LOAD_ADDR (EBI_SDRAM_BASE + 0x00400000)
|
#define CONFIG_SYS_LOAD_ADDR (EBI_SDRAM_BASE + 0x00400000)
|
||||||
|
|
|
||||||
|
|
@ -164,7 +164,6 @@
|
||||||
#define CONFIG_SYS_INIT_SP_ADDR (CONFIG_SYS_INTRAM_BASE + CONFIG_SYS_INTRAM_SIZE)
|
#define CONFIG_SYS_INIT_SP_ADDR (CONFIG_SYS_INTRAM_BASE + CONFIG_SYS_INTRAM_SIZE)
|
||||||
|
|
||||||
#define CONFIG_SYS_MALLOC_LEN (256*1024)
|
#define CONFIG_SYS_MALLOC_LEN (256*1024)
|
||||||
#define CONFIG_SYS_DMA_ALLOC_LEN (16384)
|
|
||||||
|
|
||||||
/* Allow 4MB for the kernel run-time image */
|
/* Allow 4MB for the kernel run-time image */
|
||||||
#define CONFIG_SYS_LOAD_ADDR (EBI_SDRAM_BASE + 0x00400000)
|
#define CONFIG_SYS_LOAD_ADDR (EBI_SDRAM_BASE + 0x00400000)
|
||||||
|
|
|
||||||
|
|
@ -158,7 +158,6 @@
|
||||||
#define CONFIG_SYS_INIT_SP_ADDR (CONFIG_SYS_INTRAM_BASE + CONFIG_SYS_INTRAM_SIZE)
|
#define CONFIG_SYS_INIT_SP_ADDR (CONFIG_SYS_INTRAM_BASE + CONFIG_SYS_INTRAM_SIZE)
|
||||||
|
|
||||||
#define CONFIG_SYS_MALLOC_LEN (256*1024)
|
#define CONFIG_SYS_MALLOC_LEN (256*1024)
|
||||||
#define CONFIG_SYS_DMA_ALLOC_LEN (16384)
|
|
||||||
|
|
||||||
/* Allow 4MB for the kernel run-time image */
|
/* Allow 4MB for the kernel run-time image */
|
||||||
#define CONFIG_SYS_LOAD_ADDR (EBI_SDRAM_BASE + 0x00400000)
|
#define CONFIG_SYS_LOAD_ADDR (EBI_SDRAM_BASE + 0x00400000)
|
||||||
|
|
|
||||||
|
|
@ -159,7 +159,6 @@
|
||||||
#define CONFIG_SYS_INIT_SP_ADDR (CONFIG_SYS_INTRAM_BASE + CONFIG_SYS_INTRAM_SIZE)
|
#define CONFIG_SYS_INIT_SP_ADDR (CONFIG_SYS_INTRAM_BASE + CONFIG_SYS_INTRAM_SIZE)
|
||||||
|
|
||||||
#define CONFIG_SYS_MALLOC_LEN (256*1024)
|
#define CONFIG_SYS_MALLOC_LEN (256*1024)
|
||||||
#define CONFIG_SYS_DMA_ALLOC_LEN (16384)
|
|
||||||
|
|
||||||
/* Allow 4MB for the kernel run-time image */
|
/* Allow 4MB for the kernel run-time image */
|
||||||
#define CONFIG_SYS_LOAD_ADDR (EBI_SDRAM_BASE + 0x00400000)
|
#define CONFIG_SYS_LOAD_ADDR (EBI_SDRAM_BASE + 0x00400000)
|
||||||
|
|
|
||||||
|
|
@ -162,7 +162,6 @@
|
||||||
#define CONFIG_SYS_INIT_SP_ADDR (CONFIG_SYS_INTRAM_BASE + CONFIG_SYS_INTRAM_SIZE)
|
#define CONFIG_SYS_INIT_SP_ADDR (CONFIG_SYS_INTRAM_BASE + CONFIG_SYS_INTRAM_SIZE)
|
||||||
|
|
||||||
#define CONFIG_SYS_MALLOC_LEN (256*1024)
|
#define CONFIG_SYS_MALLOC_LEN (256*1024)
|
||||||
#define CONFIG_SYS_DMA_ALLOC_LEN (16384)
|
|
||||||
|
|
||||||
/* Allow 4MB for the kernel run-time image */
|
/* Allow 4MB for the kernel run-time image */
|
||||||
#define CONFIG_SYS_LOAD_ADDR (EBI_SDRAM_BASE + 0x00400000)
|
#define CONFIG_SYS_LOAD_ADDR (EBI_SDRAM_BASE + 0x00400000)
|
||||||
|
|
|
||||||
|
|
@ -151,7 +151,6 @@
|
||||||
CONFIG_SYS_INTRAM_SIZE)
|
CONFIG_SYS_INTRAM_SIZE)
|
||||||
|
|
||||||
#define CONFIG_SYS_MALLOC_LEN (256*1024)
|
#define CONFIG_SYS_MALLOC_LEN (256*1024)
|
||||||
#define CONFIG_SYS_DMA_ALLOC_LEN (16384)
|
|
||||||
|
|
||||||
/* Allow 4MB for the kernel run-time image */
|
/* Allow 4MB for the kernel run-time image */
|
||||||
#define CONFIG_SYS_LOAD_ADDR (EBI_SDRAM_BASE + 0x00400000)
|
#define CONFIG_SYS_LOAD_ADDR (EBI_SDRAM_BASE + 0x00400000)
|
||||||
|
|
|
||||||
|
|
@ -137,7 +137,6 @@
|
||||||
|
|
||||||
#define CONFIG_SYS_MALLOC_LEN (256*1024)
|
#define CONFIG_SYS_MALLOC_LEN (256*1024)
|
||||||
|
|
||||||
#define CONFIG_SYS_DMA_ALLOC_LEN (16384)
|
|
||||||
|
|
||||||
/* Allow 4MB for the kernel run-time image */
|
/* Allow 4MB for the kernel run-time image */
|
||||||
#define CONFIG_SYS_LOAD_ADDR (CONFIG_SYS_SDRAM_BASE + 0x00400000)
|
#define CONFIG_SYS_LOAD_ADDR (CONFIG_SYS_SDRAM_BASE + 0x00400000)
|
||||||
|
|
|
||||||
|
|
@ -157,7 +157,6 @@
|
||||||
#define CONFIG_SYS_INIT_SP_ADDR (CONFIG_SYS_INTRAM_BASE + CONFIG_SYS_INTRAM_SIZE)
|
#define CONFIG_SYS_INIT_SP_ADDR (CONFIG_SYS_INTRAM_BASE + CONFIG_SYS_INTRAM_SIZE)
|
||||||
|
|
||||||
#define CONFIG_SYS_MALLOC_LEN (1024*1024)
|
#define CONFIG_SYS_MALLOC_LEN (1024*1024)
|
||||||
#define CONFIG_SYS_DMA_ALLOC_LEN (16384)
|
|
||||||
|
|
||||||
/* Allow 4MB for the kernel run-time image */
|
/* Allow 4MB for the kernel run-time image */
|
||||||
#define CONFIG_SYS_LOAD_ADDR (EBI_SDRAM_BASE + 0x00400000)
|
#define CONFIG_SYS_LOAD_ADDR (EBI_SDRAM_BASE + 0x00400000)
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue