Lines Matching defs:solo_dev

29 static void solo_vin_config(struct solo_dev *solo_dev)
31 solo_dev->vin_hstart = 8;
32 solo_dev->vin_vstart = 2;
34 solo_reg_write(solo_dev, SOLO_SYS_VCLK,
45 solo_reg_write(solo_dev, SOLO_VI_ACT_I_P,
46 SOLO_VI_H_START(solo_dev->vin_hstart) |
47 SOLO_VI_V_START(solo_dev->vin_vstart) |
48 SOLO_VI_V_STOP(solo_dev->vin_vstart +
49 solo_dev->video_vsize));
51 solo_reg_write(solo_dev, SOLO_VI_ACT_I_S,
52 SOLO_VI_H_START(solo_dev->vout_hstart) |
53 SOLO_VI_V_START(solo_dev->vout_vstart) |
54 SOLO_VI_V_STOP(solo_dev->vout_vstart +
55 solo_dev->video_vsize));
57 solo_reg_write(solo_dev, SOLO_VI_ACT_P,
62 solo_reg_write(solo_dev, SOLO_VI_CH_FORMAT,
66 if (solo_dev->type == SOLO_DEV_6010)
67 solo_reg_write(solo_dev, SOLO_VI_FMT_CFG, 0);
69 solo_reg_write(solo_dev, SOLO_VI_FMT_CFG, 16 << 22);
71 solo_reg_write(solo_dev, SOLO_VI_PAGE_SW, 2);
73 if (solo_dev->video_type == SOLO_VO_FMT_TYPE_NTSC) {
74 solo_reg_write(solo_dev, SOLO_VI_PB_CONFIG,
76 solo_reg_write(solo_dev, SOLO_VI_PB_RANGE_HV,
78 solo_reg_write(solo_dev, SOLO_VI_PB_ACT_V,
82 solo_reg_write(solo_dev, SOLO_VI_PB_CONFIG,
84 solo_reg_write(solo_dev, SOLO_VI_PB_RANGE_HV,
86 solo_reg_write(solo_dev, SOLO_VI_PB_ACT_V,
90 solo_reg_write(solo_dev, SOLO_VI_PB_ACT_H, SOLO_VI_PB_HSTART(16) |
94 static void solo_vout_config_cursor(struct solo_dev *dev)
109 static void solo_vout_config(struct solo_dev *solo_dev)
111 solo_dev->vout_hstart = 6;
112 solo_dev->vout_vstart = 8;
114 solo_reg_write(solo_dev, SOLO_VO_FMT_ENC,
115 solo_dev->video_type |
122 solo_reg_write(solo_dev, SOLO_VO_ACT_H,
123 SOLO_VO_H_START(solo_dev->vout_hstart) |
124 SOLO_VO_H_STOP(solo_dev->vout_hstart +
125 solo_dev->video_hsize));
127 solo_reg_write(solo_dev, SOLO_VO_ACT_V,
128 SOLO_VO_V_START(solo_dev->vout_vstart) |
129 SOLO_VO_V_STOP(solo_dev->vout_vstart +
130 solo_dev->video_vsize));
132 solo_reg_write(solo_dev, SOLO_VO_RANGE_HV,
133 SOLO_VO_H_LEN(solo_dev->video_hsize) |
134 SOLO_VO_V_LEN(solo_dev->video_vsize));
137 solo_reg_write(solo_dev, SOLO_VO_BORDER_LINE_COLOR,
139 solo_reg_write(solo_dev, SOLO_VO_BORDER_FILL_COLOR,
141 solo_reg_write(solo_dev, SOLO_VO_BKG_COLOR,
144 solo_reg_write(solo_dev, SOLO_VO_DISP_ERASE, SOLO_VO_DISP_ERASE_ON);
146 solo_reg_write(solo_dev, SOLO_VI_WIN_SW, 0);
148 solo_reg_write(solo_dev, SOLO_VO_ZOOM_CTRL, 0);
149 solo_reg_write(solo_dev, SOLO_VO_FREEZE_CTRL, 0);
151 solo_reg_write(solo_dev, SOLO_VO_DISP_CTRL, SOLO_VO_DISP_ON |
156 solo_vout_config_cursor(solo_dev);
159 solo_reg_write(solo_dev, SOLO_VI_CH_ENA,
160 (1 << solo_dev->nr_chans) - 1);
163 static int solo_dma_vin_region(struct solo_dev *solo_dev, u32 off,
178 ret = solo_p2m_dma(solo_dev, 1, buf,
179 SOLO_MOTION_EXT_ADDR(solo_dev) + off + i,
190 int solo_set_motion_threshold(struct solo_dev *solo_dev, u8 ch, u16 val)
192 if (ch > solo_dev->nr_chans)
195 return solo_dma_vin_region(solo_dev, SOLO_MOT_FLAG_AREA +
200 int solo_set_motion_block(struct solo_dev *solo_dev, u8 ch,
215 ret |= solo_p2m_dma(solo_dev, 1, buf,
216 SOLO_MOTION_EXT_ADDR(solo_dev) + off + y * size,
227 static void solo_motion_config(struct solo_dev *solo_dev)
231 for (i = 0; i < solo_dev->nr_chans; i++) {
233 solo_dma_vin_region(solo_dev, i * SOLO_MOT_FLAG_SIZE, 0x0000,
237 solo_dma_vin_region(solo_dev, SOLO_MOT_FLAG_AREA +
243 solo_set_motion_threshold(solo_dev, i, SOLO_DEF_MOT_THRESH);
247 solo_reg_write(solo_dev, SOLO_VI_MOT_ADR, SOLO_VI_MOTION_EN(0) |
248 (SOLO_MOTION_EXT_ADDR(solo_dev) >> 16));
249 solo_reg_write(solo_dev, SOLO_VI_MOT_CTRL,
251 SOLO_VI_MOTION_SAMPLE_LENGTH(solo_dev->video_hsize / 16)
255 solo_reg_write(solo_dev, SOLO_VI_MOTION_BORDER, 0);
256 solo_reg_write(solo_dev, SOLO_VI_MOTION_BAR, 0);
259 int solo_disp_init(struct solo_dev *solo_dev)
263 solo_dev->video_hsize = 704;
264 if (solo_dev->video_type == SOLO_VO_FMT_TYPE_NTSC) {
265 solo_dev->video_vsize = 240;
266 solo_dev->fps = 30;
268 solo_dev->video_vsize = 288;
269 solo_dev->fps = 25;
272 solo_vin_config(solo_dev);
273 solo_motion_config(solo_dev);
274 solo_vout_config(solo_dev);
276 for (i = 0; i < solo_dev->nr_chans; i++)
277 solo_reg_write(solo_dev, SOLO_VI_WIN_ON(i), 1);
282 void solo_disp_exit(struct solo_dev *solo_dev)
286 solo_reg_write(solo_dev, SOLO_VO_DISP_CTRL, 0);
287 solo_reg_write(solo_dev, SOLO_VO_ZOOM_CTRL, 0);
288 solo_reg_write(solo_dev, SOLO_VO_FREEZE_CTRL, 0);
290 for (i = 0; i < solo_dev->nr_chans; i++) {
291 solo_reg_write(solo_dev, SOLO_VI_WIN_CTRL0(i), 0);
292 solo_reg_write(solo_dev, SOLO_VI_WIN_CTRL1(i), 0);
293 solo_reg_write(solo_dev, SOLO_VI_WIN_ON(i), 0);
298 solo_reg_write(solo_dev, SOLO_VO_BORDER_X(i), 0);
301 solo_reg_write(solo_dev, SOLO_VO_BORDER_Y(i), 0);
303 solo_reg_write(solo_dev, SOLO_VO_BORDER_LINE_MASK, 0);
304 solo_reg_write(solo_dev, SOLO_VO_BORDER_FILL_MASK, 0);
306 solo_reg_write(solo_dev, SOLO_VO_RECTANGLE_CTRL(0), 0);
307 solo_reg_write(solo_dev, SOLO_VO_RECTANGLE_START(0), 0);
308 solo_reg_write(solo_dev, SOLO_VO_RECTANGLE_STOP(0), 0);
310 solo_reg_write(solo_dev, SOLO_VO_RECTANGLE_CTRL(1), 0);
311 solo_reg_write(solo_dev, SOLO_VO_RECTANGLE_START(1), 0);
312 solo_reg_write(solo_dev, SOLO_VO_RECTANGLE_STOP(1), 0);