xref: /linux/drivers/media/platform/allegro-dvt/allegro-core.c (revision 566ab427f827b0256d3e8ce0235d088e6a9c28bd)
1 // SPDX-License-Identifier: GPL-2.0
2 /*
3  * Copyright (C) 2019 Pengutronix, Michael Tretter <kernel@pengutronix.de>
4  *
5  * Allegro DVT video encoder driver
6  */
7 
8 #include <linux/bits.h>
9 #include <linux/clk.h>
10 #include <linux/firmware.h>
11 #include <linux/gcd.h>
12 #include <linux/interrupt.h>
13 #include <linux/io.h>
14 #include <linux/kernel.h>
15 #include <linux/log2.h>
16 #include <linux/mfd/syscon.h>
17 #include <linux/mfd/syscon/xlnx-vcu.h>
18 #include <linux/module.h>
19 #include <linux/of.h>
20 #include <linux/platform_device.h>
21 #include <linux/pm_runtime.h>
22 #include <linux/regmap.h>
23 #include <linux/sizes.h>
24 #include <linux/slab.h>
25 #include <linux/videodev2.h>
26 #include <media/v4l2-ctrls.h>
27 #include <media/v4l2-device.h>
28 #include <media/v4l2-event.h>
29 #include <media/v4l2-ioctl.h>
30 #include <media/v4l2-mem2mem.h>
31 #include <media/videobuf2-dma-contig.h>
32 #include <media/videobuf2-v4l2.h>
33 
34 #include "allegro-mail.h"
35 #include "nal-h264.h"
36 #include "nal-hevc.h"
37 
38 /*
39  * Support up to 4k video streams. The hardware actually supports higher
40  * resolutions, which are specified in PG252 June 6, 2018 (H.264/H.265 Video
41  * Codec Unit v1.1) Chapter 3.
42  */
43 #define ALLEGRO_WIDTH_MIN 128
44 #define ALLEGRO_WIDTH_DEFAULT 1920
45 #define ALLEGRO_WIDTH_MAX 3840
46 #define ALLEGRO_HEIGHT_MIN 64
47 #define ALLEGRO_HEIGHT_DEFAULT 1080
48 #define ALLEGRO_HEIGHT_MAX 2160
49 
50 #define ALLEGRO_FRAMERATE_DEFAULT ((struct v4l2_fract) { 30, 1 })
51 
52 #define ALLEGRO_GOP_SIZE_DEFAULT 25
53 #define ALLEGRO_GOP_SIZE_MAX 1000
54 
55 /*
56  * MCU Control Registers
57  *
58  * The Zynq UltraScale+ Devices Register Reference documents the registers
59  * with an offset of 0x9000, which equals the size of the SRAM and one page
60  * gap. The driver handles SRAM and registers separately and, therefore, is
61  * oblivious of the offset.
62  */
63 #define AL5_MCU_RESET                   0x0000
64 #define AL5_MCU_RESET_SOFT              BIT(0)
65 #define AL5_MCU_RESET_REGS              BIT(1)
66 #define AL5_MCU_RESET_MODE              0x0004
67 #define AL5_MCU_RESET_MODE_SLEEP        BIT(0)
68 #define AL5_MCU_RESET_MODE_HALT         BIT(1)
69 #define AL5_MCU_STA                     0x0008
70 #define AL5_MCU_STA_SLEEP               BIT(0)
71 #define AL5_MCU_WAKEUP                  0x000c
72 
73 #define AL5_ICACHE_ADDR_OFFSET_MSB      0x0010
74 #define AL5_ICACHE_ADDR_OFFSET_LSB      0x0014
75 #define AL5_DCACHE_ADDR_OFFSET_MSB      0x0018
76 #define AL5_DCACHE_ADDR_OFFSET_LSB      0x001c
77 
78 #define AL5_MCU_INTERRUPT               0x0100
79 #define AL5_ITC_CPU_IRQ_MSK             0x0104
80 #define AL5_ITC_CPU_IRQ_CLR             0x0108
81 #define AL5_ITC_CPU_IRQ_STA             0x010C
82 #define AL5_ITC_CPU_IRQ_STA_TRIGGERED   BIT(0)
83 
84 #define AXI_ADDR_OFFSET_IP              0x0208
85 
86 /*
87  * The MCU accesses the system memory with a 2G offset compared to CPU
88  * physical addresses.
89  */
90 #define MCU_CACHE_OFFSET SZ_2G
91 
92 /*
93  * The driver needs to reserve some space at the beginning of capture buffers,
94  * because it needs to write SPS/PPS NAL units. The encoder writes the actual
95  * frame data after the offset.
96  */
97 #define ENCODER_STREAM_OFFSET SZ_128
98 
99 #define SIZE_MACROBLOCK 16
100 
101 /* Encoding options */
102 #define LOG2_MAX_FRAME_NUM		4
103 #define LOG2_MAX_PIC_ORDER_CNT		10
104 #define BETA_OFFSET_DIV_2		-1
105 #define TC_OFFSET_DIV_2			-1
106 
107 /*
108  * This control allows applications to explicitly disable the encoder buffer.
109  * This value is Allegro specific.
110  */
111 #define V4L2_CID_USER_ALLEGRO_ENCODER_BUFFER (V4L2_CID_USER_ALLEGRO_BASE + 0)
112 
113 static int debug;
114 module_param(debug, int, 0644);
115 MODULE_PARM_DESC(debug, "Debug level (0-2)");
116 
117 struct allegro_buffer {
118 	void *vaddr;
119 	dma_addr_t paddr;
120 	size_t size;
121 	struct list_head head;
122 };
123 
124 struct allegro_dev;
125 struct allegro_channel;
126 
127 struct allegro_mbox {
128 	struct allegro_dev *dev;
129 	unsigned int head;
130 	unsigned int tail;
131 	unsigned int data;
132 	size_t size;
133 	/* protect mailbox from simultaneous accesses */
134 	struct mutex lock;
135 };
136 
137 struct allegro_encoder_buffer {
138 	unsigned int size;
139 	unsigned int color_depth;
140 	unsigned int num_cores;
141 	unsigned int clk_rate;
142 };
143 
144 struct allegro_dev {
145 	struct v4l2_device v4l2_dev;
146 	struct video_device video_dev;
147 	struct v4l2_m2m_dev *m2m_dev;
148 	struct platform_device *plat_dev;
149 
150 	/* mutex protecting vb2_queue structure */
151 	struct mutex lock;
152 
153 	struct regmap *regmap;
154 	struct regmap *sram;
155 	struct regmap *settings;
156 
157 	struct clk *clk_core;
158 	struct clk *clk_mcu;
159 
160 	const struct fw_info *fw_info;
161 	struct allegro_buffer firmware;
162 	struct allegro_buffer suballocator;
163 	bool has_encoder_buffer;
164 	struct allegro_encoder_buffer encoder_buffer;
165 
166 	struct completion init_complete;
167 	bool initialized;
168 
169 	/* The mailbox interface */
170 	struct allegro_mbox *mbox_command;
171 	struct allegro_mbox *mbox_status;
172 
173 	/*
174 	 * The downstream driver limits the users to 64 users, thus I can use
175 	 * a bitfield for the user_ids that are in use. See also user_id in
176 	 * struct allegro_channel.
177 	 */
178 	unsigned long channel_user_ids;
179 	struct list_head channels;
180 };
181 
182 static const struct regmap_config allegro_regmap_config = {
183 	.name = "regmap",
184 	.reg_bits = 32,
185 	.val_bits = 32,
186 	.reg_stride = 4,
187 	.max_register = 0xfff,
188 	.cache_type = REGCACHE_NONE,
189 };
190 
191 static const struct regmap_config allegro_sram_config = {
192 	.name = "sram",
193 	.reg_bits = 32,
194 	.val_bits = 32,
195 	.reg_stride = 4,
196 	.max_register = 0x7fff,
197 	.cache_type = REGCACHE_NONE,
198 };
199 
200 #define fh_to_channel(__fh) container_of(__fh, struct allegro_channel, fh)
201 
202 struct allegro_channel {
203 	struct allegro_dev *dev;
204 	struct v4l2_fh fh;
205 	struct v4l2_ctrl_handler ctrl_handler;
206 
207 	unsigned int width;
208 	unsigned int height;
209 	unsigned int stride;
210 	struct v4l2_fract framerate;
211 
212 	enum v4l2_colorspace colorspace;
213 	enum v4l2_ycbcr_encoding ycbcr_enc;
214 	enum v4l2_quantization quantization;
215 	enum v4l2_xfer_func xfer_func;
216 
217 	u32 pixelformat;
218 	unsigned int sizeimage_raw;
219 	unsigned int osequence;
220 
221 	u32 codec;
222 	unsigned int sizeimage_encoded;
223 	unsigned int csequence;
224 
225 	bool frame_rc_enable;
226 	unsigned int bitrate;
227 	unsigned int bitrate_peak;
228 
229 	struct allegro_buffer config_blob;
230 
231 	unsigned int log2_max_frame_num;
232 	bool temporal_mvp_enable;
233 
234 	bool enable_loop_filter_across_tiles;
235 	bool enable_loop_filter_across_slices;
236 	bool enable_deblocking_filter_override;
237 	bool enable_reordering;
238 	bool dbf_ovr_en;
239 
240 	unsigned int num_ref_idx_l0;
241 	unsigned int num_ref_idx_l1;
242 
243 	/* Maximum range for motion estimation */
244 	int b_hrz_me_range;
245 	int b_vrt_me_range;
246 	int p_hrz_me_range;
247 	int p_vrt_me_range;
248 	/* Size limits of coding unit */
249 	int min_cu_size;
250 	int max_cu_size;
251 	/* Size limits of transform unit */
252 	int min_tu_size;
253 	int max_tu_size;
254 	int max_transfo_depth_intra;
255 	int max_transfo_depth_inter;
256 
257 	struct v4l2_ctrl *mpeg_video_h264_profile;
258 	struct v4l2_ctrl *mpeg_video_h264_level;
259 	struct v4l2_ctrl *mpeg_video_h264_i_frame_qp;
260 	struct v4l2_ctrl *mpeg_video_h264_max_qp;
261 	struct v4l2_ctrl *mpeg_video_h264_min_qp;
262 	struct v4l2_ctrl *mpeg_video_h264_p_frame_qp;
263 	struct v4l2_ctrl *mpeg_video_h264_b_frame_qp;
264 
265 	struct v4l2_ctrl *mpeg_video_hevc_profile;
266 	struct v4l2_ctrl *mpeg_video_hevc_level;
267 	struct v4l2_ctrl *mpeg_video_hevc_tier;
268 	struct v4l2_ctrl *mpeg_video_hevc_i_frame_qp;
269 	struct v4l2_ctrl *mpeg_video_hevc_max_qp;
270 	struct v4l2_ctrl *mpeg_video_hevc_min_qp;
271 	struct v4l2_ctrl *mpeg_video_hevc_p_frame_qp;
272 	struct v4l2_ctrl *mpeg_video_hevc_b_frame_qp;
273 
274 	struct v4l2_ctrl *mpeg_video_frame_rc_enable;
275 	struct { /* video bitrate mode control cluster */
276 		struct v4l2_ctrl *mpeg_video_bitrate_mode;
277 		struct v4l2_ctrl *mpeg_video_bitrate;
278 		struct v4l2_ctrl *mpeg_video_bitrate_peak;
279 	};
280 	struct v4l2_ctrl *mpeg_video_cpb_size;
281 	struct v4l2_ctrl *mpeg_video_gop_size;
282 
283 	struct v4l2_ctrl *encoder_buffer;
284 
285 	/* user_id is used to identify the channel during CREATE_CHANNEL */
286 	/* not sure, what to set here and if this is actually required */
287 	int user_id;
288 	/* channel_id is set by the mcu and used by all later commands */
289 	int mcu_channel_id;
290 
291 	struct list_head buffers_reference;
292 	struct list_head buffers_intermediate;
293 
294 	struct list_head source_shadow_list;
295 	struct list_head stream_shadow_list;
296 	/* protect shadow lists of buffers passed to firmware */
297 	struct mutex shadow_list_lock;
298 
299 	struct list_head list;
300 	struct completion completion;
301 
302 	unsigned int error;
303 };
304 
305 static inline int
306 allegro_channel_get_i_frame_qp(struct allegro_channel *channel)
307 {
308 	if (channel->codec == V4L2_PIX_FMT_HEVC)
309 		return v4l2_ctrl_g_ctrl(channel->mpeg_video_hevc_i_frame_qp);
310 	else
311 		return v4l2_ctrl_g_ctrl(channel->mpeg_video_h264_i_frame_qp);
312 }
313 
314 static inline int
315 allegro_channel_get_p_frame_qp(struct allegro_channel *channel)
316 {
317 	if (channel->codec == V4L2_PIX_FMT_HEVC)
318 		return v4l2_ctrl_g_ctrl(channel->mpeg_video_hevc_p_frame_qp);
319 	else
320 		return v4l2_ctrl_g_ctrl(channel->mpeg_video_h264_p_frame_qp);
321 }
322 
323 static inline int
324 allegro_channel_get_b_frame_qp(struct allegro_channel *channel)
325 {
326 	if (channel->codec == V4L2_PIX_FMT_HEVC)
327 		return v4l2_ctrl_g_ctrl(channel->mpeg_video_hevc_b_frame_qp);
328 	else
329 		return v4l2_ctrl_g_ctrl(channel->mpeg_video_h264_b_frame_qp);
330 }
331 
332 static inline int
333 allegro_channel_get_min_qp(struct allegro_channel *channel)
334 {
335 	if (channel->codec == V4L2_PIX_FMT_HEVC)
336 		return v4l2_ctrl_g_ctrl(channel->mpeg_video_hevc_min_qp);
337 	else
338 		return v4l2_ctrl_g_ctrl(channel->mpeg_video_h264_min_qp);
339 }
340 
341 static inline int
342 allegro_channel_get_max_qp(struct allegro_channel *channel)
343 {
344 	if (channel->codec == V4L2_PIX_FMT_HEVC)
345 		return v4l2_ctrl_g_ctrl(channel->mpeg_video_hevc_max_qp);
346 	else
347 		return v4l2_ctrl_g_ctrl(channel->mpeg_video_h264_max_qp);
348 }
349 
350 struct allegro_m2m_buffer {
351 	struct v4l2_m2m_buffer buf;
352 	struct list_head head;
353 };
354 
355 #define to_allegro_m2m_buffer(__buf) \
356 	container_of(__buf, struct allegro_m2m_buffer, buf)
357 
358 struct fw_info {
359 	unsigned int id;
360 	unsigned int id_codec;
361 	char *version;
362 	unsigned int mailbox_cmd;
363 	unsigned int mailbox_status;
364 	size_t mailbox_size;
365 	enum mcu_msg_version mailbox_version;
366 	size_t suballocator_size;
367 };
368 
369 static const struct fw_info supported_firmware[] = {
370 	{
371 		.id = 18296,
372 		.id_codec = 96272,
373 		.version = "v2018.2",
374 		.mailbox_cmd = 0x7800,
375 		.mailbox_status = 0x7c00,
376 		.mailbox_size = 0x400 - 0x8,
377 		.mailbox_version = MCU_MSG_VERSION_2018_2,
378 		.suballocator_size = SZ_16M,
379 	}, {
380 		.id = 14680,
381 		.id_codec = 126572,
382 		.version = "v2019.2",
383 		.mailbox_cmd = 0x7000,
384 		.mailbox_status = 0x7800,
385 		.mailbox_size = 0x800 - 0x8,
386 		.mailbox_version = MCU_MSG_VERSION_2019_2,
387 		.suballocator_size = SZ_32M,
388 	},
389 };
390 
391 static inline u32 to_mcu_addr(struct allegro_dev *dev, dma_addr_t phys)
392 {
393 	if (upper_32_bits(phys) || (lower_32_bits(phys) & MCU_CACHE_OFFSET))
394 		v4l2_warn(&dev->v4l2_dev,
395 			  "address %pad is outside mcu window\n", &phys);
396 
397 	return lower_32_bits(phys) | MCU_CACHE_OFFSET;
398 }
399 
400 static inline u32 to_mcu_size(struct allegro_dev *dev, size_t size)
401 {
402 	return lower_32_bits(size);
403 }
404 
405 static inline u32 to_codec_addr(struct allegro_dev *dev, dma_addr_t phys)
406 {
407 	if (upper_32_bits(phys))
408 		v4l2_warn(&dev->v4l2_dev,
409 			  "address %pad cannot be used by codec\n", &phys);
410 
411 	return lower_32_bits(phys);
412 }
413 
414 static inline u64 ptr_to_u64(const void *ptr)
415 {
416 	return (uintptr_t)ptr;
417 }
418 
419 /* Helper functions for channel and user operations */
420 
421 static unsigned long allegro_next_user_id(struct allegro_dev *dev)
422 {
423 	if (dev->channel_user_ids == ~0UL)
424 		return -EBUSY;
425 
426 	return ffz(dev->channel_user_ids);
427 }
428 
429 static struct allegro_channel *
430 allegro_find_channel_by_user_id(struct allegro_dev *dev,
431 				unsigned int user_id)
432 {
433 	struct allegro_channel *channel;
434 
435 	list_for_each_entry(channel, &dev->channels, list) {
436 		if (channel->user_id == user_id)
437 			return channel;
438 	}
439 
440 	return ERR_PTR(-EINVAL);
441 }
442 
443 static struct allegro_channel *
444 allegro_find_channel_by_channel_id(struct allegro_dev *dev,
445 				   unsigned int channel_id)
446 {
447 	struct allegro_channel *channel;
448 
449 	list_for_each_entry(channel, &dev->channels, list) {
450 		if (channel->mcu_channel_id == channel_id)
451 			return channel;
452 	}
453 
454 	return ERR_PTR(-EINVAL);
455 }
456 
457 static inline bool channel_exists(struct allegro_channel *channel)
458 {
459 	return channel->mcu_channel_id != -1;
460 }
461 
462 #define AL_ERROR			0x80
463 #define AL_ERR_INIT_FAILED		0x81
464 #define AL_ERR_NO_FRAME_DECODED		0x82
465 #define AL_ERR_RESOLUTION_CHANGE	0x85
466 #define AL_ERR_NO_MEMORY		0x87
467 #define AL_ERR_STREAM_OVERFLOW		0x88
468 #define AL_ERR_TOO_MANY_SLICES		0x89
469 #define AL_ERR_BUF_NOT_READY		0x8c
470 #define AL_ERR_NO_CHANNEL_AVAILABLE	0x8d
471 #define AL_ERR_RESOURCE_UNAVAILABLE	0x8e
472 #define AL_ERR_NOT_ENOUGH_CORES		0x8f
473 #define AL_ERR_REQUEST_MALFORMED	0x90
474 #define AL_ERR_CMD_NOT_ALLOWED		0x91
475 #define AL_ERR_INVALID_CMD_VALUE	0x92
476 
477 static inline const char *allegro_err_to_string(unsigned int err)
478 {
479 	switch (err) {
480 	case AL_ERR_INIT_FAILED:
481 		return "initialization failed";
482 	case AL_ERR_NO_FRAME_DECODED:
483 		return "no frame decoded";
484 	case AL_ERR_RESOLUTION_CHANGE:
485 		return "resolution change";
486 	case AL_ERR_NO_MEMORY:
487 		return "out of memory";
488 	case AL_ERR_STREAM_OVERFLOW:
489 		return "stream buffer overflow";
490 	case AL_ERR_TOO_MANY_SLICES:
491 		return "too many slices";
492 	case AL_ERR_BUF_NOT_READY:
493 		return "buffer not ready";
494 	case AL_ERR_NO_CHANNEL_AVAILABLE:
495 		return "no channel available";
496 	case AL_ERR_RESOURCE_UNAVAILABLE:
497 		return "resource unavailable";
498 	case AL_ERR_NOT_ENOUGH_CORES:
499 		return "not enough cores";
500 	case AL_ERR_REQUEST_MALFORMED:
501 		return "request malformed";
502 	case AL_ERR_CMD_NOT_ALLOWED:
503 		return "command not allowed";
504 	case AL_ERR_INVALID_CMD_VALUE:
505 		return "invalid command value";
506 	case AL_ERROR:
507 	default:
508 		return "unknown error";
509 	}
510 }
511 
512 static unsigned int estimate_stream_size(unsigned int width,
513 					 unsigned int height)
514 {
515 	unsigned int offset = ENCODER_STREAM_OFFSET;
516 	unsigned int num_blocks = DIV_ROUND_UP(width, SIZE_MACROBLOCK) *
517 					DIV_ROUND_UP(height, SIZE_MACROBLOCK);
518 	unsigned int pcm_size = SZ_256;
519 	unsigned int partition_table = SZ_256;
520 
521 	return round_up(offset + num_blocks * pcm_size + partition_table, 32);
522 }
523 
524 static enum v4l2_mpeg_video_h264_level
525 select_minimum_h264_level(unsigned int width, unsigned int height)
526 {
527 	unsigned int pic_width_in_mb = DIV_ROUND_UP(width, SIZE_MACROBLOCK);
528 	unsigned int frame_height_in_mb = DIV_ROUND_UP(height, SIZE_MACROBLOCK);
529 	unsigned int frame_size_in_mb = pic_width_in_mb * frame_height_in_mb;
530 	enum v4l2_mpeg_video_h264_level level = V4L2_MPEG_VIDEO_H264_LEVEL_4_0;
531 
532 	/*
533 	 * The level limits are specified in Rec. ITU-T H.264 Annex A.3.1 and
534 	 * also specify limits regarding bit rate and CBP size. Only approximate
535 	 * the levels using the frame size.
536 	 *
537 	 * Level 5.1 allows up to 4k video resolution.
538 	 */
539 	if (frame_size_in_mb <= 99)
540 		level = V4L2_MPEG_VIDEO_H264_LEVEL_1_0;
541 	else if (frame_size_in_mb <= 396)
542 		level = V4L2_MPEG_VIDEO_H264_LEVEL_1_1;
543 	else if (frame_size_in_mb <= 792)
544 		level = V4L2_MPEG_VIDEO_H264_LEVEL_2_1;
545 	else if (frame_size_in_mb <= 1620)
546 		level = V4L2_MPEG_VIDEO_H264_LEVEL_2_2;
547 	else if (frame_size_in_mb <= 3600)
548 		level = V4L2_MPEG_VIDEO_H264_LEVEL_3_1;
549 	else if (frame_size_in_mb <= 5120)
550 		level = V4L2_MPEG_VIDEO_H264_LEVEL_3_2;
551 	else if (frame_size_in_mb <= 8192)
552 		level = V4L2_MPEG_VIDEO_H264_LEVEL_4_0;
553 	else if (frame_size_in_mb <= 8704)
554 		level = V4L2_MPEG_VIDEO_H264_LEVEL_4_2;
555 	else if (frame_size_in_mb <= 22080)
556 		level = V4L2_MPEG_VIDEO_H264_LEVEL_5_0;
557 	else
558 		level = V4L2_MPEG_VIDEO_H264_LEVEL_5_1;
559 
560 	return level;
561 }
562 
563 static unsigned int h264_maximum_bitrate(enum v4l2_mpeg_video_h264_level level)
564 {
565 	switch (level) {
566 	case V4L2_MPEG_VIDEO_H264_LEVEL_1_0:
567 		return 64000;
568 	case V4L2_MPEG_VIDEO_H264_LEVEL_1B:
569 		return 128000;
570 	case V4L2_MPEG_VIDEO_H264_LEVEL_1_1:
571 		return 192000;
572 	case V4L2_MPEG_VIDEO_H264_LEVEL_1_2:
573 		return 384000;
574 	case V4L2_MPEG_VIDEO_H264_LEVEL_1_3:
575 		return 768000;
576 	case V4L2_MPEG_VIDEO_H264_LEVEL_2_0:
577 		return 2000000;
578 	case V4L2_MPEG_VIDEO_H264_LEVEL_2_1:
579 		return 4000000;
580 	case V4L2_MPEG_VIDEO_H264_LEVEL_2_2:
581 		return 4000000;
582 	case V4L2_MPEG_VIDEO_H264_LEVEL_3_0:
583 		return 10000000;
584 	case V4L2_MPEG_VIDEO_H264_LEVEL_3_1:
585 		return 14000000;
586 	case V4L2_MPEG_VIDEO_H264_LEVEL_3_2:
587 		return 20000000;
588 	case V4L2_MPEG_VIDEO_H264_LEVEL_4_0:
589 		return 20000000;
590 	case V4L2_MPEG_VIDEO_H264_LEVEL_4_1:
591 		return 50000000;
592 	case V4L2_MPEG_VIDEO_H264_LEVEL_4_2:
593 		return 50000000;
594 	case V4L2_MPEG_VIDEO_H264_LEVEL_5_0:
595 		return 135000000;
596 	case V4L2_MPEG_VIDEO_H264_LEVEL_5_1:
597 	default:
598 		return 240000000;
599 	}
600 }
601 
602 static unsigned int h264_maximum_cpb_size(enum v4l2_mpeg_video_h264_level level)
603 {
604 	switch (level) {
605 	case V4L2_MPEG_VIDEO_H264_LEVEL_1_0:
606 		return 175;
607 	case V4L2_MPEG_VIDEO_H264_LEVEL_1B:
608 		return 350;
609 	case V4L2_MPEG_VIDEO_H264_LEVEL_1_1:
610 		return 500;
611 	case V4L2_MPEG_VIDEO_H264_LEVEL_1_2:
612 		return 1000;
613 	case V4L2_MPEG_VIDEO_H264_LEVEL_1_3:
614 		return 2000;
615 	case V4L2_MPEG_VIDEO_H264_LEVEL_2_0:
616 		return 2000;
617 	case V4L2_MPEG_VIDEO_H264_LEVEL_2_1:
618 		return 4000;
619 	case V4L2_MPEG_VIDEO_H264_LEVEL_2_2:
620 		return 4000;
621 	case V4L2_MPEG_VIDEO_H264_LEVEL_3_0:
622 		return 10000;
623 	case V4L2_MPEG_VIDEO_H264_LEVEL_3_1:
624 		return 14000;
625 	case V4L2_MPEG_VIDEO_H264_LEVEL_3_2:
626 		return 20000;
627 	case V4L2_MPEG_VIDEO_H264_LEVEL_4_0:
628 		return 25000;
629 	case V4L2_MPEG_VIDEO_H264_LEVEL_4_1:
630 		return 62500;
631 	case V4L2_MPEG_VIDEO_H264_LEVEL_4_2:
632 		return 62500;
633 	case V4L2_MPEG_VIDEO_H264_LEVEL_5_0:
634 		return 135000;
635 	case V4L2_MPEG_VIDEO_H264_LEVEL_5_1:
636 	default:
637 		return 240000;
638 	}
639 }
640 
641 static enum v4l2_mpeg_video_hevc_level
642 select_minimum_hevc_level(unsigned int width, unsigned int height)
643 {
644 	unsigned int luma_picture_size = width * height;
645 	enum v4l2_mpeg_video_hevc_level level;
646 
647 	if (luma_picture_size <= 36864)
648 		level = V4L2_MPEG_VIDEO_HEVC_LEVEL_1;
649 	else if (luma_picture_size <= 122880)
650 		level = V4L2_MPEG_VIDEO_HEVC_LEVEL_2;
651 	else if (luma_picture_size <= 245760)
652 		level = V4L2_MPEG_VIDEO_HEVC_LEVEL_2_1;
653 	else if (luma_picture_size <= 552960)
654 		level = V4L2_MPEG_VIDEO_HEVC_LEVEL_3;
655 	else if (luma_picture_size <= 983040)
656 		level = V4L2_MPEG_VIDEO_HEVC_LEVEL_3_1;
657 	else if (luma_picture_size <= 2228224)
658 		level = V4L2_MPEG_VIDEO_HEVC_LEVEL_4;
659 	else if (luma_picture_size <= 8912896)
660 		level = V4L2_MPEG_VIDEO_HEVC_LEVEL_5;
661 	else
662 		level = V4L2_MPEG_VIDEO_HEVC_LEVEL_6;
663 
664 	return level;
665 }
666 
667 static unsigned int hevc_maximum_bitrate(enum v4l2_mpeg_video_hevc_level level)
668 {
669 	/*
670 	 * See Rec. ITU-T H.265 v5 (02/2018), A.4.2 Profile-specific level
671 	 * limits for the video profiles.
672 	 */
673 	switch (level) {
674 	case V4L2_MPEG_VIDEO_HEVC_LEVEL_1:
675 		return 128;
676 	case V4L2_MPEG_VIDEO_HEVC_LEVEL_2:
677 		return 1500;
678 	case V4L2_MPEG_VIDEO_HEVC_LEVEL_2_1:
679 		return 3000;
680 	case V4L2_MPEG_VIDEO_HEVC_LEVEL_3:
681 		return 6000;
682 	case V4L2_MPEG_VIDEO_HEVC_LEVEL_3_1:
683 		return 10000;
684 	case V4L2_MPEG_VIDEO_HEVC_LEVEL_4:
685 		return 12000;
686 	case V4L2_MPEG_VIDEO_HEVC_LEVEL_4_1:
687 		return 20000;
688 	case V4L2_MPEG_VIDEO_HEVC_LEVEL_5:
689 		return 25000;
690 	default:
691 	case V4L2_MPEG_VIDEO_HEVC_LEVEL_5_1:
692 		return 40000;
693 	}
694 }
695 
696 static unsigned int hevc_maximum_cpb_size(enum v4l2_mpeg_video_hevc_level level)
697 {
698 	switch (level) {
699 	case V4L2_MPEG_VIDEO_HEVC_LEVEL_1:
700 		return 350;
701 	case V4L2_MPEG_VIDEO_HEVC_LEVEL_2:
702 		return 1500;
703 	case V4L2_MPEG_VIDEO_HEVC_LEVEL_2_1:
704 		return 3000;
705 	case V4L2_MPEG_VIDEO_HEVC_LEVEL_3:
706 		return 6000;
707 	case V4L2_MPEG_VIDEO_HEVC_LEVEL_3_1:
708 		return 10000;
709 	case V4L2_MPEG_VIDEO_HEVC_LEVEL_4:
710 		return 12000;
711 	case V4L2_MPEG_VIDEO_HEVC_LEVEL_4_1:
712 		return 20000;
713 	case V4L2_MPEG_VIDEO_HEVC_LEVEL_5:
714 		return 25000;
715 	default:
716 	case V4L2_MPEG_VIDEO_HEVC_LEVEL_5_1:
717 		return 40000;
718 	}
719 }
720 
721 static const struct fw_info *
722 allegro_get_firmware_info(struct allegro_dev *dev,
723 			  const struct firmware *fw,
724 			  const struct firmware *fw_codec)
725 {
726 	int i;
727 	unsigned int id = fw->size;
728 	unsigned int id_codec = fw_codec->size;
729 
730 	for (i = 0; i < ARRAY_SIZE(supported_firmware); i++)
731 		if (supported_firmware[i].id == id &&
732 		    supported_firmware[i].id_codec == id_codec)
733 			return &supported_firmware[i];
734 
735 	return NULL;
736 }
737 
738 /*
739  * Buffers that are used internally by the MCU.
740  */
741 
742 static int allegro_alloc_buffer(struct allegro_dev *dev,
743 				struct allegro_buffer *buffer, size_t size)
744 {
745 	buffer->vaddr = dma_alloc_coherent(&dev->plat_dev->dev, size,
746 					   &buffer->paddr, GFP_KERNEL);
747 	if (!buffer->vaddr)
748 		return -ENOMEM;
749 	buffer->size = size;
750 
751 	return 0;
752 }
753 
754 static void allegro_free_buffer(struct allegro_dev *dev,
755 				struct allegro_buffer *buffer)
756 {
757 	if (buffer->vaddr) {
758 		dma_free_coherent(&dev->plat_dev->dev, buffer->size,
759 				  buffer->vaddr, buffer->paddr);
760 		buffer->vaddr = NULL;
761 		buffer->size = 0;
762 	}
763 }
764 
765 /*
766  * Mailbox interface to send messages to the MCU.
767  */
768 
769 static void allegro_mcu_interrupt(struct allegro_dev *dev);
770 static void allegro_handle_message(struct allegro_dev *dev,
771 				   union mcu_msg_response *msg);
772 
773 static struct allegro_mbox *allegro_mbox_init(struct allegro_dev *dev,
774 					      unsigned int base, size_t size)
775 {
776 	struct allegro_mbox *mbox;
777 
778 	mbox = devm_kmalloc(&dev->plat_dev->dev, sizeof(*mbox), GFP_KERNEL);
779 	if (!mbox)
780 		return ERR_PTR(-ENOMEM);
781 
782 	mbox->dev = dev;
783 
784 	mbox->head = base;
785 	mbox->tail = base + 0x4;
786 	mbox->data = base + 0x8;
787 	mbox->size = size;
788 	mutex_init(&mbox->lock);
789 
790 	regmap_write(dev->sram, mbox->head, 0);
791 	regmap_write(dev->sram, mbox->tail, 0);
792 
793 	return mbox;
794 }
795 
796 static int allegro_mbox_write(struct allegro_mbox *mbox,
797 			      const u32 *src, size_t size)
798 {
799 	struct regmap *sram = mbox->dev->sram;
800 	unsigned int tail;
801 	size_t size_no_wrap;
802 	int err = 0;
803 	int stride = regmap_get_reg_stride(sram);
804 
805 	if (!src)
806 		return -EINVAL;
807 
808 	if (size > mbox->size)
809 		return -EINVAL;
810 
811 	mutex_lock(&mbox->lock);
812 	regmap_read(sram, mbox->tail, &tail);
813 	if (tail > mbox->size) {
814 		err = -EIO;
815 		goto out;
816 	}
817 	size_no_wrap = min(size, mbox->size - (size_t)tail);
818 	regmap_bulk_write(sram, mbox->data + tail,
819 			  src, size_no_wrap / stride);
820 	regmap_bulk_write(sram, mbox->data,
821 			  src + (size_no_wrap / sizeof(*src)),
822 			  (size - size_no_wrap) / stride);
823 	regmap_write(sram, mbox->tail, (tail + size) % mbox->size);
824 
825 out:
826 	mutex_unlock(&mbox->lock);
827 
828 	return err;
829 }
830 
831 static ssize_t allegro_mbox_read(struct allegro_mbox *mbox,
832 				 u32 *dst, size_t nbyte)
833 {
834 	struct {
835 		u16 length;
836 		u16 type;
837 	} __attribute__ ((__packed__)) *header;
838 	struct regmap *sram = mbox->dev->sram;
839 	unsigned int head;
840 	ssize_t size;
841 	size_t body_no_wrap;
842 	int stride = regmap_get_reg_stride(sram);
843 
844 	regmap_read(sram, mbox->head, &head);
845 	if (head > mbox->size)
846 		return -EIO;
847 
848 	/* Assume that the header does not wrap. */
849 	regmap_bulk_read(sram, mbox->data + head,
850 			 dst, sizeof(*header) / stride);
851 	header = (void *)dst;
852 	size = header->length + sizeof(*header);
853 	if (size > mbox->size || size & 0x3)
854 		return -EIO;
855 	if (size > nbyte)
856 		return -EINVAL;
857 
858 	/*
859 	 * The message might wrap within the mailbox. If the message does not
860 	 * wrap, the first read will read the entire message, otherwise the
861 	 * first read will read message until the end of the mailbox and the
862 	 * second read will read the remaining bytes from the beginning of the
863 	 * mailbox.
864 	 *
865 	 * Skip the header, as was already read to get the size of the body.
866 	 */
867 	body_no_wrap = min((size_t)header->length,
868 			   (size_t)(mbox->size - (head + sizeof(*header))));
869 	regmap_bulk_read(sram, mbox->data + head + sizeof(*header),
870 			 dst + (sizeof(*header) / sizeof(*dst)),
871 			 body_no_wrap / stride);
872 	regmap_bulk_read(sram, mbox->data,
873 			 dst + (sizeof(*header) + body_no_wrap) / sizeof(*dst),
874 			 (header->length - body_no_wrap) / stride);
875 
876 	regmap_write(sram, mbox->head, (head + size) % mbox->size);
877 
878 	return size;
879 }
880 
881 /**
882  * allegro_mbox_send() - Send a message via the mailbox
883  * @mbox: the mailbox which is used to send the message
884  * @msg: the message to send
885  */
886 static int allegro_mbox_send(struct allegro_mbox *mbox, void *msg)
887 {
888 	struct allegro_dev *dev = mbox->dev;
889 	ssize_t size;
890 	int err;
891 	u32 *tmp;
892 
893 	tmp = kzalloc(mbox->size, GFP_KERNEL);
894 	if (!tmp) {
895 		err = -ENOMEM;
896 		goto out;
897 	}
898 
899 	size = allegro_encode_mail(tmp, msg);
900 
901 	err = allegro_mbox_write(mbox, tmp, size);
902 	kfree(tmp);
903 	if (err)
904 		goto out;
905 
906 	allegro_mcu_interrupt(dev);
907 
908 out:
909 	return err;
910 }
911 
912 /**
913  * allegro_mbox_notify() - Notify the mailbox about a new message
914  * @mbox: The allegro_mbox to notify
915  */
916 static void allegro_mbox_notify(struct allegro_mbox *mbox)
917 {
918 	struct allegro_dev *dev = mbox->dev;
919 	union mcu_msg_response *msg;
920 	ssize_t size;
921 	u32 *tmp;
922 	int err;
923 
924 	msg = kmalloc(sizeof(*msg), GFP_KERNEL);
925 	if (!msg)
926 		return;
927 
928 	msg->header.version = dev->fw_info->mailbox_version;
929 
930 	tmp = kmalloc(mbox->size, GFP_KERNEL);
931 	if (!tmp)
932 		goto out;
933 
934 	size = allegro_mbox_read(mbox, tmp, mbox->size);
935 	if (size < 0)
936 		goto out;
937 
938 	err = allegro_decode_mail(msg, tmp);
939 	if (err)
940 		goto out;
941 
942 	allegro_handle_message(dev, msg);
943 
944 out:
945 	kfree(tmp);
946 	kfree(msg);
947 }
948 
949 static int allegro_encoder_buffer_init(struct allegro_dev *dev,
950 				       struct allegro_encoder_buffer *buffer)
951 {
952 	int err;
953 	struct regmap *settings = dev->settings;
954 	unsigned int supports_10_bit;
955 	unsigned int memory_depth;
956 	unsigned int num_cores;
957 	unsigned int color_depth;
958 	unsigned long clk_rate;
959 
960 	/* We don't support the encoder buffer pre Firmware version 2019.2 */
961 	if (dev->fw_info->mailbox_version < MCU_MSG_VERSION_2019_2)
962 		return -ENODEV;
963 
964 	if (!settings)
965 		return -EINVAL;
966 
967 	err = regmap_read(settings, VCU_ENC_COLOR_DEPTH, &supports_10_bit);
968 	if (err < 0)
969 		return err;
970 	err = regmap_read(settings, VCU_MEMORY_DEPTH, &memory_depth);
971 	if (err < 0)
972 		return err;
973 	err = regmap_read(settings, VCU_NUM_CORE, &num_cores);
974 	if (err < 0)
975 		return err;
976 
977 	clk_rate = clk_get_rate(dev->clk_core);
978 	if (clk_rate == 0)
979 		return -EINVAL;
980 
981 	color_depth = supports_10_bit ? 10 : 8;
982 	/* The firmware expects the encoder buffer size in bits. */
983 	buffer->size = color_depth * 32 * memory_depth;
984 	buffer->color_depth = color_depth;
985 	buffer->num_cores = num_cores;
986 	buffer->clk_rate = clk_rate;
987 
988 	v4l2_dbg(1, debug, &dev->v4l2_dev,
989 		 "using %d bits encoder buffer with %d-bit color depth\n",
990 		 buffer->size, color_depth);
991 
992 	return 0;
993 }
994 
995 static void allegro_mcu_send_init(struct allegro_dev *dev,
996 				  dma_addr_t suballoc_dma, size_t suballoc_size)
997 {
998 	struct mcu_msg_init_request msg;
999 
1000 	memset(&msg, 0, sizeof(msg));
1001 
1002 	msg.header.type = MCU_MSG_TYPE_INIT;
1003 	msg.header.version = dev->fw_info->mailbox_version;
1004 
1005 	msg.suballoc_dma = to_mcu_addr(dev, suballoc_dma);
1006 	msg.suballoc_size = to_mcu_size(dev, suballoc_size);
1007 
1008 	if (dev->has_encoder_buffer) {
1009 		msg.encoder_buffer_size = dev->encoder_buffer.size;
1010 		msg.encoder_buffer_color_depth = dev->encoder_buffer.color_depth;
1011 		msg.num_cores = dev->encoder_buffer.num_cores;
1012 		msg.clk_rate = dev->encoder_buffer.clk_rate;
1013 	} else {
1014 		msg.encoder_buffer_size = -1;
1015 		msg.encoder_buffer_color_depth = -1;
1016 		msg.num_cores = -1;
1017 		msg.clk_rate = -1;
1018 	}
1019 
1020 	allegro_mbox_send(dev->mbox_command, &msg);
1021 }
1022 
1023 static u32 v4l2_pixelformat_to_mcu_format(u32 pixelformat)
1024 {
1025 	switch (pixelformat) {
1026 	case V4L2_PIX_FMT_NV12:
1027 		/* AL_420_8BITS: 0x100 -> NV12, 0x88 -> 8 bit */
1028 		return 0x100 | 0x88;
1029 	default:
1030 		return -EINVAL;
1031 	}
1032 }
1033 
1034 static u32 v4l2_colorspace_to_mcu_colorspace(enum v4l2_colorspace colorspace)
1035 {
1036 	switch (colorspace) {
1037 	case V4L2_COLORSPACE_REC709:
1038 		return 2;
1039 	case V4L2_COLORSPACE_SMPTE170M:
1040 		return 3;
1041 	case V4L2_COLORSPACE_SMPTE240M:
1042 		return 4;
1043 	case V4L2_COLORSPACE_SRGB:
1044 		return 7;
1045 	default:
1046 		/* UNKNOWN */
1047 		return 0;
1048 	}
1049 }
1050 
1051 static u8 v4l2_profile_to_mcu_profile(enum v4l2_mpeg_video_h264_profile profile)
1052 {
1053 	switch (profile) {
1054 	case V4L2_MPEG_VIDEO_H264_PROFILE_BASELINE:
1055 	default:
1056 		return 66;
1057 	}
1058 }
1059 
1060 static u16 v4l2_level_to_mcu_level(enum v4l2_mpeg_video_h264_level level)
1061 {
1062 	switch (level) {
1063 	case V4L2_MPEG_VIDEO_H264_LEVEL_1_0:
1064 		return 10;
1065 	case V4L2_MPEG_VIDEO_H264_LEVEL_1_1:
1066 		return 11;
1067 	case V4L2_MPEG_VIDEO_H264_LEVEL_1_2:
1068 		return 12;
1069 	case V4L2_MPEG_VIDEO_H264_LEVEL_1_3:
1070 		return 13;
1071 	case V4L2_MPEG_VIDEO_H264_LEVEL_2_0:
1072 		return 20;
1073 	case V4L2_MPEG_VIDEO_H264_LEVEL_2_1:
1074 		return 21;
1075 	case V4L2_MPEG_VIDEO_H264_LEVEL_2_2:
1076 		return 22;
1077 	case V4L2_MPEG_VIDEO_H264_LEVEL_3_0:
1078 		return 30;
1079 	case V4L2_MPEG_VIDEO_H264_LEVEL_3_1:
1080 		return 31;
1081 	case V4L2_MPEG_VIDEO_H264_LEVEL_3_2:
1082 		return 32;
1083 	case V4L2_MPEG_VIDEO_H264_LEVEL_4_0:
1084 		return 40;
1085 	case V4L2_MPEG_VIDEO_H264_LEVEL_4_1:
1086 		return 41;
1087 	case V4L2_MPEG_VIDEO_H264_LEVEL_4_2:
1088 		return 42;
1089 	case V4L2_MPEG_VIDEO_H264_LEVEL_5_0:
1090 		return 50;
1091 	case V4L2_MPEG_VIDEO_H264_LEVEL_5_1:
1092 	default:
1093 		return 51;
1094 	}
1095 }
1096 
1097 static u8 hevc_profile_to_mcu_profile(enum v4l2_mpeg_video_hevc_profile profile)
1098 {
1099 	switch (profile) {
1100 	default:
1101 	case V4L2_MPEG_VIDEO_HEVC_PROFILE_MAIN:
1102 		return 1;
1103 	case V4L2_MPEG_VIDEO_HEVC_PROFILE_MAIN_10:
1104 		return 2;
1105 	case V4L2_MPEG_VIDEO_HEVC_PROFILE_MAIN_STILL_PICTURE:
1106 		return 3;
1107 	}
1108 }
1109 
1110 static u16 hevc_level_to_mcu_level(enum v4l2_mpeg_video_hevc_level level)
1111 {
1112 	switch (level) {
1113 	case V4L2_MPEG_VIDEO_HEVC_LEVEL_1:
1114 		return 10;
1115 	case V4L2_MPEG_VIDEO_HEVC_LEVEL_2:
1116 		return 20;
1117 	case V4L2_MPEG_VIDEO_HEVC_LEVEL_2_1:
1118 		return 21;
1119 	case V4L2_MPEG_VIDEO_HEVC_LEVEL_3:
1120 		return 30;
1121 	case V4L2_MPEG_VIDEO_HEVC_LEVEL_3_1:
1122 		return 31;
1123 	case V4L2_MPEG_VIDEO_HEVC_LEVEL_4:
1124 		return 40;
1125 	case V4L2_MPEG_VIDEO_HEVC_LEVEL_4_1:
1126 		return 41;
1127 	case V4L2_MPEG_VIDEO_HEVC_LEVEL_5:
1128 		return 50;
1129 	default:
1130 	case V4L2_MPEG_VIDEO_HEVC_LEVEL_5_1:
1131 		return 51;
1132 	}
1133 }
1134 
1135 static u8 hevc_tier_to_mcu_tier(enum v4l2_mpeg_video_hevc_tier tier)
1136 {
1137 	switch (tier) {
1138 	default:
1139 	case V4L2_MPEG_VIDEO_HEVC_TIER_MAIN:
1140 		return 0;
1141 	case V4L2_MPEG_VIDEO_HEVC_TIER_HIGH:
1142 		return 1;
1143 	}
1144 }
1145 
1146 static u32
1147 v4l2_bitrate_mode_to_mcu_mode(enum v4l2_mpeg_video_bitrate_mode mode)
1148 {
1149 	switch (mode) {
1150 	case V4L2_MPEG_VIDEO_BITRATE_MODE_VBR:
1151 		return 2;
1152 	case V4L2_MPEG_VIDEO_BITRATE_MODE_CBR:
1153 	default:
1154 		return 1;
1155 	}
1156 }
1157 
1158 static u32 v4l2_cpb_size_to_mcu(unsigned int cpb_size, unsigned int bitrate)
1159 {
1160 	unsigned int cpb_size_kbit;
1161 	unsigned int bitrate_kbps;
1162 
1163 	/*
1164 	 * The mcu expects the CPB size in units of a 90 kHz clock, but the
1165 	 * channel follows the V4L2_CID_MPEG_VIDEO_H264_CPB_SIZE and stores
1166 	 * the CPB size in kilobytes.
1167 	 */
1168 	cpb_size_kbit = cpb_size * BITS_PER_BYTE;
1169 	bitrate_kbps = bitrate / 1000;
1170 
1171 	return (cpb_size_kbit * 90000) / bitrate_kbps;
1172 }
1173 
1174 static s16 get_qp_delta(int minuend, int subtrahend)
1175 {
1176 	if (minuend == subtrahend)
1177 		return -1;
1178 	else
1179 		return minuend - subtrahend;
1180 }
1181 
1182 static u32 allegro_channel_get_entropy_mode(struct allegro_channel *channel)
1183 {
1184 #define ALLEGRO_ENTROPY_MODE_CAVLC 0
1185 #define ALLEGRO_ENTROPY_MODE_CABAC 1
1186 
1187 	/* HEVC always uses CABAC, but this has to be explicitly set */
1188 	if (channel->codec == V4L2_PIX_FMT_HEVC)
1189 		return ALLEGRO_ENTROPY_MODE_CABAC;
1190 
1191 	return ALLEGRO_ENTROPY_MODE_CAVLC;
1192 }
1193 
1194 static int fill_create_channel_param(struct allegro_channel *channel,
1195 				     struct create_channel_param *param)
1196 {
1197 	int i_frame_qp = allegro_channel_get_i_frame_qp(channel);
1198 	int p_frame_qp = allegro_channel_get_p_frame_qp(channel);
1199 	int b_frame_qp = allegro_channel_get_b_frame_qp(channel);
1200 	int bitrate_mode = v4l2_ctrl_g_ctrl(channel->mpeg_video_bitrate_mode);
1201 	unsigned int cpb_size = v4l2_ctrl_g_ctrl(channel->mpeg_video_cpb_size);
1202 
1203 	param->width = channel->width;
1204 	param->height = channel->height;
1205 	param->format = v4l2_pixelformat_to_mcu_format(channel->pixelformat);
1206 	param->colorspace =
1207 		v4l2_colorspace_to_mcu_colorspace(channel->colorspace);
1208 	param->src_mode = 0x0;
1209 
1210 	param->codec = channel->codec;
1211 	if (channel->codec == V4L2_PIX_FMT_H264) {
1212 		enum v4l2_mpeg_video_h264_profile profile;
1213 		enum v4l2_mpeg_video_h264_level level;
1214 
1215 		profile = v4l2_ctrl_g_ctrl(channel->mpeg_video_h264_profile);
1216 		level = v4l2_ctrl_g_ctrl(channel->mpeg_video_h264_level);
1217 
1218 		param->profile = v4l2_profile_to_mcu_profile(profile);
1219 		param->constraint_set_flags = BIT(1);
1220 		param->level = v4l2_level_to_mcu_level(level);
1221 	} else {
1222 		enum v4l2_mpeg_video_hevc_profile profile;
1223 		enum v4l2_mpeg_video_hevc_level level;
1224 		enum v4l2_mpeg_video_hevc_tier tier;
1225 
1226 		profile = v4l2_ctrl_g_ctrl(channel->mpeg_video_hevc_profile);
1227 		level = v4l2_ctrl_g_ctrl(channel->mpeg_video_hevc_level);
1228 		tier = v4l2_ctrl_g_ctrl(channel->mpeg_video_hevc_tier);
1229 
1230 		param->profile = hevc_profile_to_mcu_profile(profile);
1231 		param->level = hevc_level_to_mcu_level(level);
1232 		param->tier = hevc_tier_to_mcu_tier(tier);
1233 	}
1234 
1235 	param->log2_max_poc = LOG2_MAX_PIC_ORDER_CNT;
1236 	param->log2_max_frame_num = channel->log2_max_frame_num;
1237 	param->temporal_mvp_enable = channel->temporal_mvp_enable;
1238 
1239 	param->dbf_ovr_en = channel->dbf_ovr_en;
1240 	param->override_lf = channel->enable_deblocking_filter_override;
1241 	param->enable_reordering = channel->enable_reordering;
1242 	param->entropy_mode = allegro_channel_get_entropy_mode(channel);
1243 	param->rdo_cost_mode = 1;
1244 	param->custom_lda = 1;
1245 	param->lf = 1;
1246 	param->lf_x_tile = channel->enable_loop_filter_across_tiles;
1247 	param->lf_x_slice = channel->enable_loop_filter_across_slices;
1248 
1249 	param->src_bit_depth = 8;
1250 
1251 	param->beta_offset = BETA_OFFSET_DIV_2;
1252 	param->tc_offset = TC_OFFSET_DIV_2;
1253 	param->num_slices = 1;
1254 	param->me_range[0] = channel->b_hrz_me_range;
1255 	param->me_range[1] = channel->b_vrt_me_range;
1256 	param->me_range[2] = channel->p_hrz_me_range;
1257 	param->me_range[3] = channel->p_vrt_me_range;
1258 	param->max_cu_size = channel->max_cu_size;
1259 	param->min_cu_size = channel->min_cu_size;
1260 	param->max_tu_size = channel->max_tu_size;
1261 	param->min_tu_size = channel->min_tu_size;
1262 	param->max_transfo_depth_intra = channel->max_transfo_depth_intra;
1263 	param->max_transfo_depth_inter = channel->max_transfo_depth_inter;
1264 
1265 	param->encoder_buffer_enabled = v4l2_ctrl_g_ctrl(channel->encoder_buffer);
1266 	param->encoder_buffer_offset = 0;
1267 
1268 	param->rate_control_mode = channel->frame_rc_enable ?
1269 		v4l2_bitrate_mode_to_mcu_mode(bitrate_mode) : 0;
1270 
1271 	param->cpb_size = v4l2_cpb_size_to_mcu(cpb_size, channel->bitrate_peak);
1272 	/* Shall be ]0;cpb_size in 90 kHz units]. Use maximum value. */
1273 	param->initial_rem_delay = param->cpb_size;
1274 	param->framerate = DIV_ROUND_UP(channel->framerate.numerator,
1275 					channel->framerate.denominator);
1276 	param->clk_ratio = channel->framerate.denominator == 1001 ? 1001 : 1000;
1277 	param->target_bitrate = channel->bitrate;
1278 	param->max_bitrate = channel->bitrate_peak;
1279 	param->initial_qp = i_frame_qp;
1280 	param->min_qp = allegro_channel_get_min_qp(channel);
1281 	param->max_qp = allegro_channel_get_max_qp(channel);
1282 	param->ip_delta = get_qp_delta(i_frame_qp, p_frame_qp);
1283 	param->pb_delta = get_qp_delta(p_frame_qp, b_frame_qp);
1284 	param->golden_ref = 0;
1285 	param->golden_delta = 2;
1286 	param->golden_ref_frequency = 10;
1287 	param->rate_control_option = 0x00000000;
1288 
1289 	param->num_pixel = channel->width + channel->height;
1290 	param->max_psnr = 4200;
1291 	param->max_pixel_value = 255;
1292 
1293 	param->gop_ctrl_mode = 0x00000002;
1294 	param->freq_idr = v4l2_ctrl_g_ctrl(channel->mpeg_video_gop_size);
1295 	param->freq_lt = 0;
1296 	param->gdr_mode = 0x00000000;
1297 	param->gop_length = v4l2_ctrl_g_ctrl(channel->mpeg_video_gop_size);
1298 	param->subframe_latency = 0x00000000;
1299 
1300 	param->lda_factors[0] = 51;
1301 	param->lda_factors[1] = 90;
1302 	param->lda_factors[2] = 151;
1303 	param->lda_factors[3] = 151;
1304 	param->lda_factors[4] = 151;
1305 	param->lda_factors[5] = 151;
1306 
1307 	param->max_num_merge_cand = 5;
1308 
1309 	return 0;
1310 }
1311 
1312 static int allegro_mcu_send_create_channel(struct allegro_dev *dev,
1313 					   struct allegro_channel *channel)
1314 {
1315 	struct mcu_msg_create_channel msg;
1316 	struct allegro_buffer *blob = &channel->config_blob;
1317 	struct create_channel_param param;
1318 	size_t size;
1319 
1320 	memset(&param, 0, sizeof(param));
1321 	fill_create_channel_param(channel, &param);
1322 	allegro_alloc_buffer(dev, blob, sizeof(struct create_channel_param));
1323 	param.version = dev->fw_info->mailbox_version;
1324 	size = allegro_encode_config_blob(blob->vaddr, &param);
1325 
1326 	memset(&msg, 0, sizeof(msg));
1327 
1328 	msg.header.type = MCU_MSG_TYPE_CREATE_CHANNEL;
1329 	msg.header.version = dev->fw_info->mailbox_version;
1330 
1331 	msg.user_id = channel->user_id;
1332 
1333 	msg.blob = blob->vaddr;
1334 	msg.blob_size = size;
1335 	msg.blob_mcu_addr = to_mcu_addr(dev, blob->paddr);
1336 
1337 	allegro_mbox_send(dev->mbox_command, &msg);
1338 
1339 	return 0;
1340 }
1341 
1342 static int allegro_mcu_send_destroy_channel(struct allegro_dev *dev,
1343 					    struct allegro_channel *channel)
1344 {
1345 	struct mcu_msg_destroy_channel msg;
1346 
1347 	memset(&msg, 0, sizeof(msg));
1348 
1349 	msg.header.type = MCU_MSG_TYPE_DESTROY_CHANNEL;
1350 	msg.header.version = dev->fw_info->mailbox_version;
1351 
1352 	msg.channel_id = channel->mcu_channel_id;
1353 
1354 	allegro_mbox_send(dev->mbox_command, &msg);
1355 
1356 	return 0;
1357 }
1358 
1359 static int allegro_mcu_send_put_stream_buffer(struct allegro_dev *dev,
1360 					      struct allegro_channel *channel,
1361 					      dma_addr_t paddr,
1362 					      unsigned long size,
1363 					      u64 dst_handle)
1364 {
1365 	struct mcu_msg_put_stream_buffer msg;
1366 
1367 	memset(&msg, 0, sizeof(msg));
1368 
1369 	msg.header.type = MCU_MSG_TYPE_PUT_STREAM_BUFFER;
1370 	msg.header.version = dev->fw_info->mailbox_version;
1371 
1372 	msg.channel_id = channel->mcu_channel_id;
1373 	msg.dma_addr = to_codec_addr(dev, paddr);
1374 	msg.mcu_addr = to_mcu_addr(dev, paddr);
1375 	msg.size = size;
1376 	msg.offset = ENCODER_STREAM_OFFSET;
1377 	/* copied to mcu_msg_encode_frame_response */
1378 	msg.dst_handle = dst_handle;
1379 
1380 	allegro_mbox_send(dev->mbox_command, &msg);
1381 
1382 	return 0;
1383 }
1384 
1385 static int allegro_mcu_send_encode_frame(struct allegro_dev *dev,
1386 					 struct allegro_channel *channel,
1387 					 dma_addr_t src_y, dma_addr_t src_uv,
1388 					 u64 src_handle)
1389 {
1390 	struct mcu_msg_encode_frame msg;
1391 	bool use_encoder_buffer = v4l2_ctrl_g_ctrl(channel->encoder_buffer);
1392 
1393 	memset(&msg, 0, sizeof(msg));
1394 
1395 	msg.header.type = MCU_MSG_TYPE_ENCODE_FRAME;
1396 	msg.header.version = dev->fw_info->mailbox_version;
1397 
1398 	msg.channel_id = channel->mcu_channel_id;
1399 	msg.encoding_options = AL_OPT_FORCE_LOAD;
1400 	if (use_encoder_buffer)
1401 		msg.encoding_options |= AL_OPT_USE_L2;
1402 	msg.pps_qp = 26; /* qp are relative to 26 */
1403 	msg.user_param = 0; /* copied to mcu_msg_encode_frame_response */
1404 	/* src_handle is copied to mcu_msg_encode_frame_response */
1405 	msg.src_handle = src_handle;
1406 	msg.src_y = to_codec_addr(dev, src_y);
1407 	msg.src_uv = to_codec_addr(dev, src_uv);
1408 	msg.stride = channel->stride;
1409 
1410 	allegro_mbox_send(dev->mbox_command, &msg);
1411 
1412 	return 0;
1413 }
1414 
1415 static int allegro_mcu_wait_for_init_timeout(struct allegro_dev *dev,
1416 					     unsigned long timeout_ms)
1417 {
1418 	unsigned long time_left;
1419 
1420 	time_left = wait_for_completion_timeout(&dev->init_complete,
1421 						msecs_to_jiffies(timeout_ms));
1422 	if (time_left == 0)
1423 		return -ETIMEDOUT;
1424 
1425 	reinit_completion(&dev->init_complete);
1426 	return 0;
1427 }
1428 
1429 static int allegro_mcu_push_buffer_internal(struct allegro_channel *channel,
1430 					    enum mcu_msg_type type)
1431 {
1432 	struct allegro_dev *dev = channel->dev;
1433 	struct mcu_msg_push_buffers_internal *msg;
1434 	struct mcu_msg_push_buffers_internal_buffer *buffer;
1435 	unsigned int num_buffers = 0;
1436 	size_t size;
1437 	struct allegro_buffer *al_buffer;
1438 	struct list_head *list;
1439 	int err;
1440 
1441 	switch (type) {
1442 	case MCU_MSG_TYPE_PUSH_BUFFER_REFERENCE:
1443 		list = &channel->buffers_reference;
1444 		break;
1445 	case MCU_MSG_TYPE_PUSH_BUFFER_INTERMEDIATE:
1446 		list = &channel->buffers_intermediate;
1447 		break;
1448 	default:
1449 		return -EINVAL;
1450 	}
1451 
1452 	list_for_each_entry(al_buffer, list, head)
1453 		num_buffers++;
1454 	size = struct_size(msg, buffer, num_buffers);
1455 
1456 	msg = kmalloc(size, GFP_KERNEL);
1457 	if (!msg)
1458 		return -ENOMEM;
1459 
1460 	msg->header.type = type;
1461 	msg->header.version = dev->fw_info->mailbox_version;
1462 
1463 	msg->channel_id = channel->mcu_channel_id;
1464 	msg->num_buffers = num_buffers;
1465 
1466 	buffer = msg->buffer;
1467 	list_for_each_entry(al_buffer, list, head) {
1468 		buffer->dma_addr = to_codec_addr(dev, al_buffer->paddr);
1469 		buffer->mcu_addr = to_mcu_addr(dev, al_buffer->paddr);
1470 		buffer->size = to_mcu_size(dev, al_buffer->size);
1471 		buffer++;
1472 	}
1473 
1474 	err = allegro_mbox_send(dev->mbox_command, msg);
1475 
1476 	kfree(msg);
1477 	return err;
1478 }
1479 
1480 static int allegro_mcu_push_buffer_intermediate(struct allegro_channel *channel)
1481 {
1482 	enum mcu_msg_type type = MCU_MSG_TYPE_PUSH_BUFFER_INTERMEDIATE;
1483 
1484 	return allegro_mcu_push_buffer_internal(channel, type);
1485 }
1486 
1487 static int allegro_mcu_push_buffer_reference(struct allegro_channel *channel)
1488 {
1489 	enum mcu_msg_type type = MCU_MSG_TYPE_PUSH_BUFFER_REFERENCE;
1490 
1491 	return allegro_mcu_push_buffer_internal(channel, type);
1492 }
1493 
1494 static int allocate_buffers_internal(struct allegro_channel *channel,
1495 				     struct list_head *list,
1496 				     size_t n, size_t size)
1497 {
1498 	struct allegro_dev *dev = channel->dev;
1499 	unsigned int i;
1500 	int err;
1501 	struct allegro_buffer *buffer, *tmp;
1502 
1503 	for (i = 0; i < n; i++) {
1504 		buffer = kmalloc(sizeof(*buffer), GFP_KERNEL);
1505 		if (!buffer) {
1506 			err = -ENOMEM;
1507 			goto err;
1508 		}
1509 		INIT_LIST_HEAD(&buffer->head);
1510 
1511 		err = allegro_alloc_buffer(dev, buffer, size);
1512 		if (err)
1513 			goto err;
1514 		list_add(&buffer->head, list);
1515 	}
1516 
1517 	return 0;
1518 
1519 err:
1520 	list_for_each_entry_safe(buffer, tmp, list, head) {
1521 		list_del(&buffer->head);
1522 		allegro_free_buffer(dev, buffer);
1523 		kfree(buffer);
1524 	}
1525 	return err;
1526 }
1527 
1528 static void destroy_buffers_internal(struct allegro_channel *channel,
1529 				     struct list_head *list)
1530 {
1531 	struct allegro_dev *dev = channel->dev;
1532 	struct allegro_buffer *buffer, *tmp;
1533 
1534 	list_for_each_entry_safe(buffer, tmp, list, head) {
1535 		list_del(&buffer->head);
1536 		allegro_free_buffer(dev, buffer);
1537 		kfree(buffer);
1538 	}
1539 }
1540 
1541 static void destroy_reference_buffers(struct allegro_channel *channel)
1542 {
1543 	return destroy_buffers_internal(channel, &channel->buffers_reference);
1544 }
1545 
1546 static void destroy_intermediate_buffers(struct allegro_channel *channel)
1547 {
1548 	return destroy_buffers_internal(channel,
1549 					&channel->buffers_intermediate);
1550 }
1551 
1552 static int allocate_intermediate_buffers(struct allegro_channel *channel,
1553 					 size_t n, size_t size)
1554 {
1555 	return allocate_buffers_internal(channel,
1556 					 &channel->buffers_intermediate,
1557 					 n, size);
1558 }
1559 
1560 static int allocate_reference_buffers(struct allegro_channel *channel,
1561 				      size_t n, size_t size)
1562 {
1563 	return allocate_buffers_internal(channel,
1564 					 &channel->buffers_reference,
1565 					 n, PAGE_ALIGN(size));
1566 }
1567 
1568 static ssize_t allegro_h264_write_sps(struct allegro_channel *channel,
1569 				      void *dest, size_t n)
1570 {
1571 	struct allegro_dev *dev = channel->dev;
1572 	struct nal_h264_sps *sps;
1573 	ssize_t size;
1574 	unsigned int size_mb = SIZE_MACROBLOCK;
1575 	/* Calculation of crop units in Rec. ITU-T H.264 (04/2017) p. 76 */
1576 	unsigned int crop_unit_x = 2;
1577 	unsigned int crop_unit_y = 2;
1578 	enum v4l2_mpeg_video_h264_profile profile;
1579 	enum v4l2_mpeg_video_h264_level level;
1580 	unsigned int cpb_size;
1581 	unsigned int cpb_size_scale;
1582 
1583 	sps = kzalloc(sizeof(*sps), GFP_KERNEL);
1584 	if (!sps)
1585 		return -ENOMEM;
1586 
1587 	profile = v4l2_ctrl_g_ctrl(channel->mpeg_video_h264_profile);
1588 	level = v4l2_ctrl_g_ctrl(channel->mpeg_video_h264_level);
1589 
1590 	sps->profile_idc = nal_h264_profile(profile);
1591 	sps->constraint_set0_flag = 0;
1592 	sps->constraint_set1_flag = 1;
1593 	sps->constraint_set2_flag = 0;
1594 	sps->constraint_set3_flag = 0;
1595 	sps->constraint_set4_flag = 0;
1596 	sps->constraint_set5_flag = 0;
1597 	sps->level_idc = nal_h264_level(level);
1598 	sps->seq_parameter_set_id = 0;
1599 	sps->log2_max_frame_num_minus4 = LOG2_MAX_FRAME_NUM - 4;
1600 	sps->pic_order_cnt_type = 0;
1601 	sps->log2_max_pic_order_cnt_lsb_minus4 = LOG2_MAX_PIC_ORDER_CNT - 4;
1602 	sps->max_num_ref_frames = 3;
1603 	sps->gaps_in_frame_num_value_allowed_flag = 0;
1604 	sps->pic_width_in_mbs_minus1 =
1605 		DIV_ROUND_UP(channel->width, size_mb) - 1;
1606 	sps->pic_height_in_map_units_minus1 =
1607 		DIV_ROUND_UP(channel->height, size_mb) - 1;
1608 	sps->frame_mbs_only_flag = 1;
1609 	sps->mb_adaptive_frame_field_flag = 0;
1610 	sps->direct_8x8_inference_flag = 1;
1611 	sps->frame_cropping_flag =
1612 		(channel->width % size_mb) || (channel->height % size_mb);
1613 	if (sps->frame_cropping_flag) {
1614 		sps->crop_left = 0;
1615 		sps->crop_right = (round_up(channel->width, size_mb) - channel->width) / crop_unit_x;
1616 		sps->crop_top = 0;
1617 		sps->crop_bottom = (round_up(channel->height, size_mb) - channel->height) / crop_unit_y;
1618 	}
1619 	sps->vui_parameters_present_flag = 1;
1620 	sps->vui.aspect_ratio_info_present_flag = 0;
1621 	sps->vui.overscan_info_present_flag = 0;
1622 
1623 	sps->vui.video_signal_type_present_flag = 1;
1624 	sps->vui.video_format = 5; /* unspecified */
1625 	sps->vui.video_full_range_flag = nal_h264_full_range(channel->quantization);
1626 	sps->vui.colour_description_present_flag = 1;
1627 	sps->vui.colour_primaries = nal_h264_color_primaries(channel->colorspace);
1628 	sps->vui.transfer_characteristics =
1629 		nal_h264_transfer_characteristics(channel->colorspace, channel->xfer_func);
1630 	sps->vui.matrix_coefficients =
1631 		nal_h264_matrix_coeffs(channel->colorspace, channel->ycbcr_enc);
1632 
1633 	sps->vui.chroma_loc_info_present_flag = 1;
1634 	sps->vui.chroma_sample_loc_type_top_field = 0;
1635 	sps->vui.chroma_sample_loc_type_bottom_field = 0;
1636 
1637 	sps->vui.timing_info_present_flag = 1;
1638 	sps->vui.num_units_in_tick = channel->framerate.denominator;
1639 	sps->vui.time_scale = 2 * channel->framerate.numerator;
1640 
1641 	sps->vui.fixed_frame_rate_flag = 1;
1642 	sps->vui.nal_hrd_parameters_present_flag = 0;
1643 	sps->vui.vcl_hrd_parameters_present_flag = 1;
1644 	sps->vui.vcl_hrd_parameters.cpb_cnt_minus1 = 0;
1645 	/* See Rec. ITU-T H.264 (04/2017) p. 410 E-53 */
1646 	sps->vui.vcl_hrd_parameters.bit_rate_scale =
1647 		ffs(channel->bitrate_peak) - 6;
1648 	sps->vui.vcl_hrd_parameters.bit_rate_value_minus1[0] =
1649 		channel->bitrate_peak / (1 << (6 + sps->vui.vcl_hrd_parameters.bit_rate_scale)) - 1;
1650 	/* See Rec. ITU-T H.264 (04/2017) p. 410 E-54 */
1651 	cpb_size = v4l2_ctrl_g_ctrl(channel->mpeg_video_cpb_size);
1652 	cpb_size_scale = ffs(cpb_size) - 4;
1653 	sps->vui.vcl_hrd_parameters.cpb_size_scale = cpb_size_scale;
1654 	sps->vui.vcl_hrd_parameters.cpb_size_value_minus1[0] =
1655 		(cpb_size * 1000) / (1 << (4 + cpb_size_scale)) - 1;
1656 	sps->vui.vcl_hrd_parameters.cbr_flag[0] =
1657 		!v4l2_ctrl_g_ctrl(channel->mpeg_video_frame_rc_enable);
1658 	sps->vui.vcl_hrd_parameters.initial_cpb_removal_delay_length_minus1 = 31;
1659 	sps->vui.vcl_hrd_parameters.cpb_removal_delay_length_minus1 = 31;
1660 	sps->vui.vcl_hrd_parameters.dpb_output_delay_length_minus1 = 31;
1661 	sps->vui.vcl_hrd_parameters.time_offset_length = 0;
1662 	sps->vui.low_delay_hrd_flag = 0;
1663 	sps->vui.pic_struct_present_flag = 1;
1664 	sps->vui.bitstream_restriction_flag = 0;
1665 
1666 	size = nal_h264_write_sps(&dev->plat_dev->dev, dest, n, sps);
1667 
1668 	kfree(sps);
1669 
1670 	return size;
1671 }
1672 
1673 static ssize_t allegro_h264_write_pps(struct allegro_channel *channel,
1674 				      void *dest, size_t n)
1675 {
1676 	struct allegro_dev *dev = channel->dev;
1677 	struct nal_h264_pps *pps;
1678 	ssize_t size;
1679 
1680 	pps = kzalloc(sizeof(*pps), GFP_KERNEL);
1681 	if (!pps)
1682 		return -ENOMEM;
1683 
1684 	pps->pic_parameter_set_id = 0;
1685 	pps->seq_parameter_set_id = 0;
1686 	pps->entropy_coding_mode_flag = 0;
1687 	pps->bottom_field_pic_order_in_frame_present_flag = 0;
1688 	pps->num_slice_groups_minus1 = 0;
1689 	pps->num_ref_idx_l0_default_active_minus1 = channel->num_ref_idx_l0 - 1;
1690 	pps->num_ref_idx_l1_default_active_minus1 = channel->num_ref_idx_l1 - 1;
1691 	pps->weighted_pred_flag = 0;
1692 	pps->weighted_bipred_idc = 0;
1693 	pps->pic_init_qp_minus26 = 0;
1694 	pps->pic_init_qs_minus26 = 0;
1695 	pps->chroma_qp_index_offset = 0;
1696 	pps->deblocking_filter_control_present_flag = 1;
1697 	pps->constrained_intra_pred_flag = 0;
1698 	pps->redundant_pic_cnt_present_flag = 0;
1699 	pps->transform_8x8_mode_flag = 0;
1700 	pps->pic_scaling_matrix_present_flag = 0;
1701 	pps->second_chroma_qp_index_offset = 0;
1702 
1703 	size = nal_h264_write_pps(&dev->plat_dev->dev, dest, n, pps);
1704 
1705 	kfree(pps);
1706 
1707 	return size;
1708 }
1709 
1710 static void allegro_channel_eos_event(struct allegro_channel *channel)
1711 {
1712 	const struct v4l2_event eos_event = {
1713 		.type = V4L2_EVENT_EOS
1714 	};
1715 
1716 	v4l2_event_queue_fh(&channel->fh, &eos_event);
1717 }
1718 
1719 static ssize_t allegro_hevc_write_vps(struct allegro_channel *channel,
1720 				      void *dest, size_t n)
1721 {
1722 	struct allegro_dev *dev = channel->dev;
1723 	struct nal_hevc_vps *vps;
1724 	struct nal_hevc_profile_tier_level *ptl;
1725 	ssize_t size;
1726 	unsigned int num_ref_frames = channel->num_ref_idx_l0;
1727 	s32 profile = v4l2_ctrl_g_ctrl(channel->mpeg_video_hevc_profile);
1728 	s32 level = v4l2_ctrl_g_ctrl(channel->mpeg_video_hevc_level);
1729 	s32 tier = v4l2_ctrl_g_ctrl(channel->mpeg_video_hevc_tier);
1730 
1731 	vps = kzalloc(sizeof(*vps), GFP_KERNEL);
1732 	if (!vps)
1733 		return -ENOMEM;
1734 
1735 	vps->base_layer_internal_flag = 1;
1736 	vps->base_layer_available_flag = 1;
1737 	vps->temporal_id_nesting_flag = 1;
1738 
1739 	ptl = &vps->profile_tier_level;
1740 	ptl->general_profile_idc = nal_hevc_profile(profile);
1741 	ptl->general_profile_compatibility_flag[ptl->general_profile_idc] = 1;
1742 	ptl->general_tier_flag = nal_hevc_tier(tier);
1743 	ptl->general_progressive_source_flag = 1;
1744 	ptl->general_frame_only_constraint_flag = 1;
1745 	ptl->general_level_idc = nal_hevc_level(level);
1746 
1747 	vps->sub_layer_ordering_info_present_flag = 0;
1748 	vps->max_dec_pic_buffering_minus1[0] = num_ref_frames;
1749 	vps->max_num_reorder_pics[0] = num_ref_frames;
1750 
1751 	size = nal_hevc_write_vps(&dev->plat_dev->dev, dest, n, vps);
1752 
1753 	kfree(vps);
1754 
1755 	return size;
1756 }
1757 
1758 static ssize_t allegro_hevc_write_sps(struct allegro_channel *channel,
1759 				      void *dest, size_t n)
1760 {
1761 	struct allegro_dev *dev = channel->dev;
1762 	struct nal_hevc_sps *sps;
1763 	struct nal_hevc_profile_tier_level *ptl;
1764 	struct nal_hevc_vui_parameters *vui;
1765 	struct nal_hevc_hrd_parameters *hrd;
1766 	ssize_t size;
1767 	unsigned int cpb_size;
1768 	unsigned int num_ref_frames = channel->num_ref_idx_l0;
1769 	s32 profile = v4l2_ctrl_g_ctrl(channel->mpeg_video_hevc_profile);
1770 	s32 level = v4l2_ctrl_g_ctrl(channel->mpeg_video_hevc_level);
1771 	s32 tier = v4l2_ctrl_g_ctrl(channel->mpeg_video_hevc_tier);
1772 
1773 	sps = kzalloc(sizeof(*sps), GFP_KERNEL);
1774 	if (!sps)
1775 		return -ENOMEM;
1776 
1777 	sps->temporal_id_nesting_flag = 1;
1778 
1779 	ptl = &sps->profile_tier_level;
1780 	ptl->general_profile_idc = nal_hevc_profile(profile);
1781 	ptl->general_profile_compatibility_flag[ptl->general_profile_idc] = 1;
1782 	ptl->general_tier_flag = nal_hevc_tier(tier);
1783 	ptl->general_progressive_source_flag = 1;
1784 	ptl->general_frame_only_constraint_flag = 1;
1785 	ptl->general_level_idc = nal_hevc_level(level);
1786 
1787 	sps->seq_parameter_set_id = 0;
1788 	sps->chroma_format_idc = 1; /* Only 4:2:0 sampling supported */
1789 	sps->pic_width_in_luma_samples = round_up(channel->width, 8);
1790 	sps->pic_height_in_luma_samples = round_up(channel->height, 8);
1791 	sps->conf_win_right_offset =
1792 		sps->pic_width_in_luma_samples - channel->width;
1793 	sps->conf_win_bottom_offset =
1794 		sps->pic_height_in_luma_samples - channel->height;
1795 	sps->conformance_window_flag =
1796 		sps->conf_win_right_offset || sps->conf_win_bottom_offset;
1797 
1798 	sps->log2_max_pic_order_cnt_lsb_minus4 = LOG2_MAX_PIC_ORDER_CNT - 4;
1799 
1800 	sps->sub_layer_ordering_info_present_flag = 1;
1801 	sps->max_dec_pic_buffering_minus1[0] = num_ref_frames;
1802 	sps->max_num_reorder_pics[0] = num_ref_frames;
1803 
1804 	sps->log2_min_luma_coding_block_size_minus3 =
1805 		channel->min_cu_size - 3;
1806 	sps->log2_diff_max_min_luma_coding_block_size =
1807 		channel->max_cu_size - channel->min_cu_size;
1808 	sps->log2_min_luma_transform_block_size_minus2 =
1809 		channel->min_tu_size - 2;
1810 	sps->log2_diff_max_min_luma_transform_block_size =
1811 		channel->max_tu_size - channel->min_tu_size;
1812 	sps->max_transform_hierarchy_depth_intra =
1813 		channel->max_transfo_depth_intra;
1814 	sps->max_transform_hierarchy_depth_inter =
1815 		channel->max_transfo_depth_inter;
1816 
1817 	sps->sps_temporal_mvp_enabled_flag = channel->temporal_mvp_enable;
1818 	sps->strong_intra_smoothing_enabled_flag = channel->max_cu_size > 4;
1819 
1820 	sps->vui_parameters_present_flag = 1;
1821 	vui = &sps->vui;
1822 
1823 	vui->video_signal_type_present_flag = 1;
1824 	vui->video_format = 5; /* unspecified */
1825 	vui->video_full_range_flag = nal_hevc_full_range(channel->quantization);
1826 	vui->colour_description_present_flag = 1;
1827 	vui->colour_primaries = nal_hevc_color_primaries(channel->colorspace);
1828 	vui->transfer_characteristics = nal_hevc_transfer_characteristics(channel->colorspace,
1829 									  channel->xfer_func);
1830 	vui->matrix_coeffs = nal_hevc_matrix_coeffs(channel->colorspace, channel->ycbcr_enc);
1831 
1832 	vui->chroma_loc_info_present_flag = 1;
1833 	vui->chroma_sample_loc_type_top_field = 0;
1834 	vui->chroma_sample_loc_type_bottom_field = 0;
1835 
1836 	vui->vui_timing_info_present_flag = 1;
1837 	vui->vui_num_units_in_tick = channel->framerate.denominator;
1838 	vui->vui_time_scale = channel->framerate.numerator;
1839 
1840 	vui->bitstream_restriction_flag = 1;
1841 	vui->motion_vectors_over_pic_boundaries_flag = 1;
1842 	vui->restricted_ref_pic_lists_flag = 1;
1843 	vui->log2_max_mv_length_horizontal = 15;
1844 	vui->log2_max_mv_length_vertical = 15;
1845 
1846 	vui->vui_hrd_parameters_present_flag = 1;
1847 	hrd = &vui->nal_hrd_parameters;
1848 	hrd->vcl_hrd_parameters_present_flag = 1;
1849 
1850 	hrd->initial_cpb_removal_delay_length_minus1 = 31;
1851 	hrd->au_cpb_removal_delay_length_minus1 = 30;
1852 	hrd->dpb_output_delay_length_minus1 = 30;
1853 
1854 	hrd->bit_rate_scale = ffs(channel->bitrate_peak) - 6;
1855 	hrd->vcl_hrd[0].bit_rate_value_minus1[0] =
1856 		(channel->bitrate_peak >> (6 + hrd->bit_rate_scale)) - 1;
1857 
1858 	cpb_size = v4l2_ctrl_g_ctrl(channel->mpeg_video_cpb_size) * 1000;
1859 	hrd->cpb_size_scale = ffs(cpb_size) - 4;
1860 	hrd->vcl_hrd[0].cpb_size_value_minus1[0] = (cpb_size >> (4 + hrd->cpb_size_scale)) - 1;
1861 
1862 	hrd->vcl_hrd[0].cbr_flag[0] = !v4l2_ctrl_g_ctrl(channel->mpeg_video_frame_rc_enable);
1863 
1864 	size = nal_hevc_write_sps(&dev->plat_dev->dev, dest, n, sps);
1865 
1866 	kfree(sps);
1867 
1868 	return size;
1869 }
1870 
1871 static ssize_t allegro_hevc_write_pps(struct allegro_channel *channel,
1872 				      struct mcu_msg_encode_frame_response *msg,
1873 				      void *dest, size_t n)
1874 {
1875 	struct allegro_dev *dev = channel->dev;
1876 	struct nal_hevc_pps *pps;
1877 	ssize_t size;
1878 	int i;
1879 
1880 	pps = kzalloc(sizeof(*pps), GFP_KERNEL);
1881 	if (!pps)
1882 		return -ENOMEM;
1883 
1884 	pps->pps_pic_parameter_set_id = 0;
1885 	pps->pps_seq_parameter_set_id = 0;
1886 
1887 	if (msg->num_column > 1 || msg->num_row > 1) {
1888 		pps->tiles_enabled_flag = 1;
1889 		pps->num_tile_columns_minus1 = msg->num_column - 1;
1890 		pps->num_tile_rows_minus1 = msg->num_row - 1;
1891 
1892 		for (i = 0; i < msg->num_column; i++)
1893 			pps->column_width_minus1[i] = msg->tile_width[i] - 1;
1894 
1895 		for (i = 0; i < msg->num_row; i++)
1896 			pps->row_height_minus1[i] = msg->tile_height[i] - 1;
1897 	}
1898 
1899 	pps->loop_filter_across_tiles_enabled_flag =
1900 		channel->enable_loop_filter_across_tiles;
1901 	pps->pps_loop_filter_across_slices_enabled_flag =
1902 		channel->enable_loop_filter_across_slices;
1903 	pps->deblocking_filter_control_present_flag = 1;
1904 	pps->deblocking_filter_override_enabled_flag =
1905 		channel->enable_deblocking_filter_override;
1906 	pps->pps_beta_offset_div2 = BETA_OFFSET_DIV_2;
1907 	pps->pps_tc_offset_div2 = TC_OFFSET_DIV_2;
1908 
1909 	pps->lists_modification_present_flag = channel->enable_reordering;
1910 
1911 	size = nal_hevc_write_pps(&dev->plat_dev->dev, dest, n, pps);
1912 
1913 	kfree(pps);
1914 
1915 	return size;
1916 }
1917 
1918 static u64 allegro_put_buffer(struct allegro_channel *channel,
1919 			      struct list_head *list,
1920 			      struct vb2_v4l2_buffer *buffer)
1921 {
1922 	struct v4l2_m2m_buffer *b = container_of(buffer,
1923 						 struct v4l2_m2m_buffer, vb);
1924 	struct allegro_m2m_buffer *shadow = to_allegro_m2m_buffer(b);
1925 
1926 	mutex_lock(&channel->shadow_list_lock);
1927 	list_add_tail(&shadow->head, list);
1928 	mutex_unlock(&channel->shadow_list_lock);
1929 
1930 	return ptr_to_u64(buffer);
1931 }
1932 
1933 static struct vb2_v4l2_buffer *
1934 allegro_get_buffer(struct allegro_channel *channel,
1935 		   struct list_head *list, u64 handle)
1936 {
1937 	struct allegro_m2m_buffer *shadow, *tmp;
1938 	struct vb2_v4l2_buffer *buffer = NULL;
1939 
1940 	mutex_lock(&channel->shadow_list_lock);
1941 	list_for_each_entry_safe(shadow, tmp, list, head) {
1942 		if (handle == ptr_to_u64(&shadow->buf.vb)) {
1943 			buffer = &shadow->buf.vb;
1944 			list_del_init(&shadow->head);
1945 			break;
1946 		}
1947 	}
1948 	mutex_unlock(&channel->shadow_list_lock);
1949 
1950 	return buffer;
1951 }
1952 
1953 static void allegro_channel_finish_frame(struct allegro_channel *channel,
1954 		struct mcu_msg_encode_frame_response *msg)
1955 {
1956 	struct allegro_dev *dev = channel->dev;
1957 	struct vb2_v4l2_buffer *src_buf;
1958 	struct vb2_v4l2_buffer *dst_buf;
1959 	struct {
1960 		u32 offset;
1961 		u32 size;
1962 	} *partition;
1963 	enum vb2_buffer_state state = VB2_BUF_STATE_ERROR;
1964 	char *curr;
1965 	ssize_t len;
1966 	ssize_t free;
1967 
1968 	src_buf = allegro_get_buffer(channel, &channel->source_shadow_list,
1969 				     msg->src_handle);
1970 	if (!src_buf)
1971 		v4l2_warn(&dev->v4l2_dev,
1972 			  "channel %d: invalid source buffer\n",
1973 			  channel->mcu_channel_id);
1974 
1975 	dst_buf = allegro_get_buffer(channel, &channel->stream_shadow_list,
1976 				     msg->dst_handle);
1977 	if (!dst_buf)
1978 		v4l2_warn(&dev->v4l2_dev,
1979 			  "channel %d: invalid stream buffer\n",
1980 			  channel->mcu_channel_id);
1981 
1982 	if (!src_buf || !dst_buf)
1983 		goto err;
1984 
1985 	if (v4l2_m2m_is_last_draining_src_buf(channel->fh.m2m_ctx, src_buf)) {
1986 		dst_buf->flags |= V4L2_BUF_FLAG_LAST;
1987 		allegro_channel_eos_event(channel);
1988 		v4l2_m2m_mark_stopped(channel->fh.m2m_ctx);
1989 	}
1990 
1991 	dst_buf->sequence = channel->csequence++;
1992 
1993 	if (msg->error_code & AL_ERROR) {
1994 		v4l2_err(&dev->v4l2_dev,
1995 			 "channel %d: failed to encode frame: %s (%x)\n",
1996 			 channel->mcu_channel_id,
1997 			 allegro_err_to_string(msg->error_code),
1998 			 msg->error_code);
1999 		goto err;
2000 	}
2001 
2002 	if (msg->partition_table_size != 1) {
2003 		v4l2_warn(&dev->v4l2_dev,
2004 			  "channel %d: only handling first partition table entry (%d entries)\n",
2005 			  channel->mcu_channel_id, msg->partition_table_size);
2006 	}
2007 
2008 	if (msg->partition_table_offset +
2009 	    msg->partition_table_size * sizeof(*partition) >
2010 	    vb2_plane_size(&dst_buf->vb2_buf, 0)) {
2011 		v4l2_err(&dev->v4l2_dev,
2012 			 "channel %d: partition table outside of dst_buf\n",
2013 			 channel->mcu_channel_id);
2014 		goto err;
2015 	}
2016 
2017 	partition =
2018 	    vb2_plane_vaddr(&dst_buf->vb2_buf, 0) + msg->partition_table_offset;
2019 	if (partition->offset + partition->size >
2020 	    vb2_plane_size(&dst_buf->vb2_buf, 0)) {
2021 		v4l2_err(&dev->v4l2_dev,
2022 			 "channel %d: encoded frame is outside of dst_buf (offset 0x%x, size 0x%x)\n",
2023 			 channel->mcu_channel_id, partition->offset,
2024 			 partition->size);
2025 		goto err;
2026 	}
2027 
2028 	v4l2_dbg(2, debug, &dev->v4l2_dev,
2029 		 "channel %d: encoded frame of size %d is at offset 0x%x\n",
2030 		 channel->mcu_channel_id, partition->size, partition->offset);
2031 
2032 	/*
2033 	 * The payload must include the data before the partition offset,
2034 	 * because we will put the sps and pps data there.
2035 	 */
2036 	vb2_set_plane_payload(&dst_buf->vb2_buf, 0,
2037 			      partition->offset + partition->size);
2038 
2039 	curr = vb2_plane_vaddr(&dst_buf->vb2_buf, 0);
2040 	free = partition->offset;
2041 
2042 	if (channel->codec == V4L2_PIX_FMT_HEVC && msg->is_idr) {
2043 		len = allegro_hevc_write_vps(channel, curr, free);
2044 		if (len < 0) {
2045 			v4l2_err(&dev->v4l2_dev,
2046 				 "not enough space for video parameter set: %zd left\n",
2047 				 free);
2048 			goto err;
2049 		}
2050 		curr += len;
2051 		free -= len;
2052 		v4l2_dbg(1, debug, &dev->v4l2_dev,
2053 			 "channel %d: wrote %zd byte VPS nal unit\n",
2054 			 channel->mcu_channel_id, len);
2055 	}
2056 
2057 	if (msg->is_idr) {
2058 		if (channel->codec == V4L2_PIX_FMT_H264)
2059 			len = allegro_h264_write_sps(channel, curr, free);
2060 		else
2061 			len = allegro_hevc_write_sps(channel, curr, free);
2062 		if (len < 0) {
2063 			v4l2_err(&dev->v4l2_dev,
2064 				 "not enough space for sequence parameter set: %zd left\n",
2065 				 free);
2066 			goto err;
2067 		}
2068 		curr += len;
2069 		free -= len;
2070 		v4l2_dbg(1, debug, &dev->v4l2_dev,
2071 			 "channel %d: wrote %zd byte SPS nal unit\n",
2072 			 channel->mcu_channel_id, len);
2073 	}
2074 
2075 	if (msg->slice_type == AL_ENC_SLICE_TYPE_I) {
2076 		if (channel->codec == V4L2_PIX_FMT_H264)
2077 			len = allegro_h264_write_pps(channel, curr, free);
2078 		else
2079 			len = allegro_hevc_write_pps(channel, msg, curr, free);
2080 		if (len < 0) {
2081 			v4l2_err(&dev->v4l2_dev,
2082 				 "not enough space for picture parameter set: %zd left\n",
2083 				 free);
2084 			goto err;
2085 		}
2086 		curr += len;
2087 		free -= len;
2088 		v4l2_dbg(1, debug, &dev->v4l2_dev,
2089 			 "channel %d: wrote %zd byte PPS nal unit\n",
2090 			 channel->mcu_channel_id, len);
2091 	}
2092 
2093 	if (msg->slice_type != AL_ENC_SLICE_TYPE_I && !msg->is_idr) {
2094 		dst_buf->vb2_buf.planes[0].data_offset = free;
2095 		free = 0;
2096 	} else {
2097 		if (channel->codec == V4L2_PIX_FMT_H264)
2098 			len = nal_h264_write_filler(&dev->plat_dev->dev, curr, free);
2099 		else
2100 			len = nal_hevc_write_filler(&dev->plat_dev->dev, curr, free);
2101 		if (len < 0) {
2102 			v4l2_err(&dev->v4l2_dev,
2103 				 "failed to write %zd filler data\n", free);
2104 			goto err;
2105 		}
2106 		curr += len;
2107 		free -= len;
2108 		v4l2_dbg(2, debug, &dev->v4l2_dev,
2109 			 "channel %d: wrote %zd bytes filler nal unit\n",
2110 			 channel->mcu_channel_id, len);
2111 	}
2112 
2113 	if (free != 0) {
2114 		v4l2_err(&dev->v4l2_dev,
2115 			 "non-VCL NAL units do not fill space until VCL NAL unit: %zd bytes left\n",
2116 			 free);
2117 		goto err;
2118 	}
2119 
2120 	state = VB2_BUF_STATE_DONE;
2121 
2122 	v4l2_m2m_buf_copy_metadata(src_buf, dst_buf, false);
2123 	if (msg->is_idr)
2124 		dst_buf->flags |= V4L2_BUF_FLAG_KEYFRAME;
2125 	else
2126 		dst_buf->flags |= V4L2_BUF_FLAG_PFRAME;
2127 
2128 	v4l2_dbg(1, debug, &dev->v4l2_dev,
2129 		 "channel %d: encoded frame #%03d (%s%s, QP %d, %d bytes)\n",
2130 		 channel->mcu_channel_id,
2131 		 dst_buf->sequence,
2132 		 msg->is_idr ? "IDR, " : "",
2133 		 msg->slice_type == AL_ENC_SLICE_TYPE_I ? "I slice" :
2134 		 msg->slice_type == AL_ENC_SLICE_TYPE_P ? "P slice" : "unknown",
2135 		 msg->qp, partition->size);
2136 
2137 err:
2138 	if (src_buf)
2139 		v4l2_m2m_buf_done(src_buf, VB2_BUF_STATE_DONE);
2140 
2141 	if (dst_buf)
2142 		v4l2_m2m_buf_done(dst_buf, state);
2143 }
2144 
2145 static int allegro_handle_init(struct allegro_dev *dev,
2146 			       struct mcu_msg_init_response *msg)
2147 {
2148 	complete(&dev->init_complete);
2149 
2150 	return 0;
2151 }
2152 
2153 static int
2154 allegro_handle_create_channel(struct allegro_dev *dev,
2155 			      struct mcu_msg_create_channel_response *msg)
2156 {
2157 	struct allegro_channel *channel;
2158 	int err = 0;
2159 	struct create_channel_param param;
2160 
2161 	channel = allegro_find_channel_by_user_id(dev, msg->user_id);
2162 	if (IS_ERR(channel)) {
2163 		v4l2_warn(&dev->v4l2_dev,
2164 			  "received %s for unknown user %d\n",
2165 			  msg_type_name(msg->header.type),
2166 			  msg->user_id);
2167 		return -EINVAL;
2168 	}
2169 
2170 	if (msg->error_code) {
2171 		v4l2_err(&dev->v4l2_dev,
2172 			 "user %d: mcu failed to create channel: %s (%x)\n",
2173 			 channel->user_id,
2174 			 allegro_err_to_string(msg->error_code),
2175 			 msg->error_code);
2176 		err = -EIO;
2177 		goto out;
2178 	}
2179 
2180 	channel->mcu_channel_id = msg->channel_id;
2181 	v4l2_dbg(1, debug, &dev->v4l2_dev,
2182 		 "user %d: channel has channel id %d\n",
2183 		 channel->user_id, channel->mcu_channel_id);
2184 
2185 	err = allegro_decode_config_blob(&param, msg, channel->config_blob.vaddr);
2186 	allegro_free_buffer(channel->dev, &channel->config_blob);
2187 	if (err)
2188 		goto out;
2189 
2190 	channel->num_ref_idx_l0 = param.num_ref_idx_l0;
2191 	channel->num_ref_idx_l1 = param.num_ref_idx_l1;
2192 
2193 	v4l2_dbg(1, debug, &dev->v4l2_dev,
2194 		 "channel %d: intermediate buffers: %d x %d bytes\n",
2195 		 channel->mcu_channel_id,
2196 		 msg->int_buffers_count, msg->int_buffers_size);
2197 	err = allocate_intermediate_buffers(channel, msg->int_buffers_count,
2198 					    msg->int_buffers_size);
2199 	if (err) {
2200 		v4l2_err(&dev->v4l2_dev,
2201 			 "channel %d: failed to allocate intermediate buffers\n",
2202 			 channel->mcu_channel_id);
2203 		goto out;
2204 	}
2205 	err = allegro_mcu_push_buffer_intermediate(channel);
2206 	if (err)
2207 		goto out;
2208 
2209 	v4l2_dbg(1, debug, &dev->v4l2_dev,
2210 		 "channel %d: reference buffers: %d x %d bytes\n",
2211 		 channel->mcu_channel_id,
2212 		 msg->rec_buffers_count, msg->rec_buffers_size);
2213 	err = allocate_reference_buffers(channel, msg->rec_buffers_count,
2214 					 msg->rec_buffers_size);
2215 	if (err) {
2216 		v4l2_err(&dev->v4l2_dev,
2217 			 "channel %d: failed to allocate reference buffers\n",
2218 			 channel->mcu_channel_id);
2219 		goto out;
2220 	}
2221 	err = allegro_mcu_push_buffer_reference(channel);
2222 	if (err)
2223 		goto out;
2224 
2225 out:
2226 	channel->error = err;
2227 	complete(&channel->completion);
2228 
2229 	/* Handled successfully, error is passed via channel->error */
2230 	return 0;
2231 }
2232 
2233 static int
2234 allegro_handle_destroy_channel(struct allegro_dev *dev,
2235 			       struct mcu_msg_destroy_channel_response *msg)
2236 {
2237 	struct allegro_channel *channel;
2238 
2239 	channel = allegro_find_channel_by_channel_id(dev, msg->channel_id);
2240 	if (IS_ERR(channel)) {
2241 		v4l2_err(&dev->v4l2_dev,
2242 			 "received %s for unknown channel %d\n",
2243 			 msg_type_name(msg->header.type),
2244 			 msg->channel_id);
2245 		return -EINVAL;
2246 	}
2247 
2248 	v4l2_dbg(2, debug, &dev->v4l2_dev,
2249 		 "user %d: vcu destroyed channel %d\n",
2250 		 channel->user_id, channel->mcu_channel_id);
2251 	complete(&channel->completion);
2252 
2253 	return 0;
2254 }
2255 
2256 static int
2257 allegro_handle_encode_frame(struct allegro_dev *dev,
2258 			    struct mcu_msg_encode_frame_response *msg)
2259 {
2260 	struct allegro_channel *channel;
2261 
2262 	channel = allegro_find_channel_by_channel_id(dev, msg->channel_id);
2263 	if (IS_ERR(channel)) {
2264 		v4l2_err(&dev->v4l2_dev,
2265 			 "received %s for unknown channel %d\n",
2266 			 msg_type_name(msg->header.type),
2267 			 msg->channel_id);
2268 		return -EINVAL;
2269 	}
2270 
2271 	allegro_channel_finish_frame(channel, msg);
2272 
2273 	return 0;
2274 }
2275 
2276 static void allegro_handle_message(struct allegro_dev *dev,
2277 				   union mcu_msg_response *msg)
2278 {
2279 	switch (msg->header.type) {
2280 	case MCU_MSG_TYPE_INIT:
2281 		allegro_handle_init(dev, &msg->init);
2282 		break;
2283 	case MCU_MSG_TYPE_CREATE_CHANNEL:
2284 		allegro_handle_create_channel(dev, &msg->create_channel);
2285 		break;
2286 	case MCU_MSG_TYPE_DESTROY_CHANNEL:
2287 		allegro_handle_destroy_channel(dev, &msg->destroy_channel);
2288 		break;
2289 	case MCU_MSG_TYPE_ENCODE_FRAME:
2290 		allegro_handle_encode_frame(dev, &msg->encode_frame);
2291 		break;
2292 	default:
2293 		v4l2_warn(&dev->v4l2_dev,
2294 			  "%s: unknown message %s\n",
2295 			  __func__, msg_type_name(msg->header.type));
2296 		break;
2297 	}
2298 }
2299 
2300 static irqreturn_t allegro_hardirq(int irq, void *data)
2301 {
2302 	struct allegro_dev *dev = data;
2303 	unsigned int status;
2304 
2305 	regmap_read(dev->regmap, AL5_ITC_CPU_IRQ_STA, &status);
2306 	if (!(status & AL5_ITC_CPU_IRQ_STA_TRIGGERED))
2307 		return IRQ_NONE;
2308 
2309 	regmap_write(dev->regmap, AL5_ITC_CPU_IRQ_CLR, status);
2310 
2311 	return IRQ_WAKE_THREAD;
2312 }
2313 
2314 static irqreturn_t allegro_irq_thread(int irq, void *data)
2315 {
2316 	struct allegro_dev *dev = data;
2317 
2318 	/*
2319 	 * The firmware is initialized after the mailbox is setup. We further
2320 	 * check the AL5_ITC_CPU_IRQ_STA register, if the firmware actually
2321 	 * triggered the interrupt. Although this should not happen, make sure
2322 	 * that we ignore interrupts, if the mailbox is not initialized.
2323 	 */
2324 	if (!dev->mbox_status)
2325 		return IRQ_NONE;
2326 
2327 	allegro_mbox_notify(dev->mbox_status);
2328 
2329 	return IRQ_HANDLED;
2330 }
2331 
2332 static void allegro_copy_firmware(struct allegro_dev *dev,
2333 				  const u8 * const buf, size_t size)
2334 {
2335 	int err = 0;
2336 
2337 	v4l2_dbg(1, debug, &dev->v4l2_dev,
2338 		 "copy mcu firmware (%zu B) to SRAM\n", size);
2339 	err = regmap_bulk_write(dev->sram, 0x0, buf, size / 4);
2340 	if (err)
2341 		v4l2_err(&dev->v4l2_dev,
2342 			 "failed to copy firmware: %d\n", err);
2343 }
2344 
2345 static void allegro_copy_fw_codec(struct allegro_dev *dev,
2346 				  const u8 * const buf, size_t size)
2347 {
2348 	int err;
2349 	dma_addr_t icache_offset, dcache_offset;
2350 
2351 	/*
2352 	 * The downstream allocates 600 KB for the codec firmware to have some
2353 	 * extra space for "possible extensions." My tests were fine with
2354 	 * allocating just enough memory for the actual firmware, but I am not
2355 	 * sure that the firmware really does not use the remaining space.
2356 	 */
2357 	err = allegro_alloc_buffer(dev, &dev->firmware, size);
2358 	if (err) {
2359 		v4l2_err(&dev->v4l2_dev,
2360 			 "failed to allocate %zu bytes for firmware\n", size);
2361 		return;
2362 	}
2363 
2364 	v4l2_dbg(1, debug, &dev->v4l2_dev,
2365 		 "copy codec firmware (%zd B) to phys %pad\n",
2366 		 size, &dev->firmware.paddr);
2367 	memcpy(dev->firmware.vaddr, buf, size);
2368 
2369 	regmap_write(dev->regmap, AXI_ADDR_OFFSET_IP,
2370 		     upper_32_bits(dev->firmware.paddr));
2371 
2372 	icache_offset = dev->firmware.paddr - MCU_CACHE_OFFSET;
2373 	v4l2_dbg(2, debug, &dev->v4l2_dev,
2374 		 "icache_offset: msb = 0x%x, lsb = 0x%x\n",
2375 		 upper_32_bits(icache_offset), lower_32_bits(icache_offset));
2376 	regmap_write(dev->regmap, AL5_ICACHE_ADDR_OFFSET_MSB,
2377 		     upper_32_bits(icache_offset));
2378 	regmap_write(dev->regmap, AL5_ICACHE_ADDR_OFFSET_LSB,
2379 		     lower_32_bits(icache_offset));
2380 
2381 	dcache_offset =
2382 	    (dev->firmware.paddr & 0xffffffff00000000ULL) - MCU_CACHE_OFFSET;
2383 	v4l2_dbg(2, debug, &dev->v4l2_dev,
2384 		 "dcache_offset: msb = 0x%x, lsb = 0x%x\n",
2385 		 upper_32_bits(dcache_offset), lower_32_bits(dcache_offset));
2386 	regmap_write(dev->regmap, AL5_DCACHE_ADDR_OFFSET_MSB,
2387 		     upper_32_bits(dcache_offset));
2388 	regmap_write(dev->regmap, AL5_DCACHE_ADDR_OFFSET_LSB,
2389 		     lower_32_bits(dcache_offset));
2390 }
2391 
2392 static void allegro_free_fw_codec(struct allegro_dev *dev)
2393 {
2394 	allegro_free_buffer(dev, &dev->firmware);
2395 }
2396 
2397 /*
2398  * Control functions for the MCU
2399  */
2400 
2401 static int allegro_mcu_enable_interrupts(struct allegro_dev *dev)
2402 {
2403 	return regmap_write(dev->regmap, AL5_ITC_CPU_IRQ_MSK, BIT(0));
2404 }
2405 
2406 static int allegro_mcu_disable_interrupts(struct allegro_dev *dev)
2407 {
2408 	return regmap_write(dev->regmap, AL5_ITC_CPU_IRQ_MSK, 0);
2409 }
2410 
2411 static int allegro_mcu_wait_for_sleep(struct allegro_dev *dev)
2412 {
2413 	unsigned long timeout;
2414 	unsigned int status;
2415 
2416 	timeout = jiffies + msecs_to_jiffies(100);
2417 	while (regmap_read(dev->regmap, AL5_MCU_STA, &status) == 0 &&
2418 	       status != AL5_MCU_STA_SLEEP) {
2419 		if (time_after(jiffies, timeout))
2420 			return -ETIMEDOUT;
2421 		cpu_relax();
2422 	}
2423 
2424 	return 0;
2425 }
2426 
2427 static int allegro_mcu_start(struct allegro_dev *dev)
2428 {
2429 	unsigned long timeout;
2430 	unsigned int status;
2431 	int err;
2432 
2433 	err = regmap_write(dev->regmap, AL5_MCU_WAKEUP, BIT(0));
2434 	if (err)
2435 		return err;
2436 
2437 	timeout = jiffies + msecs_to_jiffies(100);
2438 	while (regmap_read(dev->regmap, AL5_MCU_STA, &status) == 0 &&
2439 	       status == AL5_MCU_STA_SLEEP) {
2440 		if (time_after(jiffies, timeout))
2441 			return -ETIMEDOUT;
2442 		cpu_relax();
2443 	}
2444 
2445 	err = regmap_write(dev->regmap, AL5_MCU_WAKEUP, 0);
2446 	if (err)
2447 		return err;
2448 
2449 	return 0;
2450 }
2451 
2452 static int allegro_mcu_reset(struct allegro_dev *dev)
2453 {
2454 	int err;
2455 
2456 	/*
2457 	 * Ensure that the AL5_MCU_WAKEUP bit is set to 0 otherwise the mcu
2458 	 * does not go to sleep after the reset.
2459 	 */
2460 	err = regmap_write(dev->regmap, AL5_MCU_WAKEUP, 0);
2461 	if (err)
2462 		return err;
2463 
2464 	err = regmap_write(dev->regmap,
2465 			   AL5_MCU_RESET_MODE, AL5_MCU_RESET_MODE_SLEEP);
2466 	if (err < 0)
2467 		return err;
2468 
2469 	err = regmap_write(dev->regmap, AL5_MCU_RESET, AL5_MCU_RESET_SOFT);
2470 	if (err < 0)
2471 		return err;
2472 
2473 	return allegro_mcu_wait_for_sleep(dev);
2474 }
2475 
2476 static void allegro_mcu_interrupt(struct allegro_dev *dev)
2477 {
2478 	regmap_write(dev->regmap, AL5_MCU_INTERRUPT, BIT(0));
2479 }
2480 
2481 static void allegro_destroy_channel(struct allegro_channel *channel)
2482 {
2483 	struct allegro_dev *dev = channel->dev;
2484 	unsigned long time_left;
2485 
2486 	if (channel_exists(channel)) {
2487 		reinit_completion(&channel->completion);
2488 		allegro_mcu_send_destroy_channel(dev, channel);
2489 		time_left = wait_for_completion_timeout(&channel->completion,
2490 							msecs_to_jiffies(5000));
2491 		if (time_left == 0)
2492 			v4l2_warn(&dev->v4l2_dev,
2493 				  "channel %d: timeout while destroying\n",
2494 				  channel->mcu_channel_id);
2495 
2496 		channel->mcu_channel_id = -1;
2497 	}
2498 
2499 	destroy_intermediate_buffers(channel);
2500 	destroy_reference_buffers(channel);
2501 
2502 	v4l2_ctrl_grab(channel->mpeg_video_h264_profile, false);
2503 	v4l2_ctrl_grab(channel->mpeg_video_h264_level, false);
2504 	v4l2_ctrl_grab(channel->mpeg_video_h264_i_frame_qp, false);
2505 	v4l2_ctrl_grab(channel->mpeg_video_h264_max_qp, false);
2506 	v4l2_ctrl_grab(channel->mpeg_video_h264_min_qp, false);
2507 	v4l2_ctrl_grab(channel->mpeg_video_h264_p_frame_qp, false);
2508 	v4l2_ctrl_grab(channel->mpeg_video_h264_b_frame_qp, false);
2509 
2510 	v4l2_ctrl_grab(channel->mpeg_video_hevc_profile, false);
2511 	v4l2_ctrl_grab(channel->mpeg_video_hevc_level, false);
2512 	v4l2_ctrl_grab(channel->mpeg_video_hevc_tier, false);
2513 	v4l2_ctrl_grab(channel->mpeg_video_hevc_i_frame_qp, false);
2514 	v4l2_ctrl_grab(channel->mpeg_video_hevc_max_qp, false);
2515 	v4l2_ctrl_grab(channel->mpeg_video_hevc_min_qp, false);
2516 	v4l2_ctrl_grab(channel->mpeg_video_hevc_p_frame_qp, false);
2517 	v4l2_ctrl_grab(channel->mpeg_video_hevc_b_frame_qp, false);
2518 
2519 	v4l2_ctrl_grab(channel->mpeg_video_frame_rc_enable, false);
2520 	v4l2_ctrl_grab(channel->mpeg_video_bitrate_mode, false);
2521 	v4l2_ctrl_grab(channel->mpeg_video_bitrate, false);
2522 	v4l2_ctrl_grab(channel->mpeg_video_bitrate_peak, false);
2523 	v4l2_ctrl_grab(channel->mpeg_video_cpb_size, false);
2524 	v4l2_ctrl_grab(channel->mpeg_video_gop_size, false);
2525 
2526 	v4l2_ctrl_grab(channel->encoder_buffer, false);
2527 
2528 	if (channel->user_id != -1) {
2529 		clear_bit(channel->user_id, &dev->channel_user_ids);
2530 		channel->user_id = -1;
2531 	}
2532 }
2533 
2534 /*
2535  * Create the MCU channel
2536  *
2537  * After the channel has been created, the picture size, format, colorspace
2538  * and framerate are fixed. Also the codec, profile, bitrate, etc. cannot be
2539  * changed anymore.
2540  *
2541  * The channel can be created only once. The MCU will accept source buffers
2542  * and stream buffers only after a channel has been created.
2543  */
2544 static int allegro_create_channel(struct allegro_channel *channel)
2545 {
2546 	struct allegro_dev *dev = channel->dev;
2547 	unsigned long time_left;
2548 
2549 	if (channel_exists(channel)) {
2550 		v4l2_warn(&dev->v4l2_dev,
2551 			  "channel already exists\n");
2552 		return 0;
2553 	}
2554 
2555 	channel->user_id = allegro_next_user_id(dev);
2556 	if (channel->user_id < 0) {
2557 		v4l2_err(&dev->v4l2_dev,
2558 			 "no free channels available\n");
2559 		return -EBUSY;
2560 	}
2561 	set_bit(channel->user_id, &dev->channel_user_ids);
2562 
2563 	v4l2_dbg(1, debug, &dev->v4l2_dev,
2564 		 "user %d: creating channel (%4.4s, %dx%d@%d)\n",
2565 		 channel->user_id,
2566 		 (char *)&channel->codec, channel->width, channel->height,
2567 		 DIV_ROUND_UP(channel->framerate.numerator,
2568 			      channel->framerate.denominator));
2569 
2570 	v4l2_ctrl_grab(channel->mpeg_video_h264_profile, true);
2571 	v4l2_ctrl_grab(channel->mpeg_video_h264_level, true);
2572 	v4l2_ctrl_grab(channel->mpeg_video_h264_i_frame_qp, true);
2573 	v4l2_ctrl_grab(channel->mpeg_video_h264_max_qp, true);
2574 	v4l2_ctrl_grab(channel->mpeg_video_h264_min_qp, true);
2575 	v4l2_ctrl_grab(channel->mpeg_video_h264_p_frame_qp, true);
2576 	v4l2_ctrl_grab(channel->mpeg_video_h264_b_frame_qp, true);
2577 
2578 	v4l2_ctrl_grab(channel->mpeg_video_hevc_profile, true);
2579 	v4l2_ctrl_grab(channel->mpeg_video_hevc_level, true);
2580 	v4l2_ctrl_grab(channel->mpeg_video_hevc_tier, true);
2581 	v4l2_ctrl_grab(channel->mpeg_video_hevc_i_frame_qp, true);
2582 	v4l2_ctrl_grab(channel->mpeg_video_hevc_max_qp, true);
2583 	v4l2_ctrl_grab(channel->mpeg_video_hevc_min_qp, true);
2584 	v4l2_ctrl_grab(channel->mpeg_video_hevc_p_frame_qp, true);
2585 	v4l2_ctrl_grab(channel->mpeg_video_hevc_b_frame_qp, true);
2586 
2587 	v4l2_ctrl_grab(channel->mpeg_video_frame_rc_enable, true);
2588 	v4l2_ctrl_grab(channel->mpeg_video_bitrate_mode, true);
2589 	v4l2_ctrl_grab(channel->mpeg_video_bitrate, true);
2590 	v4l2_ctrl_grab(channel->mpeg_video_bitrate_peak, true);
2591 	v4l2_ctrl_grab(channel->mpeg_video_cpb_size, true);
2592 	v4l2_ctrl_grab(channel->mpeg_video_gop_size, true);
2593 
2594 	v4l2_ctrl_grab(channel->encoder_buffer, true);
2595 
2596 	reinit_completion(&channel->completion);
2597 	allegro_mcu_send_create_channel(dev, channel);
2598 	time_left = wait_for_completion_timeout(&channel->completion,
2599 						msecs_to_jiffies(5000));
2600 	if (time_left == 0)
2601 		channel->error = -ETIMEDOUT;
2602 	if (channel->error)
2603 		goto err;
2604 
2605 	v4l2_dbg(1, debug, &dev->v4l2_dev,
2606 		 "channel %d: accepting buffers\n",
2607 		 channel->mcu_channel_id);
2608 
2609 	return 0;
2610 
2611 err:
2612 	allegro_destroy_channel(channel);
2613 
2614 	return channel->error;
2615 }
2616 
2617 /**
2618  * allegro_channel_adjust() - Adjust channel parameters to current format
2619  * @channel: the channel to adjust
2620  *
2621  * Various parameters of a channel and their limits depend on the currently
2622  * set format. Adjust the parameters after a format change in one go.
2623  */
2624 static void allegro_channel_adjust(struct allegro_channel *channel)
2625 {
2626 	struct allegro_dev *dev = channel->dev;
2627 	u32 codec = channel->codec;
2628 	struct v4l2_ctrl *ctrl;
2629 	s64 min;
2630 	s64 max;
2631 
2632 	channel->sizeimage_encoded =
2633 		estimate_stream_size(channel->width, channel->height);
2634 
2635 	if (codec == V4L2_PIX_FMT_H264) {
2636 		ctrl = channel->mpeg_video_h264_level;
2637 		min = select_minimum_h264_level(channel->width, channel->height);
2638 	} else {
2639 		ctrl = channel->mpeg_video_hevc_level;
2640 		min = select_minimum_hevc_level(channel->width, channel->height);
2641 	}
2642 	if (ctrl->minimum > min)
2643 		v4l2_dbg(1, debug, &dev->v4l2_dev,
2644 			 "%s.minimum: %lld -> %lld\n",
2645 			 v4l2_ctrl_get_name(ctrl->id), ctrl->minimum, min);
2646 	v4l2_ctrl_lock(ctrl);
2647 	__v4l2_ctrl_modify_range(ctrl, min, ctrl->maximum,
2648 				 ctrl->step, ctrl->default_value);
2649 	v4l2_ctrl_unlock(ctrl);
2650 
2651 	ctrl = channel->mpeg_video_bitrate;
2652 	if (codec == V4L2_PIX_FMT_H264)
2653 		max = h264_maximum_bitrate(v4l2_ctrl_g_ctrl(channel->mpeg_video_h264_level));
2654 	else
2655 		max = hevc_maximum_bitrate(v4l2_ctrl_g_ctrl(channel->mpeg_video_hevc_level));
2656 	if (ctrl->maximum < max)
2657 		v4l2_dbg(1, debug, &dev->v4l2_dev,
2658 			 "%s: maximum: %lld -> %lld\n",
2659 			 v4l2_ctrl_get_name(ctrl->id), ctrl->maximum, max);
2660 	v4l2_ctrl_lock(ctrl);
2661 	__v4l2_ctrl_modify_range(ctrl, ctrl->minimum, max,
2662 				 ctrl->step, ctrl->default_value);
2663 	v4l2_ctrl_unlock(ctrl);
2664 
2665 	ctrl = channel->mpeg_video_bitrate_peak;
2666 	v4l2_ctrl_lock(ctrl);
2667 	__v4l2_ctrl_modify_range(ctrl, ctrl->minimum, max,
2668 				 ctrl->step, ctrl->default_value);
2669 	v4l2_ctrl_unlock(ctrl);
2670 
2671 	v4l2_ctrl_activate(channel->mpeg_video_h264_profile,
2672 			   codec == V4L2_PIX_FMT_H264);
2673 	v4l2_ctrl_activate(channel->mpeg_video_h264_level,
2674 			   codec == V4L2_PIX_FMT_H264);
2675 	v4l2_ctrl_activate(channel->mpeg_video_h264_i_frame_qp,
2676 			   codec == V4L2_PIX_FMT_H264);
2677 	v4l2_ctrl_activate(channel->mpeg_video_h264_max_qp,
2678 			   codec == V4L2_PIX_FMT_H264);
2679 	v4l2_ctrl_activate(channel->mpeg_video_h264_min_qp,
2680 			   codec == V4L2_PIX_FMT_H264);
2681 	v4l2_ctrl_activate(channel->mpeg_video_h264_p_frame_qp,
2682 			   codec == V4L2_PIX_FMT_H264);
2683 	v4l2_ctrl_activate(channel->mpeg_video_h264_b_frame_qp,
2684 			   codec == V4L2_PIX_FMT_H264);
2685 
2686 	v4l2_ctrl_activate(channel->mpeg_video_hevc_profile,
2687 			   codec == V4L2_PIX_FMT_HEVC);
2688 	v4l2_ctrl_activate(channel->mpeg_video_hevc_level,
2689 			   codec == V4L2_PIX_FMT_HEVC);
2690 	v4l2_ctrl_activate(channel->mpeg_video_hevc_tier,
2691 			   codec == V4L2_PIX_FMT_HEVC);
2692 	v4l2_ctrl_activate(channel->mpeg_video_hevc_i_frame_qp,
2693 			   codec == V4L2_PIX_FMT_HEVC);
2694 	v4l2_ctrl_activate(channel->mpeg_video_hevc_max_qp,
2695 			   codec == V4L2_PIX_FMT_HEVC);
2696 	v4l2_ctrl_activate(channel->mpeg_video_hevc_min_qp,
2697 			   codec == V4L2_PIX_FMT_HEVC);
2698 	v4l2_ctrl_activate(channel->mpeg_video_hevc_p_frame_qp,
2699 			   codec == V4L2_PIX_FMT_HEVC);
2700 	v4l2_ctrl_activate(channel->mpeg_video_hevc_b_frame_qp,
2701 			   codec == V4L2_PIX_FMT_HEVC);
2702 
2703 	if (codec == V4L2_PIX_FMT_H264)
2704 		channel->log2_max_frame_num = LOG2_MAX_FRAME_NUM;
2705 	channel->temporal_mvp_enable = true;
2706 	channel->dbf_ovr_en = (codec == V4L2_PIX_FMT_H264);
2707 	channel->enable_deblocking_filter_override = (codec == V4L2_PIX_FMT_HEVC);
2708 	channel->enable_reordering = (codec == V4L2_PIX_FMT_HEVC);
2709 	channel->enable_loop_filter_across_tiles = true;
2710 	channel->enable_loop_filter_across_slices = true;
2711 
2712 	if (codec == V4L2_PIX_FMT_H264) {
2713 		channel->b_hrz_me_range = 8;
2714 		channel->b_vrt_me_range = 8;
2715 		channel->p_hrz_me_range = 16;
2716 		channel->p_vrt_me_range = 16;
2717 		channel->max_cu_size = ilog2(16);
2718 		channel->min_cu_size = ilog2(8);
2719 		channel->max_tu_size = ilog2(4);
2720 		channel->min_tu_size = ilog2(4);
2721 	} else {
2722 		channel->b_hrz_me_range = 16;
2723 		channel->b_vrt_me_range = 16;
2724 		channel->p_hrz_me_range = 32;
2725 		channel->p_vrt_me_range = 32;
2726 		channel->max_cu_size = ilog2(32);
2727 		channel->min_cu_size = ilog2(8);
2728 		channel->max_tu_size = ilog2(32);
2729 		channel->min_tu_size = ilog2(4);
2730 	}
2731 	channel->max_transfo_depth_intra = 1;
2732 	channel->max_transfo_depth_inter = 1;
2733 }
2734 
2735 static void allegro_set_default_params(struct allegro_channel *channel)
2736 {
2737 	channel->width = ALLEGRO_WIDTH_DEFAULT;
2738 	channel->height = ALLEGRO_HEIGHT_DEFAULT;
2739 	channel->stride = round_up(channel->width, 32);
2740 	channel->framerate = ALLEGRO_FRAMERATE_DEFAULT;
2741 
2742 	channel->colorspace = V4L2_COLORSPACE_REC709;
2743 	channel->ycbcr_enc = V4L2_YCBCR_ENC_DEFAULT;
2744 	channel->quantization = V4L2_QUANTIZATION_DEFAULT;
2745 	channel->xfer_func = V4L2_XFER_FUNC_DEFAULT;
2746 
2747 	channel->pixelformat = V4L2_PIX_FMT_NV12;
2748 	channel->sizeimage_raw = channel->stride * channel->height * 3 / 2;
2749 
2750 	channel->codec = V4L2_PIX_FMT_H264;
2751 }
2752 
2753 static int allegro_queue_setup(struct vb2_queue *vq,
2754 			       unsigned int *nbuffers, unsigned int *nplanes,
2755 			       unsigned int sizes[],
2756 			       struct device *alloc_devs[])
2757 {
2758 	struct allegro_channel *channel = vb2_get_drv_priv(vq);
2759 	struct allegro_dev *dev = channel->dev;
2760 
2761 	v4l2_dbg(2, debug, &dev->v4l2_dev,
2762 		 "%s: queue setup[%s]: nplanes = %d\n",
2763 		 V4L2_TYPE_IS_OUTPUT(vq->type) ? "output" : "capture",
2764 		 *nplanes == 0 ? "REQBUFS" : "CREATE_BUFS", *nplanes);
2765 
2766 	if (*nplanes != 0) {
2767 		if (V4L2_TYPE_IS_OUTPUT(vq->type)) {
2768 			if (sizes[0] < channel->sizeimage_raw)
2769 				return -EINVAL;
2770 		} else {
2771 			if (sizes[0] < channel->sizeimage_encoded)
2772 				return -EINVAL;
2773 		}
2774 	} else {
2775 		*nplanes = 1;
2776 		if (V4L2_TYPE_IS_OUTPUT(vq->type))
2777 			sizes[0] = channel->sizeimage_raw;
2778 		else
2779 			sizes[0] = channel->sizeimage_encoded;
2780 	}
2781 
2782 	return 0;
2783 }
2784 
2785 static int allegro_buf_prepare(struct vb2_buffer *vb)
2786 {
2787 	struct vb2_v4l2_buffer *vbuf = to_vb2_v4l2_buffer(vb);
2788 	struct allegro_channel *channel = vb2_get_drv_priv(vb->vb2_queue);
2789 	struct allegro_dev *dev = channel->dev;
2790 
2791 	if (V4L2_TYPE_IS_OUTPUT(vb->vb2_queue->type)) {
2792 		if (vbuf->field == V4L2_FIELD_ANY)
2793 			vbuf->field = V4L2_FIELD_NONE;
2794 		if (vbuf->field != V4L2_FIELD_NONE) {
2795 			v4l2_err(&dev->v4l2_dev,
2796 				 "channel %d: unsupported field\n",
2797 				 channel->mcu_channel_id);
2798 			return -EINVAL;
2799 		}
2800 	}
2801 
2802 	return 0;
2803 }
2804 
2805 static void allegro_buf_queue(struct vb2_buffer *vb)
2806 {
2807 	struct allegro_channel *channel = vb2_get_drv_priv(vb->vb2_queue);
2808 	struct vb2_v4l2_buffer *vbuf = to_vb2_v4l2_buffer(vb);
2809 	struct vb2_queue *q = vb->vb2_queue;
2810 
2811 	if (V4L2_TYPE_IS_CAPTURE(q->type) &&
2812 	    vb2_is_streaming(q) &&
2813 	    v4l2_m2m_dst_buf_is_last(channel->fh.m2m_ctx)) {
2814 		unsigned int i;
2815 
2816 		for (i = 0; i < vb->num_planes; i++)
2817 			vb2_set_plane_payload(vb, i, 0);
2818 
2819 		vbuf->field = V4L2_FIELD_NONE;
2820 		vbuf->sequence = channel->csequence++;
2821 
2822 		v4l2_m2m_last_buffer_done(channel->fh.m2m_ctx, vbuf);
2823 		allegro_channel_eos_event(channel);
2824 		return;
2825 	}
2826 
2827 	v4l2_m2m_buf_queue(channel->fh.m2m_ctx, vbuf);
2828 }
2829 
2830 static int allegro_start_streaming(struct vb2_queue *q, unsigned int count)
2831 {
2832 	struct allegro_channel *channel = vb2_get_drv_priv(q);
2833 	struct allegro_dev *dev = channel->dev;
2834 
2835 	v4l2_dbg(2, debug, &dev->v4l2_dev,
2836 		 "%s: start streaming\n",
2837 		 V4L2_TYPE_IS_OUTPUT(q->type) ? "output" : "capture");
2838 
2839 	v4l2_m2m_update_start_streaming_state(channel->fh.m2m_ctx, q);
2840 
2841 	if (V4L2_TYPE_IS_OUTPUT(q->type))
2842 		channel->osequence = 0;
2843 	else
2844 		channel->csequence = 0;
2845 
2846 	return 0;
2847 }
2848 
2849 static void allegro_stop_streaming(struct vb2_queue *q)
2850 {
2851 	struct allegro_channel *channel = vb2_get_drv_priv(q);
2852 	struct allegro_dev *dev = channel->dev;
2853 	struct vb2_v4l2_buffer *buffer;
2854 	struct allegro_m2m_buffer *shadow, *tmp;
2855 
2856 	v4l2_dbg(2, debug, &dev->v4l2_dev,
2857 		 "%s: stop streaming\n",
2858 		 V4L2_TYPE_IS_OUTPUT(q->type) ? "output" : "capture");
2859 
2860 	if (V4L2_TYPE_IS_OUTPUT(q->type)) {
2861 		mutex_lock(&channel->shadow_list_lock);
2862 		list_for_each_entry_safe(shadow, tmp,
2863 					 &channel->source_shadow_list, head) {
2864 			list_del(&shadow->head);
2865 			v4l2_m2m_buf_done(&shadow->buf.vb, VB2_BUF_STATE_ERROR);
2866 		}
2867 		mutex_unlock(&channel->shadow_list_lock);
2868 
2869 		while ((buffer = v4l2_m2m_src_buf_remove(channel->fh.m2m_ctx)))
2870 			v4l2_m2m_buf_done(buffer, VB2_BUF_STATE_ERROR);
2871 	} else {
2872 		mutex_lock(&channel->shadow_list_lock);
2873 		list_for_each_entry_safe(shadow, tmp,
2874 					 &channel->stream_shadow_list, head) {
2875 			list_del(&shadow->head);
2876 			v4l2_m2m_buf_done(&shadow->buf.vb, VB2_BUF_STATE_ERROR);
2877 		}
2878 		mutex_unlock(&channel->shadow_list_lock);
2879 
2880 		allegro_destroy_channel(channel);
2881 		while ((buffer = v4l2_m2m_dst_buf_remove(channel->fh.m2m_ctx)))
2882 			v4l2_m2m_buf_done(buffer, VB2_BUF_STATE_ERROR);
2883 	}
2884 
2885 	v4l2_m2m_update_stop_streaming_state(channel->fh.m2m_ctx, q);
2886 
2887 	if (V4L2_TYPE_IS_OUTPUT(q->type) &&
2888 	    v4l2_m2m_has_stopped(channel->fh.m2m_ctx))
2889 		allegro_channel_eos_event(channel);
2890 }
2891 
2892 static const struct vb2_ops allegro_queue_ops = {
2893 	.queue_setup = allegro_queue_setup,
2894 	.buf_prepare = allegro_buf_prepare,
2895 	.buf_queue = allegro_buf_queue,
2896 	.start_streaming = allegro_start_streaming,
2897 	.stop_streaming = allegro_stop_streaming,
2898 	.wait_prepare = vb2_ops_wait_prepare,
2899 	.wait_finish = vb2_ops_wait_finish,
2900 };
2901 
2902 static int allegro_queue_init(void *priv,
2903 			      struct vb2_queue *src_vq,
2904 			      struct vb2_queue *dst_vq)
2905 {
2906 	int err;
2907 	struct allegro_channel *channel = priv;
2908 
2909 	src_vq->dev = &channel->dev->plat_dev->dev;
2910 	src_vq->type = V4L2_BUF_TYPE_VIDEO_OUTPUT;
2911 	src_vq->io_modes = VB2_DMABUF | VB2_MMAP;
2912 	src_vq->mem_ops = &vb2_dma_contig_memops;
2913 	src_vq->drv_priv = channel;
2914 	src_vq->timestamp_flags = V4L2_BUF_FLAG_TIMESTAMP_COPY;
2915 	src_vq->ops = &allegro_queue_ops;
2916 	src_vq->buf_struct_size = sizeof(struct allegro_m2m_buffer);
2917 	src_vq->lock = &channel->dev->lock;
2918 	err = vb2_queue_init(src_vq);
2919 	if (err)
2920 		return err;
2921 
2922 	dst_vq->dev = &channel->dev->plat_dev->dev;
2923 	dst_vq->type = V4L2_BUF_TYPE_VIDEO_CAPTURE;
2924 	dst_vq->io_modes = VB2_DMABUF | VB2_MMAP;
2925 	dst_vq->mem_ops = &vb2_dma_contig_memops;
2926 	dst_vq->drv_priv = channel;
2927 	dst_vq->timestamp_flags = V4L2_BUF_FLAG_TIMESTAMP_COPY;
2928 	dst_vq->ops = &allegro_queue_ops;
2929 	dst_vq->buf_struct_size = sizeof(struct allegro_m2m_buffer);
2930 	dst_vq->lock = &channel->dev->lock;
2931 	err = vb2_queue_init(dst_vq);
2932 	if (err)
2933 		return err;
2934 
2935 	return 0;
2936 }
2937 
2938 static int allegro_clamp_qp(struct allegro_channel *channel,
2939 			    struct v4l2_ctrl *ctrl)
2940 {
2941 	struct v4l2_ctrl *next_ctrl;
2942 
2943 	if (ctrl->id == V4L2_CID_MPEG_VIDEO_H264_I_FRAME_QP)
2944 		next_ctrl = channel->mpeg_video_h264_p_frame_qp;
2945 	else if (ctrl->id == V4L2_CID_MPEG_VIDEO_H264_P_FRAME_QP)
2946 		next_ctrl = channel->mpeg_video_h264_b_frame_qp;
2947 	else
2948 		return 0;
2949 
2950 	/* Modify range automatically updates the value */
2951 	__v4l2_ctrl_modify_range(next_ctrl, ctrl->val, 51, 1, ctrl->val);
2952 
2953 	return allegro_clamp_qp(channel, next_ctrl);
2954 }
2955 
2956 static int allegro_clamp_bitrate(struct allegro_channel *channel,
2957 				 struct v4l2_ctrl *ctrl)
2958 {
2959 	struct v4l2_ctrl *ctrl_bitrate = channel->mpeg_video_bitrate;
2960 	struct v4l2_ctrl *ctrl_bitrate_peak = channel->mpeg_video_bitrate_peak;
2961 
2962 	if (ctrl->val == V4L2_MPEG_VIDEO_BITRATE_MODE_VBR &&
2963 	    ctrl_bitrate_peak->val < ctrl_bitrate->val)
2964 		ctrl_bitrate_peak->val = ctrl_bitrate->val;
2965 
2966 	return 0;
2967 }
2968 
2969 static int allegro_try_ctrl(struct v4l2_ctrl *ctrl)
2970 {
2971 	struct allegro_channel *channel = container_of(ctrl->handler,
2972 						       struct allegro_channel,
2973 						       ctrl_handler);
2974 
2975 	switch (ctrl->id) {
2976 	case V4L2_CID_MPEG_VIDEO_BITRATE_MODE:
2977 		allegro_clamp_bitrate(channel, ctrl);
2978 		break;
2979 	case V4L2_CID_USER_ALLEGRO_ENCODER_BUFFER:
2980 		if (!channel->dev->has_encoder_buffer)
2981 			ctrl->val = 0;
2982 		break;
2983 	}
2984 
2985 	return 0;
2986 }
2987 
2988 static int allegro_s_ctrl(struct v4l2_ctrl *ctrl)
2989 {
2990 	struct allegro_channel *channel = container_of(ctrl->handler,
2991 						       struct allegro_channel,
2992 						       ctrl_handler);
2993 	struct allegro_dev *dev = channel->dev;
2994 
2995 	v4l2_dbg(1, debug, &dev->v4l2_dev,
2996 		 "s_ctrl: %s = %d\n", v4l2_ctrl_get_name(ctrl->id), ctrl->val);
2997 
2998 	switch (ctrl->id) {
2999 	case V4L2_CID_MPEG_VIDEO_FRAME_RC_ENABLE:
3000 		channel->frame_rc_enable = ctrl->val;
3001 		break;
3002 	case V4L2_CID_MPEG_VIDEO_BITRATE_MODE:
3003 		channel->bitrate = channel->mpeg_video_bitrate->val;
3004 		channel->bitrate_peak = channel->mpeg_video_bitrate_peak->val;
3005 		v4l2_ctrl_activate(channel->mpeg_video_bitrate_peak,
3006 				   ctrl->val == V4L2_MPEG_VIDEO_BITRATE_MODE_VBR);
3007 		break;
3008 	case V4L2_CID_MPEG_VIDEO_H264_I_FRAME_QP:
3009 	case V4L2_CID_MPEG_VIDEO_H264_P_FRAME_QP:
3010 	case V4L2_CID_MPEG_VIDEO_H264_B_FRAME_QP:
3011 		allegro_clamp_qp(channel, ctrl);
3012 		break;
3013 	}
3014 
3015 	return 0;
3016 }
3017 
3018 static const struct v4l2_ctrl_ops allegro_ctrl_ops = {
3019 	.try_ctrl = allegro_try_ctrl,
3020 	.s_ctrl = allegro_s_ctrl,
3021 };
3022 
3023 static const struct v4l2_ctrl_config allegro_encoder_buffer_ctrl_config = {
3024 	.id = V4L2_CID_USER_ALLEGRO_ENCODER_BUFFER,
3025 	.name = "Encoder Buffer Enable",
3026 	.type = V4L2_CTRL_TYPE_BOOLEAN,
3027 	.min = 0,
3028 	.max = 1,
3029 	.step = 1,
3030 	.def = 1,
3031 };
3032 
3033 static int allegro_open(struct file *file)
3034 {
3035 	struct video_device *vdev = video_devdata(file);
3036 	struct allegro_dev *dev = video_get_drvdata(vdev);
3037 	struct allegro_channel *channel = NULL;
3038 	struct v4l2_ctrl_handler *handler;
3039 	u64 mask;
3040 	int ret;
3041 	unsigned int bitrate_max;
3042 	unsigned int bitrate_def;
3043 	unsigned int cpb_size_max;
3044 	unsigned int cpb_size_def;
3045 
3046 	channel = kzalloc(sizeof(*channel), GFP_KERNEL);
3047 	if (!channel)
3048 		return -ENOMEM;
3049 
3050 	v4l2_fh_init(&channel->fh, vdev);
3051 
3052 	init_completion(&channel->completion);
3053 	INIT_LIST_HEAD(&channel->source_shadow_list);
3054 	INIT_LIST_HEAD(&channel->stream_shadow_list);
3055 	mutex_init(&channel->shadow_list_lock);
3056 
3057 	channel->dev = dev;
3058 
3059 	allegro_set_default_params(channel);
3060 
3061 	handler = &channel->ctrl_handler;
3062 	v4l2_ctrl_handler_init(handler, 0);
3063 	channel->mpeg_video_h264_profile = v4l2_ctrl_new_std_menu(handler,
3064 			&allegro_ctrl_ops,
3065 			V4L2_CID_MPEG_VIDEO_H264_PROFILE,
3066 			V4L2_MPEG_VIDEO_H264_PROFILE_BASELINE, 0x0,
3067 			V4L2_MPEG_VIDEO_H264_PROFILE_BASELINE);
3068 	mask = 1 << V4L2_MPEG_VIDEO_H264_LEVEL_1B;
3069 	channel->mpeg_video_h264_level = v4l2_ctrl_new_std_menu(handler,
3070 			&allegro_ctrl_ops,
3071 			V4L2_CID_MPEG_VIDEO_H264_LEVEL,
3072 			V4L2_MPEG_VIDEO_H264_LEVEL_5_1, mask,
3073 			V4L2_MPEG_VIDEO_H264_LEVEL_5_1);
3074 	channel->mpeg_video_h264_i_frame_qp =
3075 		v4l2_ctrl_new_std(handler,
3076 				  &allegro_ctrl_ops,
3077 				  V4L2_CID_MPEG_VIDEO_H264_I_FRAME_QP,
3078 				  0, 51, 1, 30);
3079 	channel->mpeg_video_h264_max_qp =
3080 		v4l2_ctrl_new_std(handler,
3081 				  &allegro_ctrl_ops,
3082 				  V4L2_CID_MPEG_VIDEO_H264_MAX_QP,
3083 				  0, 51, 1, 51);
3084 	channel->mpeg_video_h264_min_qp =
3085 		v4l2_ctrl_new_std(handler,
3086 				  &allegro_ctrl_ops,
3087 				  V4L2_CID_MPEG_VIDEO_H264_MIN_QP,
3088 				  0, 51, 1, 0);
3089 	channel->mpeg_video_h264_p_frame_qp =
3090 		v4l2_ctrl_new_std(handler,
3091 				  &allegro_ctrl_ops,
3092 				  V4L2_CID_MPEG_VIDEO_H264_P_FRAME_QP,
3093 				  0, 51, 1, 30);
3094 	channel->mpeg_video_h264_b_frame_qp =
3095 		v4l2_ctrl_new_std(handler,
3096 				  &allegro_ctrl_ops,
3097 				  V4L2_CID_MPEG_VIDEO_H264_B_FRAME_QP,
3098 				  0, 51, 1, 30);
3099 
3100 	channel->mpeg_video_hevc_profile =
3101 		v4l2_ctrl_new_std_menu(handler,
3102 				       &allegro_ctrl_ops,
3103 				       V4L2_CID_MPEG_VIDEO_HEVC_PROFILE,
3104 				       V4L2_MPEG_VIDEO_HEVC_PROFILE_MAIN, 0x0,
3105 				       V4L2_MPEG_VIDEO_HEVC_PROFILE_MAIN);
3106 	channel->mpeg_video_hevc_level =
3107 		v4l2_ctrl_new_std_menu(handler,
3108 				       &allegro_ctrl_ops,
3109 				       V4L2_CID_MPEG_VIDEO_HEVC_LEVEL,
3110 				       V4L2_MPEG_VIDEO_HEVC_LEVEL_5_1, 0x0,
3111 				       V4L2_MPEG_VIDEO_HEVC_LEVEL_5_1);
3112 	channel->mpeg_video_hevc_tier =
3113 		v4l2_ctrl_new_std_menu(handler,
3114 				       &allegro_ctrl_ops,
3115 				       V4L2_CID_MPEG_VIDEO_HEVC_TIER,
3116 				       V4L2_MPEG_VIDEO_HEVC_TIER_HIGH, 0x0,
3117 				       V4L2_MPEG_VIDEO_HEVC_TIER_MAIN);
3118 	channel->mpeg_video_hevc_i_frame_qp =
3119 		v4l2_ctrl_new_std(handler,
3120 				  &allegro_ctrl_ops,
3121 				  V4L2_CID_MPEG_VIDEO_HEVC_I_FRAME_QP,
3122 				  0, 51, 1, 30);
3123 	channel->mpeg_video_hevc_max_qp =
3124 		v4l2_ctrl_new_std(handler,
3125 				  &allegro_ctrl_ops,
3126 				  V4L2_CID_MPEG_VIDEO_HEVC_MAX_QP,
3127 				  0, 51, 1, 51);
3128 	channel->mpeg_video_hevc_min_qp =
3129 		v4l2_ctrl_new_std(handler,
3130 				  &allegro_ctrl_ops,
3131 				  V4L2_CID_MPEG_VIDEO_HEVC_MIN_QP,
3132 				  0, 51, 1, 0);
3133 	channel->mpeg_video_hevc_p_frame_qp =
3134 		v4l2_ctrl_new_std(handler,
3135 				  &allegro_ctrl_ops,
3136 				  V4L2_CID_MPEG_VIDEO_HEVC_P_FRAME_QP,
3137 				  0, 51, 1, 30);
3138 	channel->mpeg_video_hevc_b_frame_qp =
3139 		v4l2_ctrl_new_std(handler,
3140 				  &allegro_ctrl_ops,
3141 				  V4L2_CID_MPEG_VIDEO_HEVC_B_FRAME_QP,
3142 				  0, 51, 1, 30);
3143 
3144 	channel->mpeg_video_frame_rc_enable =
3145 		v4l2_ctrl_new_std(handler,
3146 				  &allegro_ctrl_ops,
3147 				  V4L2_CID_MPEG_VIDEO_FRAME_RC_ENABLE,
3148 				  false, 0x1,
3149 				  true, false);
3150 	channel->mpeg_video_bitrate_mode = v4l2_ctrl_new_std_menu(handler,
3151 			&allegro_ctrl_ops,
3152 			V4L2_CID_MPEG_VIDEO_BITRATE_MODE,
3153 			V4L2_MPEG_VIDEO_BITRATE_MODE_CBR, 0,
3154 			V4L2_MPEG_VIDEO_BITRATE_MODE_CBR);
3155 
3156 	if (channel->codec == V4L2_PIX_FMT_H264) {
3157 		bitrate_max = h264_maximum_bitrate(V4L2_MPEG_VIDEO_H264_LEVEL_5_1);
3158 		bitrate_def = h264_maximum_bitrate(V4L2_MPEG_VIDEO_H264_LEVEL_5_1);
3159 		cpb_size_max = h264_maximum_cpb_size(V4L2_MPEG_VIDEO_H264_LEVEL_5_1);
3160 		cpb_size_def = h264_maximum_cpb_size(V4L2_MPEG_VIDEO_H264_LEVEL_5_1);
3161 	} else {
3162 		bitrate_max = hevc_maximum_bitrate(V4L2_MPEG_VIDEO_HEVC_LEVEL_5_1);
3163 		bitrate_def = hevc_maximum_bitrate(V4L2_MPEG_VIDEO_HEVC_LEVEL_5_1);
3164 		cpb_size_max = hevc_maximum_cpb_size(V4L2_MPEG_VIDEO_HEVC_LEVEL_5_1);
3165 		cpb_size_def = hevc_maximum_cpb_size(V4L2_MPEG_VIDEO_HEVC_LEVEL_5_1);
3166 	}
3167 	channel->mpeg_video_bitrate = v4l2_ctrl_new_std(handler,
3168 			&allegro_ctrl_ops,
3169 			V4L2_CID_MPEG_VIDEO_BITRATE,
3170 			0, bitrate_max, 1, bitrate_def);
3171 	channel->mpeg_video_bitrate_peak = v4l2_ctrl_new_std(handler,
3172 			&allegro_ctrl_ops,
3173 			V4L2_CID_MPEG_VIDEO_BITRATE_PEAK,
3174 			0, bitrate_max, 1, bitrate_def);
3175 	channel->mpeg_video_cpb_size = v4l2_ctrl_new_std(handler,
3176 			&allegro_ctrl_ops,
3177 			V4L2_CID_MPEG_VIDEO_H264_CPB_SIZE,
3178 			0, cpb_size_max, 1, cpb_size_def);
3179 	channel->mpeg_video_gop_size = v4l2_ctrl_new_std(handler,
3180 			&allegro_ctrl_ops,
3181 			V4L2_CID_MPEG_VIDEO_GOP_SIZE,
3182 			0, ALLEGRO_GOP_SIZE_MAX,
3183 			1, ALLEGRO_GOP_SIZE_DEFAULT);
3184 	channel->encoder_buffer = v4l2_ctrl_new_custom(handler,
3185 			&allegro_encoder_buffer_ctrl_config, NULL);
3186 	v4l2_ctrl_new_std(handler,
3187 			  &allegro_ctrl_ops,
3188 			  V4L2_CID_MIN_BUFFERS_FOR_OUTPUT,
3189 			  1, 32,
3190 			  1, 1);
3191 	if (handler->error != 0) {
3192 		ret = handler->error;
3193 		goto error;
3194 	}
3195 
3196 	channel->fh.ctrl_handler = handler;
3197 
3198 	v4l2_ctrl_cluster(3, &channel->mpeg_video_bitrate_mode);
3199 
3200 	v4l2_ctrl_handler_setup(handler);
3201 
3202 	channel->mcu_channel_id = -1;
3203 	channel->user_id = -1;
3204 
3205 	INIT_LIST_HEAD(&channel->buffers_reference);
3206 	INIT_LIST_HEAD(&channel->buffers_intermediate);
3207 
3208 	channel->fh.m2m_ctx = v4l2_m2m_ctx_init(dev->m2m_dev, channel,
3209 						allegro_queue_init);
3210 
3211 	if (IS_ERR(channel->fh.m2m_ctx)) {
3212 		ret = PTR_ERR(channel->fh.m2m_ctx);
3213 		goto error;
3214 	}
3215 
3216 	list_add(&channel->list, &dev->channels);
3217 	file->private_data = &channel->fh;
3218 	v4l2_fh_add(&channel->fh);
3219 
3220 	allegro_channel_adjust(channel);
3221 
3222 	return 0;
3223 
3224 error:
3225 	v4l2_ctrl_handler_free(handler);
3226 	kfree(channel);
3227 	return ret;
3228 }
3229 
3230 static int allegro_release(struct file *file)
3231 {
3232 	struct allegro_channel *channel = fh_to_channel(file->private_data);
3233 
3234 	v4l2_m2m_ctx_release(channel->fh.m2m_ctx);
3235 
3236 	list_del(&channel->list);
3237 
3238 	v4l2_ctrl_handler_free(&channel->ctrl_handler);
3239 
3240 	v4l2_fh_del(&channel->fh);
3241 	v4l2_fh_exit(&channel->fh);
3242 
3243 	kfree(channel);
3244 
3245 	return 0;
3246 }
3247 
3248 static int allegro_querycap(struct file *file, void *fh,
3249 			    struct v4l2_capability *cap)
3250 {
3251 	strscpy(cap->driver, KBUILD_MODNAME, sizeof(cap->driver));
3252 	strscpy(cap->card, "Allegro DVT Video Encoder", sizeof(cap->card));
3253 
3254 	return 0;
3255 }
3256 
3257 static int allegro_enum_fmt_vid(struct file *file, void *fh,
3258 				struct v4l2_fmtdesc *f)
3259 {
3260 	switch (f->type) {
3261 	case V4L2_BUF_TYPE_VIDEO_OUTPUT:
3262 		if (f->index >= 1)
3263 			return -EINVAL;
3264 		f->pixelformat = V4L2_PIX_FMT_NV12;
3265 		break;
3266 	case V4L2_BUF_TYPE_VIDEO_CAPTURE:
3267 		if (f->index >= 2)
3268 			return -EINVAL;
3269 		if (f->index == 0)
3270 			f->pixelformat = V4L2_PIX_FMT_H264;
3271 		if (f->index == 1)
3272 			f->pixelformat = V4L2_PIX_FMT_HEVC;
3273 		break;
3274 	default:
3275 		return -EINVAL;
3276 	}
3277 	return 0;
3278 }
3279 
3280 static int allegro_g_fmt_vid_cap(struct file *file, void *fh,
3281 				 struct v4l2_format *f)
3282 {
3283 	struct allegro_channel *channel = fh_to_channel(fh);
3284 
3285 	f->fmt.pix.field = V4L2_FIELD_NONE;
3286 	f->fmt.pix.width = channel->width;
3287 	f->fmt.pix.height = channel->height;
3288 
3289 	f->fmt.pix.colorspace = channel->colorspace;
3290 	f->fmt.pix.ycbcr_enc = channel->ycbcr_enc;
3291 	f->fmt.pix.quantization = channel->quantization;
3292 	f->fmt.pix.xfer_func = channel->xfer_func;
3293 
3294 	f->fmt.pix.pixelformat = channel->codec;
3295 	f->fmt.pix.bytesperline = 0;
3296 	f->fmt.pix.sizeimage = channel->sizeimage_encoded;
3297 
3298 	return 0;
3299 }
3300 
3301 static int allegro_try_fmt_vid_cap(struct file *file, void *fh,
3302 				   struct v4l2_format *f)
3303 {
3304 	f->fmt.pix.field = V4L2_FIELD_NONE;
3305 
3306 	f->fmt.pix.width = clamp_t(__u32, f->fmt.pix.width,
3307 				   ALLEGRO_WIDTH_MIN, ALLEGRO_WIDTH_MAX);
3308 	f->fmt.pix.height = clamp_t(__u32, f->fmt.pix.height,
3309 				    ALLEGRO_HEIGHT_MIN, ALLEGRO_HEIGHT_MAX);
3310 
3311 	if (f->fmt.pix.pixelformat != V4L2_PIX_FMT_HEVC &&
3312 	    f->fmt.pix.pixelformat != V4L2_PIX_FMT_H264)
3313 		f->fmt.pix.pixelformat = V4L2_PIX_FMT_H264;
3314 
3315 	f->fmt.pix.bytesperline = 0;
3316 	f->fmt.pix.sizeimage =
3317 		estimate_stream_size(f->fmt.pix.width, f->fmt.pix.height);
3318 
3319 	return 0;
3320 }
3321 
3322 static int allegro_s_fmt_vid_cap(struct file *file, void *fh,
3323 				 struct v4l2_format *f)
3324 {
3325 	struct allegro_channel *channel = fh_to_channel(fh);
3326 	struct vb2_queue *vq;
3327 	int err;
3328 
3329 	err = allegro_try_fmt_vid_cap(file, fh, f);
3330 	if (err)
3331 		return err;
3332 
3333 	vq = v4l2_m2m_get_vq(channel->fh.m2m_ctx, f->type);
3334 	if (!vq)
3335 		return -EINVAL;
3336 	if (vb2_is_busy(vq))
3337 		return -EBUSY;
3338 
3339 	channel->codec = f->fmt.pix.pixelformat;
3340 
3341 	allegro_channel_adjust(channel);
3342 
3343 	return 0;
3344 }
3345 
3346 static int allegro_g_fmt_vid_out(struct file *file, void *fh,
3347 				 struct v4l2_format *f)
3348 {
3349 	struct allegro_channel *channel = fh_to_channel(fh);
3350 
3351 	f->fmt.pix.field = V4L2_FIELD_NONE;
3352 
3353 	f->fmt.pix.width = channel->width;
3354 	f->fmt.pix.height = channel->height;
3355 
3356 	f->fmt.pix.colorspace = channel->colorspace;
3357 	f->fmt.pix.ycbcr_enc = channel->ycbcr_enc;
3358 	f->fmt.pix.quantization = channel->quantization;
3359 	f->fmt.pix.xfer_func = channel->xfer_func;
3360 
3361 	f->fmt.pix.pixelformat = channel->pixelformat;
3362 	f->fmt.pix.bytesperline = channel->stride;
3363 	f->fmt.pix.sizeimage = channel->sizeimage_raw;
3364 
3365 	return 0;
3366 }
3367 
3368 static int allegro_try_fmt_vid_out(struct file *file, void *fh,
3369 				   struct v4l2_format *f)
3370 {
3371 	f->fmt.pix.field = V4L2_FIELD_NONE;
3372 
3373 	/*
3374 	 * The firmware of the Allegro codec handles the padding internally
3375 	 * and expects the visual frame size when configuring a channel.
3376 	 * Therefore, unlike other encoder drivers, this driver does not round
3377 	 * up the width and height to macroblock alignment and does not
3378 	 * implement the selection api.
3379 	 */
3380 	f->fmt.pix.width = clamp_t(__u32, f->fmt.pix.width,
3381 				   ALLEGRO_WIDTH_MIN, ALLEGRO_WIDTH_MAX);
3382 	f->fmt.pix.height = clamp_t(__u32, f->fmt.pix.height,
3383 				    ALLEGRO_HEIGHT_MIN, ALLEGRO_HEIGHT_MAX);
3384 
3385 	f->fmt.pix.pixelformat = V4L2_PIX_FMT_NV12;
3386 	f->fmt.pix.bytesperline = round_up(f->fmt.pix.width, 32);
3387 	f->fmt.pix.sizeimage =
3388 		f->fmt.pix.bytesperline * f->fmt.pix.height * 3 / 2;
3389 
3390 	return 0;
3391 }
3392 
3393 static int allegro_s_fmt_vid_out(struct file *file, void *fh,
3394 				 struct v4l2_format *f)
3395 {
3396 	struct allegro_channel *channel = fh_to_channel(fh);
3397 	int err;
3398 
3399 	err = allegro_try_fmt_vid_out(file, fh, f);
3400 	if (err)
3401 		return err;
3402 
3403 	channel->width = f->fmt.pix.width;
3404 	channel->height = f->fmt.pix.height;
3405 	channel->stride = f->fmt.pix.bytesperline;
3406 	channel->sizeimage_raw = f->fmt.pix.sizeimage;
3407 
3408 	channel->colorspace = f->fmt.pix.colorspace;
3409 	channel->ycbcr_enc = f->fmt.pix.ycbcr_enc;
3410 	channel->quantization = f->fmt.pix.quantization;
3411 	channel->xfer_func = f->fmt.pix.xfer_func;
3412 
3413 	allegro_channel_adjust(channel);
3414 
3415 	return 0;
3416 }
3417 
3418 static int allegro_channel_cmd_stop(struct allegro_channel *channel)
3419 {
3420 	if (v4l2_m2m_has_stopped(channel->fh.m2m_ctx))
3421 		allegro_channel_eos_event(channel);
3422 
3423 	return 0;
3424 }
3425 
3426 static int allegro_channel_cmd_start(struct allegro_channel *channel)
3427 {
3428 	if (v4l2_m2m_has_stopped(channel->fh.m2m_ctx))
3429 		vb2_clear_last_buffer_dequeued(&channel->fh.m2m_ctx->cap_q_ctx.q);
3430 
3431 	return 0;
3432 }
3433 
3434 static int allegro_encoder_cmd(struct file *file, void *fh,
3435 			       struct v4l2_encoder_cmd *cmd)
3436 {
3437 	struct allegro_channel *channel = fh_to_channel(fh);
3438 	int err;
3439 
3440 	err = v4l2_m2m_ioctl_try_encoder_cmd(file, fh, cmd);
3441 	if (err)
3442 		return err;
3443 
3444 	err = v4l2_m2m_ioctl_encoder_cmd(file, fh, cmd);
3445 	if (err)
3446 		return err;
3447 
3448 	if (cmd->cmd == V4L2_ENC_CMD_STOP)
3449 		err = allegro_channel_cmd_stop(channel);
3450 
3451 	if (cmd->cmd == V4L2_ENC_CMD_START)
3452 		err = allegro_channel_cmd_start(channel);
3453 
3454 	return err;
3455 }
3456 
3457 static int allegro_enum_framesizes(struct file *file, void *fh,
3458 				   struct v4l2_frmsizeenum *fsize)
3459 {
3460 	switch (fsize->pixel_format) {
3461 	case V4L2_PIX_FMT_HEVC:
3462 	case V4L2_PIX_FMT_H264:
3463 	case V4L2_PIX_FMT_NV12:
3464 		break;
3465 	default:
3466 		return -EINVAL;
3467 	}
3468 
3469 	if (fsize->index)
3470 		return -EINVAL;
3471 
3472 	fsize->type = V4L2_FRMSIZE_TYPE_CONTINUOUS;
3473 	fsize->stepwise.min_width = ALLEGRO_WIDTH_MIN;
3474 	fsize->stepwise.max_width = ALLEGRO_WIDTH_MAX;
3475 	fsize->stepwise.step_width = 1;
3476 	fsize->stepwise.min_height = ALLEGRO_HEIGHT_MIN;
3477 	fsize->stepwise.max_height = ALLEGRO_HEIGHT_MAX;
3478 	fsize->stepwise.step_height = 1;
3479 
3480 	return 0;
3481 }
3482 
3483 static int allegro_ioctl_streamon(struct file *file, void *priv,
3484 				  enum v4l2_buf_type type)
3485 {
3486 	struct v4l2_fh *fh = file->private_data;
3487 	struct allegro_channel *channel = fh_to_channel(fh);
3488 	int err;
3489 
3490 	if (type == V4L2_BUF_TYPE_VIDEO_CAPTURE) {
3491 		err = allegro_create_channel(channel);
3492 		if (err)
3493 			return err;
3494 	}
3495 
3496 	return v4l2_m2m_streamon(file, fh->m2m_ctx, type);
3497 }
3498 
3499 static int allegro_g_parm(struct file *file, void *fh,
3500 			  struct v4l2_streamparm *a)
3501 {
3502 	struct allegro_channel *channel = fh_to_channel(fh);
3503 	struct v4l2_fract *timeperframe;
3504 
3505 	if (a->type != V4L2_BUF_TYPE_VIDEO_OUTPUT)
3506 		return -EINVAL;
3507 
3508 	a->parm.output.capability = V4L2_CAP_TIMEPERFRAME;
3509 	timeperframe = &a->parm.output.timeperframe;
3510 	timeperframe->numerator = channel->framerate.denominator;
3511 	timeperframe->denominator = channel->framerate.numerator;
3512 
3513 	return 0;
3514 }
3515 
3516 static int allegro_s_parm(struct file *file, void *fh,
3517 			  struct v4l2_streamparm *a)
3518 {
3519 	struct allegro_channel *channel = fh_to_channel(fh);
3520 	struct v4l2_fract *timeperframe;
3521 	int div;
3522 
3523 	if (a->type != V4L2_BUF_TYPE_VIDEO_OUTPUT)
3524 		return -EINVAL;
3525 
3526 	a->parm.output.capability = V4L2_CAP_TIMEPERFRAME;
3527 	timeperframe = &a->parm.output.timeperframe;
3528 
3529 	if (timeperframe->numerator == 0 || timeperframe->denominator == 0)
3530 		return allegro_g_parm(file, fh, a);
3531 
3532 	div = gcd(timeperframe->denominator, timeperframe->numerator);
3533 	channel->framerate.numerator = timeperframe->denominator / div;
3534 	channel->framerate.denominator = timeperframe->numerator / div;
3535 
3536 	return 0;
3537 }
3538 
3539 static int allegro_subscribe_event(struct v4l2_fh *fh,
3540 				   const struct v4l2_event_subscription *sub)
3541 {
3542 	switch (sub->type) {
3543 	case V4L2_EVENT_EOS:
3544 		return v4l2_event_subscribe(fh, sub, 0, NULL);
3545 	default:
3546 		return v4l2_ctrl_subscribe_event(fh, sub);
3547 	}
3548 }
3549 
3550 static const struct v4l2_ioctl_ops allegro_ioctl_ops = {
3551 	.vidioc_querycap = allegro_querycap,
3552 	.vidioc_enum_fmt_vid_cap = allegro_enum_fmt_vid,
3553 	.vidioc_enum_fmt_vid_out = allegro_enum_fmt_vid,
3554 	.vidioc_g_fmt_vid_cap = allegro_g_fmt_vid_cap,
3555 	.vidioc_try_fmt_vid_cap = allegro_try_fmt_vid_cap,
3556 	.vidioc_s_fmt_vid_cap = allegro_s_fmt_vid_cap,
3557 	.vidioc_g_fmt_vid_out = allegro_g_fmt_vid_out,
3558 	.vidioc_try_fmt_vid_out = allegro_try_fmt_vid_out,
3559 	.vidioc_s_fmt_vid_out = allegro_s_fmt_vid_out,
3560 
3561 	.vidioc_create_bufs = v4l2_m2m_ioctl_create_bufs,
3562 	.vidioc_reqbufs = v4l2_m2m_ioctl_reqbufs,
3563 
3564 	.vidioc_expbuf = v4l2_m2m_ioctl_expbuf,
3565 	.vidioc_querybuf = v4l2_m2m_ioctl_querybuf,
3566 	.vidioc_qbuf = v4l2_m2m_ioctl_qbuf,
3567 	.vidioc_dqbuf = v4l2_m2m_ioctl_dqbuf,
3568 	.vidioc_prepare_buf = v4l2_m2m_ioctl_prepare_buf,
3569 
3570 	.vidioc_streamon = allegro_ioctl_streamon,
3571 	.vidioc_streamoff = v4l2_m2m_ioctl_streamoff,
3572 
3573 	.vidioc_try_encoder_cmd = v4l2_m2m_ioctl_try_encoder_cmd,
3574 	.vidioc_encoder_cmd = allegro_encoder_cmd,
3575 	.vidioc_enum_framesizes = allegro_enum_framesizes,
3576 
3577 	.vidioc_g_parm		= allegro_g_parm,
3578 	.vidioc_s_parm		= allegro_s_parm,
3579 
3580 	.vidioc_subscribe_event = allegro_subscribe_event,
3581 	.vidioc_unsubscribe_event = v4l2_event_unsubscribe,
3582 };
3583 
3584 static const struct v4l2_file_operations allegro_fops = {
3585 	.owner = THIS_MODULE,
3586 	.open = allegro_open,
3587 	.release = allegro_release,
3588 	.poll = v4l2_m2m_fop_poll,
3589 	.unlocked_ioctl = video_ioctl2,
3590 	.mmap = v4l2_m2m_fop_mmap,
3591 };
3592 
3593 static int allegro_register_device(struct allegro_dev *dev)
3594 {
3595 	struct video_device *video_dev = &dev->video_dev;
3596 
3597 	strscpy(video_dev->name, "allegro", sizeof(video_dev->name));
3598 	video_dev->fops = &allegro_fops;
3599 	video_dev->ioctl_ops = &allegro_ioctl_ops;
3600 	video_dev->release = video_device_release_empty;
3601 	video_dev->lock = &dev->lock;
3602 	video_dev->v4l2_dev = &dev->v4l2_dev;
3603 	video_dev->vfl_dir = VFL_DIR_M2M;
3604 	video_dev->device_caps = V4L2_CAP_VIDEO_M2M | V4L2_CAP_STREAMING;
3605 	video_set_drvdata(video_dev, dev);
3606 
3607 	return video_register_device(video_dev, VFL_TYPE_VIDEO, 0);
3608 }
3609 
3610 static void allegro_device_run(void *priv)
3611 {
3612 	struct allegro_channel *channel = priv;
3613 	struct allegro_dev *dev = channel->dev;
3614 	struct vb2_v4l2_buffer *src_buf;
3615 	struct vb2_v4l2_buffer *dst_buf;
3616 	dma_addr_t src_y;
3617 	dma_addr_t src_uv;
3618 	dma_addr_t dst_addr;
3619 	unsigned long dst_size;
3620 	u64 src_handle;
3621 	u64 dst_handle;
3622 
3623 	dst_buf = v4l2_m2m_dst_buf_remove(channel->fh.m2m_ctx);
3624 	dst_addr = vb2_dma_contig_plane_dma_addr(&dst_buf->vb2_buf, 0);
3625 	dst_size = vb2_plane_size(&dst_buf->vb2_buf, 0);
3626 	dst_handle = allegro_put_buffer(channel, &channel->stream_shadow_list,
3627 					dst_buf);
3628 	allegro_mcu_send_put_stream_buffer(dev, channel, dst_addr, dst_size,
3629 					   dst_handle);
3630 
3631 	src_buf = v4l2_m2m_src_buf_remove(channel->fh.m2m_ctx);
3632 	src_buf->sequence = channel->osequence++;
3633 	src_y = vb2_dma_contig_plane_dma_addr(&src_buf->vb2_buf, 0);
3634 	src_uv = src_y + (channel->stride * channel->height);
3635 	src_handle = allegro_put_buffer(channel, &channel->source_shadow_list,
3636 					src_buf);
3637 	allegro_mcu_send_encode_frame(dev, channel, src_y, src_uv, src_handle);
3638 
3639 	v4l2_m2m_job_finish(dev->m2m_dev, channel->fh.m2m_ctx);
3640 }
3641 
3642 static const struct v4l2_m2m_ops allegro_m2m_ops = {
3643 	.device_run = allegro_device_run,
3644 };
3645 
3646 static int allegro_mcu_hw_init(struct allegro_dev *dev,
3647 			       const struct fw_info *info)
3648 {
3649 	int err;
3650 
3651 	dev->mbox_command = allegro_mbox_init(dev, info->mailbox_cmd,
3652 					      info->mailbox_size);
3653 	dev->mbox_status = allegro_mbox_init(dev, info->mailbox_status,
3654 					     info->mailbox_size);
3655 	if (IS_ERR(dev->mbox_command) || IS_ERR(dev->mbox_status)) {
3656 		v4l2_err(&dev->v4l2_dev,
3657 			 "failed to initialize mailboxes\n");
3658 		return -EIO;
3659 	}
3660 
3661 	err = allegro_encoder_buffer_init(dev, &dev->encoder_buffer);
3662 	dev->has_encoder_buffer = (err == 0);
3663 	if (!dev->has_encoder_buffer)
3664 		v4l2_info(&dev->v4l2_dev, "encoder buffer not available\n");
3665 
3666 	allegro_mcu_enable_interrupts(dev);
3667 
3668 	/* The mcu sends INIT after reset. */
3669 	allegro_mcu_start(dev);
3670 	err = allegro_mcu_wait_for_init_timeout(dev, 5000);
3671 	if (err < 0) {
3672 		v4l2_err(&dev->v4l2_dev,
3673 			 "mcu did not send INIT after reset\n");
3674 		err = -EIO;
3675 		goto err_disable_interrupts;
3676 	}
3677 
3678 	err = allegro_alloc_buffer(dev, &dev->suballocator,
3679 				   info->suballocator_size);
3680 	if (err) {
3681 		v4l2_err(&dev->v4l2_dev,
3682 			 "failed to allocate %zu bytes for suballocator\n",
3683 			 info->suballocator_size);
3684 		goto err_reset_mcu;
3685 	}
3686 
3687 	allegro_mcu_send_init(dev, dev->suballocator.paddr,
3688 			      dev->suballocator.size);
3689 	err = allegro_mcu_wait_for_init_timeout(dev, 5000);
3690 	if (err < 0) {
3691 		v4l2_err(&dev->v4l2_dev,
3692 			 "mcu failed to configure sub-allocator\n");
3693 		err = -EIO;
3694 		goto err_free_suballocator;
3695 	}
3696 
3697 	return 0;
3698 
3699 err_free_suballocator:
3700 	allegro_free_buffer(dev, &dev->suballocator);
3701 err_reset_mcu:
3702 	allegro_mcu_reset(dev);
3703 err_disable_interrupts:
3704 	allegro_mcu_disable_interrupts(dev);
3705 
3706 	return err;
3707 }
3708 
3709 static int allegro_mcu_hw_deinit(struct allegro_dev *dev)
3710 {
3711 	int err;
3712 
3713 	err = allegro_mcu_reset(dev);
3714 	if (err)
3715 		v4l2_warn(&dev->v4l2_dev,
3716 			  "mcu failed to enter sleep state\n");
3717 
3718 	err = allegro_mcu_disable_interrupts(dev);
3719 	if (err)
3720 		v4l2_warn(&dev->v4l2_dev,
3721 			  "failed to disable interrupts\n");
3722 
3723 	allegro_free_buffer(dev, &dev->suballocator);
3724 
3725 	return 0;
3726 }
3727 
3728 static void allegro_fw_callback(const struct firmware *fw, void *context)
3729 {
3730 	struct allegro_dev *dev = context;
3731 	const char *fw_codec_name = "al5e.fw";
3732 	const struct firmware *fw_codec;
3733 	int err;
3734 
3735 	if (!fw)
3736 		return;
3737 
3738 	v4l2_dbg(1, debug, &dev->v4l2_dev,
3739 		 "requesting codec firmware '%s'\n", fw_codec_name);
3740 	err = request_firmware(&fw_codec, fw_codec_name, &dev->plat_dev->dev);
3741 	if (err)
3742 		goto err_release_firmware;
3743 
3744 	dev->fw_info = allegro_get_firmware_info(dev, fw, fw_codec);
3745 	if (!dev->fw_info) {
3746 		v4l2_err(&dev->v4l2_dev, "firmware is not supported\n");
3747 		goto err_release_firmware_codec;
3748 	}
3749 
3750 	v4l2_info(&dev->v4l2_dev,
3751 		  "using mcu firmware version '%s'\n", dev->fw_info->version);
3752 
3753 	pm_runtime_enable(&dev->plat_dev->dev);
3754 	err = pm_runtime_resume_and_get(&dev->plat_dev->dev);
3755 	if (err)
3756 		goto err_release_firmware_codec;
3757 
3758 	/* Ensure that the mcu is sleeping at the reset vector */
3759 	err = allegro_mcu_reset(dev);
3760 	if (err) {
3761 		v4l2_err(&dev->v4l2_dev, "failed to reset mcu\n");
3762 		goto err_suspend;
3763 	}
3764 
3765 	allegro_copy_firmware(dev, fw->data, fw->size);
3766 	allegro_copy_fw_codec(dev, fw_codec->data, fw_codec->size);
3767 
3768 	err = allegro_mcu_hw_init(dev, dev->fw_info);
3769 	if (err) {
3770 		v4l2_err(&dev->v4l2_dev, "failed to initialize mcu\n");
3771 		goto err_free_fw_codec;
3772 	}
3773 
3774 	dev->m2m_dev = v4l2_m2m_init(&allegro_m2m_ops);
3775 	if (IS_ERR(dev->m2m_dev)) {
3776 		v4l2_err(&dev->v4l2_dev, "failed to init mem2mem device\n");
3777 		goto err_mcu_hw_deinit;
3778 	}
3779 
3780 	err = allegro_register_device(dev);
3781 	if (err) {
3782 		v4l2_err(&dev->v4l2_dev, "failed to register video device\n");
3783 		goto err_m2m_release;
3784 	}
3785 
3786 	v4l2_dbg(1, debug, &dev->v4l2_dev,
3787 		 "allegro codec registered as /dev/video%d\n",
3788 		 dev->video_dev.num);
3789 
3790 	dev->initialized = true;
3791 
3792 	release_firmware(fw_codec);
3793 	release_firmware(fw);
3794 
3795 	return;
3796 
3797 err_m2m_release:
3798 	v4l2_m2m_release(dev->m2m_dev);
3799 	dev->m2m_dev = NULL;
3800 err_mcu_hw_deinit:
3801 	allegro_mcu_hw_deinit(dev);
3802 err_free_fw_codec:
3803 	allegro_free_fw_codec(dev);
3804 err_suspend:
3805 	pm_runtime_put(&dev->plat_dev->dev);
3806 	pm_runtime_disable(&dev->plat_dev->dev);
3807 err_release_firmware_codec:
3808 	release_firmware(fw_codec);
3809 err_release_firmware:
3810 	release_firmware(fw);
3811 }
3812 
3813 static int allegro_firmware_request_nowait(struct allegro_dev *dev)
3814 {
3815 	const char *fw = "al5e_b.fw";
3816 
3817 	v4l2_dbg(1, debug, &dev->v4l2_dev,
3818 		 "requesting firmware '%s'\n", fw);
3819 	return request_firmware_nowait(THIS_MODULE, true, fw,
3820 				       &dev->plat_dev->dev, GFP_KERNEL, dev,
3821 				       allegro_fw_callback);
3822 }
3823 
3824 static int allegro_probe(struct platform_device *pdev)
3825 {
3826 	struct allegro_dev *dev;
3827 	struct resource *res, *sram_res;
3828 	int ret;
3829 	int irq;
3830 	void __iomem *regs, *sram_regs;
3831 
3832 	dev = devm_kzalloc(&pdev->dev, sizeof(*dev), GFP_KERNEL);
3833 	if (!dev)
3834 		return -ENOMEM;
3835 	dev->plat_dev = pdev;
3836 	init_completion(&dev->init_complete);
3837 	INIT_LIST_HEAD(&dev->channels);
3838 
3839 	mutex_init(&dev->lock);
3840 
3841 	dev->initialized = false;
3842 
3843 	res = platform_get_resource_byname(pdev, IORESOURCE_MEM, "regs");
3844 	if (!res) {
3845 		dev_err(&pdev->dev,
3846 			"regs resource missing from device tree\n");
3847 		return -EINVAL;
3848 	}
3849 	regs = devm_ioremap(&pdev->dev, res->start, resource_size(res));
3850 	if (!regs) {
3851 		dev_err(&pdev->dev, "failed to map registers\n");
3852 		return -ENOMEM;
3853 	}
3854 	dev->regmap = devm_regmap_init_mmio(&pdev->dev, regs,
3855 					    &allegro_regmap_config);
3856 	if (IS_ERR(dev->regmap)) {
3857 		dev_err(&pdev->dev, "failed to init regmap\n");
3858 		return PTR_ERR(dev->regmap);
3859 	}
3860 
3861 	sram_res = platform_get_resource_byname(pdev, IORESOURCE_MEM, "sram");
3862 	if (!sram_res) {
3863 		dev_err(&pdev->dev,
3864 			"sram resource missing from device tree\n");
3865 		return -EINVAL;
3866 	}
3867 	sram_regs = devm_ioremap(&pdev->dev,
3868 				 sram_res->start,
3869 				 resource_size(sram_res));
3870 	if (!sram_regs) {
3871 		dev_err(&pdev->dev, "failed to map sram\n");
3872 		return -ENOMEM;
3873 	}
3874 	dev->sram = devm_regmap_init_mmio(&pdev->dev, sram_regs,
3875 					  &allegro_sram_config);
3876 	if (IS_ERR(dev->sram)) {
3877 		dev_err(&pdev->dev, "failed to init sram\n");
3878 		return PTR_ERR(dev->sram);
3879 	}
3880 
3881 	dev->settings = syscon_regmap_lookup_by_compatible("xlnx,vcu-settings");
3882 	if (IS_ERR(dev->settings))
3883 		dev_warn(&pdev->dev, "failed to open settings\n");
3884 
3885 	dev->clk_core = devm_clk_get(&pdev->dev, "core_clk");
3886 	if (IS_ERR(dev->clk_core))
3887 		return PTR_ERR(dev->clk_core);
3888 
3889 	dev->clk_mcu = devm_clk_get(&pdev->dev, "mcu_clk");
3890 	if (IS_ERR(dev->clk_mcu))
3891 		return PTR_ERR(dev->clk_mcu);
3892 
3893 	irq = platform_get_irq(pdev, 0);
3894 	if (irq < 0)
3895 		return irq;
3896 	ret = devm_request_threaded_irq(&pdev->dev, irq,
3897 					allegro_hardirq,
3898 					allegro_irq_thread,
3899 					IRQF_SHARED, dev_name(&pdev->dev), dev);
3900 	if (ret < 0) {
3901 		dev_err(&pdev->dev, "failed to request irq: %d\n", ret);
3902 		return ret;
3903 	}
3904 
3905 	ret = v4l2_device_register(&pdev->dev, &dev->v4l2_dev);
3906 	if (ret)
3907 		return ret;
3908 
3909 	platform_set_drvdata(pdev, dev);
3910 
3911 	ret = allegro_firmware_request_nowait(dev);
3912 	if (ret < 0) {
3913 		v4l2_err(&dev->v4l2_dev,
3914 			 "failed to request firmware: %d\n", ret);
3915 		return ret;
3916 	}
3917 
3918 	return 0;
3919 }
3920 
3921 static void allegro_remove(struct platform_device *pdev)
3922 {
3923 	struct allegro_dev *dev = platform_get_drvdata(pdev);
3924 
3925 	if (dev->initialized) {
3926 		video_unregister_device(&dev->video_dev);
3927 		if (dev->m2m_dev)
3928 			v4l2_m2m_release(dev->m2m_dev);
3929 		allegro_mcu_hw_deinit(dev);
3930 		allegro_free_fw_codec(dev);
3931 	}
3932 
3933 	pm_runtime_put(&dev->plat_dev->dev);
3934 	pm_runtime_disable(&dev->plat_dev->dev);
3935 
3936 	v4l2_device_unregister(&dev->v4l2_dev);
3937 }
3938 
3939 static int allegro_runtime_resume(struct device *device)
3940 {
3941 	struct allegro_dev *dev = dev_get_drvdata(device);
3942 	struct regmap *settings = dev->settings;
3943 	unsigned int clk_mcu;
3944 	unsigned int clk_core;
3945 	int err;
3946 
3947 	if (!settings)
3948 		return -EINVAL;
3949 
3950 #define MHZ_TO_HZ(freq) ((freq) * 1000 * 1000)
3951 
3952 	err = regmap_read(settings, VCU_CORE_CLK, &clk_core);
3953 	if (err < 0)
3954 		return err;
3955 	err = clk_set_rate(dev->clk_core, MHZ_TO_HZ(clk_core));
3956 	if (err < 0)
3957 		return err;
3958 	err = clk_prepare_enable(dev->clk_core);
3959 	if (err)
3960 		return err;
3961 
3962 	err = regmap_read(settings, VCU_MCU_CLK, &clk_mcu);
3963 	if (err < 0)
3964 		goto disable_clk_core;
3965 	err = clk_set_rate(dev->clk_mcu, MHZ_TO_HZ(clk_mcu));
3966 	if (err < 0)
3967 		goto disable_clk_core;
3968 	err = clk_prepare_enable(dev->clk_mcu);
3969 	if (err)
3970 		goto disable_clk_core;
3971 
3972 #undef MHZ_TO_HZ
3973 
3974 	return 0;
3975 
3976 disable_clk_core:
3977 	clk_disable_unprepare(dev->clk_core);
3978 
3979 	return err;
3980 }
3981 
3982 static int allegro_runtime_suspend(struct device *device)
3983 {
3984 	struct allegro_dev *dev = dev_get_drvdata(device);
3985 
3986 	clk_disable_unprepare(dev->clk_mcu);
3987 	clk_disable_unprepare(dev->clk_core);
3988 
3989 	return 0;
3990 }
3991 
3992 static const struct of_device_id allegro_dt_ids[] = {
3993 	{ .compatible = "allegro,al5e-1.1" },
3994 	{ /* sentinel */ }
3995 };
3996 
3997 MODULE_DEVICE_TABLE(of, allegro_dt_ids);
3998 
3999 static const struct dev_pm_ops allegro_pm_ops = {
4000 	.runtime_resume = allegro_runtime_resume,
4001 	.runtime_suspend = allegro_runtime_suspend,
4002 };
4003 
4004 static struct platform_driver allegro_driver = {
4005 	.probe = allegro_probe,
4006 	.remove_new = allegro_remove,
4007 	.driver = {
4008 		.name = "allegro",
4009 		.of_match_table = allegro_dt_ids,
4010 		.pm = &allegro_pm_ops,
4011 	},
4012 };
4013 
4014 module_platform_driver(allegro_driver);
4015 
4016 MODULE_LICENSE("GPL");
4017 MODULE_AUTHOR("Michael Tretter <kernel@pengutronix.de>");
4018 MODULE_DESCRIPTION("Allegro DVT encoder driver");
4019