powerpc: remove support for bootmem-allocated memory for the DIU driver
Early versions of the Freescale DIU framebuffer driver depended on a bootmem
allocation of memory for the video buffer. The need for this feature was
removed in commit 6b51d51a
, so now we can remove the platform-specific code
that allocated that memory.
Signed-off-by: Timur Tabi <timur@freescale.com>
Signed-off-by: Kumar Gala <galak@kernel.crashing.org>
This commit is contained in:
Родитель
9bd54d185a
Коммит
43c9f43492
|
@ -238,7 +238,6 @@ static void __init mpc86xx_hpcd_setup_arch(void)
|
|||
}
|
||||
#endif
|
||||
#if defined(CONFIG_FB_FSL_DIU) || defined(CONFIG_FB_FSL_DIU_MODULE)
|
||||
preallocate_diu_videomemory();
|
||||
diu_ops.get_pixel_format = mpc8610hpcd_get_pixel_format;
|
||||
diu_ops.set_gamma_table = mpc8610hpcd_set_gamma_table;
|
||||
diu_ops.set_monitor_port = mpc8610hpcd_set_monitor_port;
|
||||
|
|
|
@ -720,42 +720,6 @@ void fsl_rstcr_restart(char *cmd)
|
|||
#endif
|
||||
|
||||
#if defined(CONFIG_FB_FSL_DIU) || defined(CONFIG_FB_FSL_DIU_MODULE)
|
||||
struct platform_diu_data_ops diu_ops = {
|
||||
.diu_size = 1280 * 1024 * 4, /* default one 1280x1024 buffer */
|
||||
};
|
||||
struct platform_diu_data_ops diu_ops;
|
||||
EXPORT_SYMBOL(diu_ops);
|
||||
|
||||
int __init preallocate_diu_videomemory(void)
|
||||
{
|
||||
pr_debug("diu_size=%lu\n", diu_ops.diu_size);
|
||||
|
||||
diu_ops.diu_mem = __alloc_bootmem(diu_ops.diu_size, 8, 0);
|
||||
if (!diu_ops.diu_mem) {
|
||||
printk(KERN_ERR "fsl-diu: cannot allocate %lu bytes\n",
|
||||
diu_ops.diu_size);
|
||||
return -ENOMEM;
|
||||
}
|
||||
|
||||
pr_debug("diu_mem=%p\n", diu_ops.diu_mem);
|
||||
|
||||
rh_init(&diu_ops.diu_rh_info, 4096, ARRAY_SIZE(diu_ops.diu_rh_block),
|
||||
diu_ops.diu_rh_block);
|
||||
return rh_attach_region(&diu_ops.diu_rh_info,
|
||||
(unsigned long) diu_ops.diu_mem,
|
||||
diu_ops.diu_size);
|
||||
}
|
||||
|
||||
static int __init early_parse_diufb(char *p)
|
||||
{
|
||||
if (!p)
|
||||
return 1;
|
||||
|
||||
diu_ops.diu_size = _ALIGN_UP(memparse(p, &p), 8);
|
||||
|
||||
pr_debug("diu_size=%lu\n", diu_ops.diu_size);
|
||||
|
||||
return 0;
|
||||
}
|
||||
early_param("diufb", early_parse_diufb);
|
||||
|
||||
#endif
|
||||
|
|
|
@ -20,14 +20,7 @@ extern int fsl_spi_init(struct spi_board_info *board_infos,
|
|||
extern void fsl_rstcr_restart(char *cmd);
|
||||
|
||||
#if defined(CONFIG_FB_FSL_DIU) || defined(CONFIG_FB_FSL_DIU_MODULE)
|
||||
#include <linux/bootmem.h>
|
||||
#include <asm/rheap.h>
|
||||
struct platform_diu_data_ops {
|
||||
rh_block_t diu_rh_block[16];
|
||||
rh_info_t diu_rh_info;
|
||||
unsigned long diu_size;
|
||||
void *diu_mem;
|
||||
|
||||
unsigned int (*get_pixel_format) (unsigned int bits_per_pixel,
|
||||
int monitor_port);
|
||||
void (*set_gamma_table) (int monitor_port, char *gamma_table_base);
|
||||
|
@ -38,7 +31,6 @@ struct platform_diu_data_ops {
|
|||
};
|
||||
|
||||
extern struct platform_diu_data_ops diu_ops;
|
||||
int __init preallocate_diu_videomemory(void);
|
||||
#endif
|
||||
|
||||
#endif
|
||||
|
|
Загрузка…
Ссылка в новой задаче