#include <ipu.h>
#include <video_fb.h>
#include <mxcfb.h>
+
+#include "ipu_regs.h"
#include "videomodes.h"
DECLARE_GLOBAL_DATA_PTR;
return 0;
}
+void ipuv3_fb_shutdown(void)
+{
+ int i;
+ struct ipu_stat *stat = (struct ipu_stat *)IPU_STAT;
+
+ for (i = 0; i < ARRAY_SIZE(mxcfb_info); i++) {
+ struct fb_info *fbi = mxcfb_info[i];
+
+ if (fbi) {
+ struct mxcfb_info *mxc_fbi = fbi->par;
+
+ ipu_disable_channel(mxc_fbi->ipu_ch);
+ ipu_uninit_channel(mxc_fbi->ipu_ch);
+ }
+ }
+
+ clk_enable(g_ipu_clk);
+ for (i = 0; i < ARRAY_SIZE(stat->int_stat); i++) {
+ __raw_writel(__raw_readl(&stat->int_stat[i]),
+ &stat->int_stat[i]);
+ }
+ clk_disable(g_ipu_clk);
+}
+
/*
* Initializes the framebuffer information pointer. After allocating
* sufficient memory for the framebuffer structure, the fields are
unsigned int interface_pix_fmt,
ipu_di_clk_parent_t di_clk_parent,
unsigned long di_clk_val, int bpp);
+void ipuv3_fb_shutdown(void);
int32_t ipu_init_channel(ipu_channel_t channel, ipu_channel_params_t *params);
void ipu_uninit_channel(ipu_channel_t channel);