ark1668e_vin.c 58 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859186018611862186318641865186618671868186918701871187218731874187518761877187818791880188118821883188418851886188718881889189018911892189318941895189618971898189919001901190219031904190519061907190819091910191119121913191419151916191719181919192019211922192319241925192619271928192919301931193219331934193519361937193819391940194119421943
  1. /*
  2. * Arkmicro v4l2 driver
  3. *
  4. * Licensed under GPLv2 or later.
  5. */
  6. #include <linux/clk.h>
  7. #include <linux/clkdev.h>
  8. #include <linux/clk-provider.h>
  9. #include <linux/delay.h>
  10. #include <linux/interrupt.h>
  11. #include <linux/math64.h>
  12. #include <linux/module.h>
  13. #include <linux/of.h>
  14. #include <linux/of_graph.h>
  15. #include <linux/platform_device.h>
  16. #include <linux/pm_runtime.h>
  17. #include <linux/regmap.h>
  18. #include <linux/videodev2.h>
  19. #include <linux/kernel.h>
  20. #include <linux/init.h>
  21. #include <linux/mm.h>
  22. #include <linux/slab.h>
  23. #include <linux/fs.h>
  24. #include <linux/errno.h>
  25. #include <asm/uaccess.h>
  26. #include <linux/list.h>
  27. #include <linux/sched.h>
  28. #include <linux/poll.h>
  29. #include <linux/gpio.h>
  30. #include <asm/setup.h>
  31. #include <linux/dma-mapping.h>
  32. #include <media/v4l2-ctrls.h>
  33. #include <media/v4l2-device.h>
  34. #include <media/v4l2-event.h>
  35. #include <media/v4l2-image-sizes.h>
  36. #include <media/v4l2-ioctl.h>
  37. #include <media/v4l2-fwnode.h>
  38. #include <media/v4l2-subdev.h>
  39. #include <media/videobuf2-dma-contig.h>
  40. #include "ark1668e_vin.h"
  41. extern int ark_vin_display_init(int layer,int src_width, int src_height,int out_posx, int out_posy);
  42. extern int ark_vin_display_addr(unsigned int addr);
  43. extern int ark_vin_get_display_addr(void);
  44. extern int ark1668e_lcdc_wait_for_vsync(void);
  45. extern int ark_vin_get_screen_info(int* width,int* height);
  46. extern int ark_disp_set_layer_en(int layer_id, int enable);
  47. extern int ark_scale_start(struct ark_scale_context *context, struct ark_scale_param *param);
  48. int dvr_enter_carback(void);
  49. int dvr_exit_carback(void);
  50. static int vin_start(struct dvr_dev *dvr_dev);
  51. static void vin_init(struct ark1668e_vin_device *vin, struct vin_para *para);
  52. static int vin_exit(void);
  53. static inline void vin_reset(void);
  54. static int vin_aux_config(struct vin_para* para);
  55. static int vin_aux_start(struct dvr_dev *dvr_dev);
  56. static void vin_aux_exit(void);
  57. static inline void ark_vin_disable_write(void);
  58. static inline void ark_vin_enable_write(void);
  59. extern unsigned int g_screen_width;
  60. extern unsigned int g_screen_height;
  61. struct ark1668e_vin_device* g_ark1668e_vin = NULL;
  62. struct ark_scale_param scale_param;
  63. extern struct ark_scale_context *scale_context;
  64. static int vin_queue_setup(struct vb2_queue *vq,
  65. unsigned int *nbuffers, unsigned int *nplanes,
  66. unsigned int sizes[], struct device *alloc_devs[])
  67. {
  68. struct ark1668e_vin_device* ark_vin = vb2_get_drv_priv(vq);
  69. unsigned int size = ark_vin->fmt.fmt.pix.sizeimage;
  70. if (*nplanes)
  71. return sizes[0] < size ? -EINVAL : 0;
  72. *nplanes = 1;
  73. sizes[0] = size;
  74. return 0;
  75. }
  76. static int vin_buffer_init(struct vb2_buffer *vb)
  77. {
  78. return 0;
  79. }
  80. static int vin_buffer_prepare(struct vb2_buffer *vb)
  81. {
  82. struct vb2_v4l2_buffer *vbuf = to_vb2_v4l2_buffer(vb);
  83. struct ark1668e_vin_device* ark_vin = vb2_get_drv_priv(vb->vb2_queue);
  84. unsigned long size = ark_vin->fmt.fmt.pix.sizeimage;
  85. if (vb2_plane_size(vb, 0) < size) {
  86. v4l2_err(&ark_vin->v4l2_dev, "buffer too small (%lu < %lu)\n",
  87. vb2_plane_size(vb, 0), size);
  88. return -EINVAL;
  89. }
  90. vb2_set_plane_payload(vb, 0, size);
  91. vbuf->field = ark_vin->fmt.fmt.pix.field;
  92. return 0;
  93. }
  94. static int vin_config(void)
  95. {
  96. struct ark1668e_vin_device* vin = NULL;
  97. int ret;
  98. vin = g_ark1668e_vin;
  99. memset(&vin->dvr_dev->itu656in,0,sizeof(struct vin_para));
  100. vin->dvr_dev->itu656in.source = DVR_SOURCE_CAMERA;
  101. if(!vin->sd_init){
  102. ret = v4l2_subdev_call(vin->current_subdev->sd,core,init,0);
  103. if(ret < 0){
  104. printk(KERN_ALERT "%s %d: v4l2_subdev_call error \n",__FUNCTION__, __LINE__);
  105. return ret;
  106. }
  107. vin->sd_init = 1;
  108. }
  109. if(vin->dvr_dev->chip_info == TYPE_RN6752){
  110. ret = v4l2_subdev_call(vin->current_subdev->sd,core,ioctl,VIDIOC_ENTER_CARBACK,0);
  111. if(ret < 0){
  112. printk(KERN_ALERT "%s %d: v4l2_subdev_call error \n",__FUNCTION__, __LINE__);
  113. return ret;
  114. }
  115. }
  116. spin_lock(&vin->dvr_dev->spin_lock);
  117. ret = v4l2_subdev_call(vin->current_subdev->sd,core,ioctl,VIDIOC_GET_ITU601_ENABLE,&vin->dvr_dev->itu656in.itu601en);
  118. if(ret < 0){
  119. printk(KERN_ALERT "%s %d: v4l2_subdev_call error \n",__FUNCTION__, __LINE__);
  120. return ret;
  121. }
  122. ret = v4l2_subdev_call(vin->current_subdev->sd,core,ioctl,VIDIOC_GET_PROGRESSIVE,&vin->dvr_dev->itu656in.progressive);
  123. if(ret < 0){
  124. printk(KERN_ALERT "%s %d: v4l2_subdev_call error \n",__FUNCTION__, __LINE__);
  125. return ret;
  126. }
  127. memcpy(&vin->dvr_dev->itu656in_back, &vin->dvr_dev->itu656in, sizeof(struct vin_para));
  128. vin_reset();
  129. vin_init(vin, &vin->dvr_dev->itu656in);
  130. vin->dvr_dev->channel = g_ark1668e_vin->app_channel_set;
  131. vin_start(vin->dvr_dev);
  132. spin_unlock(&vin->dvr_dev->spin_lock);
  133. return 0;
  134. }
  135. static int vin_aux_config(struct vin_para* para)
  136. {
  137. struct ark1668e_vin_device* vin = NULL;
  138. int ret = 0;
  139. vin = g_ark1668e_vin;
  140. memset(&vin->dvr_dev->itu656in,0,sizeof(struct vin_para));
  141. vin->vin_status = vin->stream_flag;
  142. vin->stream_flag = false;
  143. vin->aux_flag = 1;
  144. if(!vin->sd_init){
  145. ret = v4l2_subdev_call(vin->current_subdev->sd,core,init,0);
  146. if(ret < 0){
  147. printk(KERN_ALERT "%s %d: v4l2_subdev_call error \n",__FUNCTION__, __LINE__);
  148. return ret;
  149. }
  150. vin->sd_init = 1;
  151. }
  152. if(vin->dvr_dev->chip_info == TYPE_RN6752){
  153. ret = v4l2_subdev_call(vin->current_subdev->sd,core,ioctl,VIDIOC_ENTER_CARBACK,0);
  154. if(ret < 0){
  155. printk(KERN_ALERT "%s %d: v4l2_subdev_call error \n",__FUNCTION__, __LINE__);
  156. return ret;
  157. }
  158. }
  159. spin_lock(&vin->dvr_dev->spin_lock);
  160. ret = v4l2_subdev_call(vin->current_subdev->sd,core,ioctl,VIDIOC_GET_ITU601_ENABLE,&vin->dvr_dev->itu656in.itu601en);
  161. if(ret < 0){
  162. printk(KERN_ALERT "%s %d: v4l2_subdev_call error \n",__FUNCTION__, __LINE__);
  163. return ret;
  164. }
  165. ret = v4l2_subdev_call(vin->current_subdev->sd,core,ioctl,VIDIOC_GET_PROGRESSIVE,&vin->dvr_dev->itu656in.progressive);
  166. if(ret < 0){
  167. printk(KERN_ALERT "%s %d: v4l2_subdev_call error \n",__FUNCTION__, __LINE__);
  168. return ret;
  169. }
  170. para->itu601en = vin->dvr_dev->itu656in.itu601en;
  171. para->progressive = vin->dvr_dev->itu656in.progressive;
  172. vin->dvr_dev->itu601en = para->itu601en;
  173. vin->dvr_dev->interlace = !para->progressive;
  174. memcpy(&vin->dvr_dev->itu656in_back, para, sizeof(struct vin_para));
  175. vin_reset();
  176. vin->dvr_dev->scale_framebuf_index = 0;
  177. vin->dvr_dev->carback_exit_status = 0;
  178. spin_unlock(&vin->dvr_dev->spin_lock);
  179. return 0;
  180. }
  181. static void vin_setaddr(struct ark1668e_vin_device *vin)
  182. {
  183. dma_addr_t addr_dma;
  184. /* Get the physical address of the assigned BUF */
  185. addr_dma = vb2_dma_contig_plane_dma_addr(&vin->cur_frm->vb.vb2_buf, 0);
  186. //printk("vin_setaddr addr_dma : 0x%x\n",addr_dma);
  187. vin_writel(ARK1668E_ITU656_DRAM_DEST1, addr_dma);
  188. vin_writel(ARK1668E_ITU656_DRAM_DEST1,addr_dma + vin->dvr_dev->src_width*vin->dvr_dev->src_height);
  189. }
  190. static inline void vin_reset(void)
  191. {
  192. //soft reset
  193. vin_writel_sys(ARK1668E_SYS_SOFT_RSTNA, vin_readl_sys(ARK1668E_SYS_SOFT_RSTNA)& ~(1 << 9));
  194. msleep(1);
  195. vin_writel_sys(ARK1668E_SYS_SOFT_RSTNA, vin_readl_sys(ARK1668E_SYS_SOFT_RSTNA)| (1 << 9));
  196. //addr reset
  197. vin_writel(ARK1668E_ITU656_RESET,vin_readl(ARK1668E_ITU656_RESET) | (1 << 1));
  198. msleep(1);
  199. vin_writel(ARK1668E_ITU656_RESET,vin_readl(ARK1668E_ITU656_RESET) & ~(1 << 1));
  200. }
  201. static int vin_start_streaming(struct vb2_queue *vq, unsigned int count)
  202. {
  203. struct ark1668e_vin_device *vin = vb2_get_drv_priv(vq);
  204. vin->stream_flag = true;
  205. vin_config();
  206. //spin_lock_irqsave(&vin->ark_queue_lock, flags);
  207. vin->sequence = 0;
  208. vin->stop = false;
  209. reinit_completion(&vin->comp);
  210. vin->cur_frm = list_first_entry(&vin->ark_queue,struct vin_buffer, list);
  211. //printk(KERN_DEBUG "start_streaming->get out buf: %p\n",vin->cur_frm->vb.vb2_buf.planes[0].mem_priv);
  212. list_del(&vin->cur_frm->list);
  213. vin_setaddr(vin);
  214. //spin_unlock_irqrestore(&vin->ark_queue_lock, flags);
  215. return 0;
  216. }
  217. static void vin_stop_streaming(struct vb2_queue *vq)
  218. {
  219. struct ark1668e_vin_device* ark_vin = vb2_get_drv_priv(vq);
  220. struct vin_buffer *buf;
  221. ark_vin->stop = true;
  222. ark_vin->stream_flag = false;
  223. vin_exit();
  224. /* Release all active buffers */
  225. //spin_lock_irqsave(&ark_vin->ark_queue_lock, flags);
  226. if (unlikely(ark_vin->cur_frm)) {
  227. vb2_buffer_done(&ark_vin->cur_frm->vb.vb2_buf,
  228. VB2_BUF_STATE_ERROR);
  229. ark_vin->cur_frm = NULL;
  230. }
  231. list_for_each_entry(buf, &ark_vin->ark_queue, list)
  232. vb2_buffer_done(&buf->vb.vb2_buf, VB2_BUF_STATE_ERROR);
  233. INIT_LIST_HEAD(&ark_vin->ark_queue);
  234. //spin_unlock_irqrestore(&ark_vin->ark_queue_lock, flags);
  235. }
  236. static void vin_buffer_queue(struct vb2_buffer *vb)
  237. {
  238. struct vb2_v4l2_buffer *vbuf = to_vb2_v4l2_buffer(vb);
  239. struct vin_buffer *buf = container_of(vbuf, struct vin_buffer, vb);
  240. struct ark1668e_vin_device *vin = vb2_get_drv_priv(vb->vb2_queue);
  241. dma_addr_t addr_dma;
  242. addr_dma = vb2_dma_contig_plane_dma_addr(vb, 0);
  243. /*app buf physical address can be obtained directly from this variable */
  244. vb->planes[0].m.offset = addr_dma;
  245. //printk(KERN_DEBUG "!vin->cur_frm = %d,list_empty(&vin->ark_queue)= %d,vb2_is_streaming(vb->vb2_queue) = %d\n",!vin->cur_frm,list_empty(&vin->ark_queue),vb2_is_streaming(vb->vb2_queue));
  246. if (!vin->cur_frm && list_empty(&vin->ark_queue) && vb2_is_streaming(vb->vb2_queue)){
  247. vin->cur_frm = buf;
  248. vin_setaddr(vin);
  249. }
  250. else{
  251. /* add buf to list */
  252. list_add_tail(&buf->list, &vin->ark_queue);
  253. if(!vb2_is_streaming(vb->vb2_queue)){
  254. printk(KERN_DEBUG "init buff.\n");
  255. vin->cur_frm = buf;
  256. vin_setaddr(vin);
  257. }
  258. }
  259. }
  260. static const struct vb2_ops vin_vb2_ops = {
  261. .queue_setup = vin_queue_setup,
  262. .buf_init = vin_buffer_init,
  263. .wait_prepare = vb2_ops_wait_prepare,
  264. .wait_finish = vb2_ops_wait_finish,
  265. .buf_prepare = vin_buffer_prepare,
  266. .start_streaming = vin_start_streaming,
  267. .stop_streaming = vin_stop_streaming,
  268. .buf_queue = vin_buffer_queue,
  269. };
  270. static int vin_querycap(struct file *file, void *priv,struct v4l2_capability *cap)
  271. {
  272. strcpy(cap->driver, ARK_VIN_NAME);
  273. strcpy(cap->card, "Ark videoin driver");
  274. cap->capabilities = V4L2_CAP_VIDEO_CAPTURE;
  275. return 0;
  276. }
  277. static int vin_enum_fmt_vid_cap(struct file *file, void *priv,struct v4l2_fmtdesc *f)
  278. {
  279. u32 index = f->index;
  280. if (index >= 1)
  281. return -EINVAL;
  282. f->pixelformat = V4L2_PIX_FMT_VYUY;
  283. return 0;
  284. }
  285. static int vin_g_fmt_vid_cap(struct file *file, void *priv,struct v4l2_format *fmt)
  286. {
  287. struct ark1668e_vin_device *vin = video_drvdata(file);
  288. *fmt = vin->fmt;
  289. return 0;
  290. }
  291. static int vin_try_fmt(struct ark1668e_vin_device *vin, struct v4l2_format *f)
  292. {
  293. struct v4l2_pix_format *pixfmt = &f->fmt.pix;
  294. if (f->type != V4L2_BUF_TYPE_VIDEO_CAPTURE)
  295. return -EINVAL;
  296. if(pixfmt->width == 0 || pixfmt->height == 0){
  297. printk(KERN_ALERT "pixfmt width is null\n");
  298. return -EINVAL;
  299. }
  300. pixfmt->field = V4L2_FIELD_ANY;
  301. pixfmt->bytesperline = (pixfmt->width * 16) >> 3;
  302. pixfmt->sizeimage = pixfmt->width * pixfmt->height * 3 / 2;
  303. printk(KERN_DEBUG "pixfmt->width = %d.\n",pixfmt->width);
  304. printk(KERN_DEBUG "pixfmt->height = %d.\n",pixfmt->height);
  305. printk(KERN_DEBUG "pixfmt->bytesperline = %d.\n",pixfmt->bytesperline);
  306. printk(KERN_DEBUG "pixfmt->sizeimage = %d.\n",pixfmt->sizeimage);
  307. return 0;
  308. }
  309. static int vin_set_fmt(struct ark1668e_vin_device *vin, struct v4l2_format *f)
  310. {
  311. int ret;
  312. ret = vin_try_fmt(vin, f);
  313. if (ret)
  314. return ret;
  315. vin_reset();
  316. vin->fmt = *f;
  317. return 0;
  318. }
  319. static int vin_try_fmt_vid_cap(struct file *file, void *priv,struct v4l2_format *f)
  320. {
  321. struct ark1668e_vin_device *ark_vin = video_drvdata(file);
  322. return vin_try_fmt(ark_vin, f);
  323. }
  324. static int vin_s_fmt_vid_cap(struct file *file, void *priv,struct v4l2_format *f)
  325. {
  326. struct ark1668e_vin_device *ark_vin = video_drvdata(file);
  327. if (vb2_is_streaming(&ark_vin->vb2_vidq))
  328. return -EBUSY;
  329. return vin_set_fmt(ark_vin, f);
  330. }
  331. static int vin_enum_input(struct file *file, void *priv,struct v4l2_input *inp)
  332. {
  333. if (inp->index != 0)
  334. return -EINVAL;
  335. inp->type = V4L2_INPUT_TYPE_CAMERA;
  336. inp->std = 0;
  337. strcpy(inp->name, "Camera");
  338. return 0;
  339. }
  340. static int vin_g_input(struct file *file, void *priv, unsigned int *i)
  341. {
  342. struct ark1668e_vin_device* vin = NULL;
  343. vin = g_ark1668e_vin;
  344. *i = vin->dvr_dev->carback_signal;
  345. return vin->dvr_dev->carback_signal;
  346. }
  347. static int vin_s_input(struct file *file, void *priv, unsigned int i)
  348. {
  349. g_ark1668e_vin->app_channel_set = i;
  350. if (i > 0)
  351. return -EINVAL;
  352. return 0;
  353. }
  354. static long vin_ioctl_default(struct file *file, void *priv,
  355. bool valid_prio, unsigned int cmd, void *param)
  356. {
  357. struct dvr_dev *dvr_dev =g_ark1668e_vin->dvr_dev;
  358. unsigned long error = 0;
  359. if(!dvr_dev){
  360. printk(KERN_ERR"%s error null device", __func__);
  361. return -ENXIO;
  362. }
  363. //spin_lock_irqsave(&dvr_dev->spin_lock, flags);
  364. switch (cmd)
  365. {
  366. case VIN_UPDATE_WINDOW:
  367. {
  368. struct vin_screen *vout_para = (struct vin_screen *)param;
  369. if(!dvr_dev->carback_exit_status){
  370. dvr_dev->work_status = 0;
  371. ark_vin_disable_write();
  372. //flush_workqueue(dvr_dev->scale_queue);
  373. mdelay(20);
  374. dvr_dev->screen_xpos = vout_para->disp_x;
  375. dvr_dev->screen_ypos = vout_para->disp_y;
  376. dvr_dev->screen_width = vout_para->disp_width;
  377. dvr_dev->screen_height = vout_para->disp_height;
  378. printk(KERN_INFO "set carback win-->w:%d,h%d,x:%d,y%d\n",dvr_dev->screen_width,dvr_dev->screen_height,vout_para->disp_x,vout_para->disp_y);
  379. error = ark_vin_display_init(DISPLAY_LAYER,dvr_dev->screen_width,dvr_dev->screen_height,dvr_dev->screen_xpos,dvr_dev->screen_ypos);
  380. dvr_dev->work_status = 1;
  381. ark_vin_enable_write();
  382. if( error < 0 )
  383. return error;
  384. }
  385. else{
  386. dvr_dev->screen_xpos = vout_para->disp_x;
  387. dvr_dev->screen_ypos = vout_para->disp_y;
  388. dvr_dev->screen_width = vout_para->disp_width;
  389. dvr_dev->screen_height = vout_para->disp_height;
  390. printk(KERN_INFO "set carback win-->w:%d,h%d,x:%d,y%d\n",dvr_dev->screen_width,dvr_dev->screen_height,vout_para->disp_x,vout_para->disp_y);
  391. error = ark_vin_display_init(DISPLAY_LAYER,dvr_dev->screen_width,dvr_dev->screen_height,dvr_dev->screen_xpos,dvr_dev->screen_ypos);
  392. if( error < 0 )
  393. return error;
  394. }
  395. break;
  396. }
  397. case VIN_START:
  398. {
  399. g_ark1668e_vin->aux_status = 1;
  400. vin_aux_start(dvr_dev);
  401. break;
  402. }
  403. case VIN_STOP:
  404. {
  405. vin_aux_exit();
  406. g_ark1668e_vin->aux_flag = 0;
  407. g_ark1668e_vin->aux_status = 0;
  408. break;
  409. }
  410. case VIN_SWITCH_CHANNEL:
  411. {
  412. int source = *((int *)param);
  413. if (source == DVR_SOURCE_AUX)
  414. dvr_dev->channel = ARK7116_AV1;
  415. else if (source == DVR_SOURCE_CAMERA)
  416. dvr_dev->channel = ARK7116_AV0;
  417. else if (source == DVR_SOURCE_DVD)
  418. dvr_dev->channel = ARK7116_AV2;
  419. else {
  420. dvr_dev->channel = source;
  421. }
  422. g_ark1668e_vin->app_channel_set = source;
  423. break;
  424. }
  425. case VIN_CONFIG:
  426. {
  427. struct vin_para *para = (struct vin_para *)param;
  428. vin_aux_config(para);
  429. break;
  430. }
  431. default:
  432. printk("%s: error cmd 0x%x\n", __func__, cmd);
  433. error = -EFAULT;
  434. goto end;
  435. }
  436. return 0;
  437. end:
  438. //spin_unlock_irqrestore(&dvr_dev->spin_lock, flags);
  439. return error;
  440. }
  441. static const struct v4l2_ioctl_ops vin_ioctl_ops = {
  442. .vidioc_querycap = vin_querycap,
  443. .vidioc_enum_fmt_vid_cap = vin_enum_fmt_vid_cap,
  444. .vidioc_g_fmt_vid_cap = vin_g_fmt_vid_cap,
  445. .vidioc_s_fmt_vid_cap = vin_s_fmt_vid_cap,
  446. .vidioc_try_fmt_vid_cap = vin_try_fmt_vid_cap,
  447. .vidioc_enum_input = vin_enum_input,
  448. .vidioc_g_input = vin_g_input,
  449. .vidioc_s_input = vin_s_input,
  450. .vidioc_reqbufs = vb2_ioctl_reqbufs,
  451. .vidioc_querybuf = vb2_ioctl_querybuf,
  452. .vidioc_qbuf = vb2_ioctl_qbuf,
  453. .vidioc_dqbuf = vb2_ioctl_dqbuf,
  454. .vidioc_streamon = vb2_ioctl_streamon,
  455. .vidioc_streamoff = vb2_ioctl_streamoff,
  456. .vidioc_default = vin_ioctl_default,
  457. };
  458. static int vin_open(struct file *file)
  459. {
  460. struct ark1668e_vin_device* ark_vin = video_drvdata(file);
  461. int ret;
  462. if (mutex_lock_interruptible(&ark_vin->lock))
  463. return -ERESTARTSYS;
  464. ret = v4l2_fh_open(file);
  465. if (ret < 0)
  466. goto unlock;
  467. if (!v4l2_fh_is_singular_file(file))
  468. goto unlock;
  469. unlock:
  470. mutex_unlock(&ark_vin->lock);
  471. return ret;
  472. }
  473. static int vin_release(struct file *file)
  474. {
  475. struct ark1668e_vin_device* ark_vin = video_drvdata(file);
  476. bool fh_singular;
  477. int ret;
  478. mutex_lock(&ark_vin->lock);
  479. fh_singular = v4l2_fh_is_singular_file(file);
  480. ret = _vb2_fop_release(file, NULL);
  481. mutex_unlock(&ark_vin->lock);
  482. return 0;
  483. }
  484. static const struct v4l2_file_operations vin_fops = {
  485. .owner = THIS_MODULE,
  486. .open = vin_open,
  487. .release = vin_release,
  488. .unlocked_ioctl = video_ioctl2,
  489. .read = vb2_fop_read,
  490. .mmap = vb2_fop_mmap,
  491. .poll = vb2_fop_poll,
  492. };
  493. #if 0
  494. static int deinterlace_process (unsigned int deinterlace_size, unsigned int data_mode, unsigned int deinterlace_type,
  495. unsigned int deinterlace_field, unsigned int src_field_addr_0, unsigned int src_field_addr_1,unsigned int src_field_addr_2,
  496. unsigned int dst_y_addr, unsigned int dst_u_addr, unsigned int dst_v_addr)
  497. {
  498. }
  499. #endif
  500. static inline void ark_vin_disable_write(void)
  501. {
  502. vin_writel(ARK1668E_ITU656_MODULE_EN,vin_readl(ARK1668E_ITU656_MODULE_EN) | (1 << 2));
  503. }
  504. static inline void ark_vin_enable_write(void)
  505. {
  506. vin_writel(ARK1668E_ITU656_MODULE_EN,vin_readl(ARK1668E_ITU656_MODULE_EN) & ~(1 << 2));
  507. }
  508. void ark_vin_disable(void)
  509. {
  510. vin_writel(ARK1668E_ITU656_IMR, 0);
  511. vin_writel(ARK1668E_ITU656_ENABLE_REG,vin_readl(ARK1668E_ITU656_ENABLE_REG) & ~(1 << 0));
  512. }
  513. void vin_alloc_buf(int type)
  514. {
  515. struct ark1668e_vin_device* vin = NULL;
  516. int i;
  517. vin = g_ark1668e_vin;
  518. printk("vin_alloc_buf buffer_size = %d\n",vin->dvr_dev->buffer_size);
  519. #if 0
  520. vin->dvr_dev->buffer_virtaddr = (void *)__get_free_pages(GFP_KERNEL, get_order(vin->dvr_dev->buffer_size));
  521. if (!vin->dvr_dev->buffer_virtaddr) {
  522. printk(KERN_ALERT "%s get. buffer_virtaddr fail\n", __func__);
  523. }
  524. vin->dvr_dev->buffer_phyaddr = virt_to_phys(vin->dvr_dev->buffer_virtaddr);
  525. for(i = 0; i < vin->dvr_dev->framebuf_num; i++){
  526. if(type == TYPE_1080P){
  527. vin->dvr_dev->framebuf_phyaddr[i] = vin->dvr_dev->buffer_phyaddr + ITU656_PROGRESSIVE_FRAME_SIZE_1080P*i;
  528. }
  529. else if(type == TYPE_720P){
  530. vin->dvr_dev->framebuf_phyaddr[i] = vin->dvr_dev->buffer_phyaddr + ITU656_PROGRESSIVE_FRAME_SIZE*i;
  531. }
  532. else{
  533. vin->dvr_dev->framebuf_phyaddr[i] = vin->dvr_dev->buffer_phyaddr + ITU656_FRAME_SIZE*i;
  534. }
  535. }
  536. vin->dvr_dev->scale_out_yaddr = (void *)__get_free_pages(GFP_KERNEL, get_order(vin->dvr_dev->scale_alloc_width*vin->dvr_dev->scale_alloc_height*2));
  537. if (!vin->dvr_dev->scale_out_yaddr) {
  538. printk(KERN_ALERT "%s get. scale_out_yaddr fail\n", __func__);
  539. }
  540. vin->dvr_dev->scale_out_yphyaddr = virt_to_phys(vin->dvr_dev->scale_out_yaddr);
  541. #else
  542. vin->dvr_dev->buffer_virtaddr = dma_alloc_wc(vin->dev, vin->dvr_dev->buffer_size,
  543. (dma_addr_t *)&vin->dvr_dev->buffer_phyaddr,
  544. GFP_KERNEL);
  545. if (!vin->dvr_dev->buffer_virtaddr){
  546. printk(KERN_ALERT "%s dma_alloc_wc fail\n", __func__);
  547. }
  548. for(i = 0; i < vin->dvr_dev->framebuf_num; i++){
  549. if(type == TYPE_1080P){
  550. vin->dvr_dev->framebuf_phyaddr[i] = vin->dvr_dev->buffer_phyaddr + ITU656_PROGRESSIVE_FRAME_SIZE_1080P*i;
  551. }
  552. else if(type == TYPE_720P){
  553. vin->dvr_dev->framebuf_phyaddr[i] = vin->dvr_dev->buffer_phyaddr + ITU656_PROGRESSIVE_FRAME_SIZE*i;
  554. }
  555. else{
  556. vin->dvr_dev->framebuf_phyaddr[i] = vin->dvr_dev->buffer_phyaddr + ITU656_FRAME_SIZE*i;
  557. }
  558. }
  559. vin->dvr_dev->scale_out_yaddr = dma_alloc_wc(vin->dev, vin->dvr_dev->scale_buffer_size,
  560. (dma_addr_t *)&vin->dvr_dev->scale_out_yphyaddr,
  561. GFP_KERNEL);
  562. if (!vin->dvr_dev->scale_out_yaddr){
  563. printk(KERN_ALERT "%s dma_alloc_wc fail\n", __func__);
  564. }
  565. for(i = 0; i < vin->dvr_dev->scale_framebuf_num; i++){
  566. vin->dvr_dev->scalebuf_phyaddr[i] = vin->dvr_dev->scale_out_yphyaddr + vin->dvr_dev->scale_alloc_width*vin->dvr_dev->scale_alloc_height*2*i;
  567. }
  568. #endif
  569. }
  570. void dvr_restart(void)
  571. {
  572. struct ark1668e_vin_device* vin = NULL;
  573. int ret;
  574. vin = g_ark1668e_vin;
  575. if(!vin->dvr_dev->carback_exit_status)
  576. {
  577. ret = v4l2_subdev_call(vin->current_subdev->sd,core,ioctl,VIDIOC_GET_PROGRESSIVE,&vin->dvr_dev->itu656in.progressive);
  578. if(ret < 0)
  579. printk(KERN_ALERT "%s %d: v4l2_subdev_call error \n",__FUNCTION__, __LINE__);
  580. vin->dvr_dev->interlace = !vin->dvr_dev->itu656in.progressive;
  581. ark_vin_disable_write();
  582. mod_timer(&vin->dvr_dev->timer, jiffies + msecs_to_jiffies(50));
  583. }
  584. }
  585. EXPORT_SYMBOL(dvr_restart);
  586. int dvr_enter_carback(void)
  587. {
  588. struct ark1668e_vin_device* vin = NULL;
  589. int ret;
  590. vin = g_ark1668e_vin;
  591. memset(&vin->dvr_dev->itu656in,0,sizeof(struct vin_para));
  592. if(vin->aux_flag){
  593. vin->aux_status = vin->aux_flag;
  594. vin_aux_exit();
  595. }
  596. vin->dvr_dev->itu656in.source = DVR_SOURCE_CAMERA;
  597. vin->vin_status = vin->stream_flag;
  598. //vin->dvr_dev->itu656in.itu601en = 1;
  599. vin->stream_flag = false;
  600. if(!vin->sd_init){
  601. ret = v4l2_subdev_call(vin->current_subdev->sd,core,init,0);
  602. if(ret < 0){
  603. printk(KERN_ALERT "%s %d: v4l2_subdev_call error \n",__FUNCTION__, __LINE__);
  604. return ret;
  605. }
  606. vin->sd_init = 1;
  607. }
  608. if(vin->dvr_dev->chip_info == TYPE_RN6752){
  609. if(vin->aux_status){
  610. ret = v4l2_subdev_call(vin->current_subdev->sd,core,ioctl,VIDIOC_SET_AVIN_MODE,0);
  611. if(ret < 0){
  612. printk(KERN_ALERT "%s %d: v4l2_subdev_call error \n",__FUNCTION__, __LINE__);
  613. return ret;
  614. }
  615. }
  616. ret = v4l2_subdev_call(vin->current_subdev->sd,core,ioctl,VIDIOC_ENTER_CARBACK,0);
  617. if(ret < 0){
  618. printk(KERN_ALERT "%s %d: v4l2_subdev_call error \n",__FUNCTION__, __LINE__);
  619. return ret;
  620. }
  621. }
  622. spin_lock(&vin->dvr_dev->spin_lock);
  623. ret = v4l2_subdev_call(vin->current_subdev->sd,core,ioctl,VIDIOC_GET_ITU601_ENABLE,&vin->dvr_dev->itu656in.itu601en);
  624. if(ret < 0){
  625. printk(KERN_ALERT "%s %d: v4l2_subdev_call error \n",__FUNCTION__, __LINE__);
  626. return ret;
  627. }
  628. ret = v4l2_subdev_call(vin->current_subdev->sd,core,ioctl,VIDIOC_GET_PROGRESSIVE,&vin->dvr_dev->itu656in.progressive);
  629. if(ret < 0){
  630. printk(KERN_ALERT "%s %d: v4l2_subdev_call error \n",__FUNCTION__, __LINE__);
  631. return ret;
  632. }
  633. //memcpy(&vin->dvr_dev->itu656in_back, &vin->dvr_dev->itu656in, sizeof(struct vin_para));
  634. vin_reset();
  635. vin_init(vin, &vin->dvr_dev->itu656in);
  636. vin_start(vin->dvr_dev);
  637. vin->dvr_dev->carback_exit_status = 0;
  638. vin->dvr_dev->scale_framebuf_index = 0;
  639. spin_unlock(&vin->dvr_dev->spin_lock);
  640. return 0;
  641. }
  642. EXPORT_SYMBOL(dvr_enter_carback);
  643. int dvr_exit_carback(void)
  644. {
  645. struct ark1668e_vin_device* vin = NULL;
  646. int ret;
  647. vin = g_ark1668e_vin;
  648. if(!vin->aux_status){
  649. vin->dvr_dev->carback_exit_status = 1;
  650. }
  651. if(vin->aux_status){
  652. //The track layer is closed here to solve the abnormal display problem of only one track layer when carback and AVIN switch
  653. ark_disp_set_layer_en(2, 0);
  654. }
  655. vin->stream_flag = vin->vin_status;
  656. ark_disp_set_layer_en(DISPLAY_LAYER, 0);
  657. spin_lock(&vin->dvr_dev->spin_lock);
  658. vin->dvr_dev->vin_mirror_config = MIRROR_NO;
  659. vin->dvr_dev->work_status = 0;
  660. vin->dvr_dev->scale_framebuf_index = 0;
  661. vin->dvr_dev->show_video = 0;
  662. vin->dvr_dev->carback_signal = 0;
  663. vin->dvr_dev->layer_status = 0;
  664. msleep(20);
  665. ark_vin_disable_write(); /*stop write data back*/
  666. ark_vin_disable();
  667. spin_unlock(&vin->dvr_dev->spin_lock);
  668. if(vin->dvr_dev->chip_info == TYPE_RN6752){
  669. ret = v4l2_subdev_call(vin->current_subdev->sd,core,ioctl,VIDIOC_EXIT_CARBACK,0);
  670. if(ret < 0){
  671. printk(KERN_ALERT "%s %d: v4l2_subdev_call error \n",__FUNCTION__, __LINE__);
  672. return ret;
  673. }
  674. if(vin->aux_status){
  675. ret = v4l2_subdev_call(vin->current_subdev->sd,core,ioctl,VIDIOC_SET_AVIN_MODE,0);
  676. if(ret < 0){
  677. printk(KERN_ALERT "%s %d: v4l2_subdev_call error \n",__FUNCTION__, __LINE__);
  678. return ret;
  679. }
  680. }
  681. }
  682. if(vin->aux_status){
  683. vin_aux_config(&vin->dvr_dev->itu656in_back);
  684. vin_aux_start(vin->dvr_dev);
  685. }
  686. return 0;
  687. }
  688. EXPORT_SYMBOL(dvr_exit_carback);
  689. int dvr_set_mirror(int value)
  690. {
  691. g_ark1668e_vin->dvr_dev->vin_mirror_config = value;
  692. return 0;
  693. }
  694. EXPORT_SYMBOL(dvr_set_mirror);
  695. int dvr_get_pragressive(void)
  696. {
  697. int pragressive;
  698. //spin_lock(&g_ark1668e_vin->dvr_dev->spin_lock);
  699. pragressive = !g_ark1668e_vin->dvr_dev->interlace;
  700. //spin_unlock(&g_ark1668e_vin->dvr_dev->spin_lock);
  701. return pragressive;
  702. }
  703. EXPORT_SYMBOL(dvr_get_pragressive);
  704. static void vin_get_signal_work(struct work_struct *work)
  705. {
  706. struct ark1668e_vin_device* vin = NULL;
  707. int signal = 0,ret;
  708. vin = g_ark1668e_vin;
  709. if(!vin->dvr_dev->carback_exit_status){
  710. ret = v4l2_subdev_call(vin->current_subdev->sd,video,g_input_status,&signal);
  711. if(ret < 0)
  712. printk(KERN_ALERT "%s %d: v4l2_subdev_call error \n",__FUNCTION__, __LINE__);
  713. if(!signal){
  714. vin->dvr_dev->carback_signal = 1;
  715. }else{
  716. vin->dvr_dev->carback_signal = 0; //no signal
  717. }
  718. if (vin->dvr_dev->show_video && vin->dvr_dev->vin_buffer_status) {
  719. if(vin->dvr_dev->carback_signal)
  720. {
  721. if(vin->dvr_dev->first_show_flag){
  722. if(vin->dvr_dev->signal_flag == 20){
  723. printk(KERN_ALERT "ark_vin_display_int_handler-->show_video\n");
  724. ark_vin_display_init(DISPLAY_LAYER,vin->dvr_dev->screen_width,vin->dvr_dev->screen_height,vin->dvr_dev->screen_xpos,vin->dvr_dev->screen_ypos);
  725. ark_disp_set_layer_en(DISPLAY_LAYER, 1);
  726. vin->dvr_dev->layer_status = 1;
  727. vin->dvr_dev->show_video = 0;
  728. vin->dvr_dev->signal_flag = 0;
  729. vin->dvr_dev->first_show_flag = 0;
  730. }else{
  731. vin->dvr_dev->layer_status = 0;
  732. vin->dvr_dev->signal_flag++;
  733. }
  734. }else{
  735. if(vin->dvr_dev->signal_flag == 10){
  736. printk(KERN_ALERT "ark_vin_display_int_handler-->show_video\n");
  737. ark_vin_display_init(DISPLAY_LAYER,vin->dvr_dev->screen_width,vin->dvr_dev->screen_height,vin->dvr_dev->screen_xpos,vin->dvr_dev->screen_ypos);
  738. ark_disp_set_layer_en(DISPLAY_LAYER, 1);
  739. vin->dvr_dev->layer_status = 1;
  740. vin->dvr_dev->show_video = 0;
  741. vin->dvr_dev->signal_flag = 0;
  742. }else{
  743. vin->dvr_dev->layer_status = 0;
  744. vin->dvr_dev->signal_flag++;
  745. }
  746. }
  747. }
  748. else
  749. {
  750. vin->dvr_dev->layer_status = 0;
  751. printk(" No signal detect.\n");
  752. }
  753. }
  754. }
  755. }
  756. static void vin_get_signal_time(struct timer_list *t)
  757. {
  758. struct ark1668e_vin_device* vin = NULL;
  759. vin = g_ark1668e_vin;
  760. queue_work(vin->dvr_dev->detect_queue, &vin->dvr_dev->detect_work);
  761. mod_timer(&vin->dvr_dev->signal_timer, jiffies + msecs_to_jiffies(30));
  762. }
  763. int dvr_detect_carback_signal(void)
  764. {
  765. struct ark1668e_vin_device* vin = NULL;
  766. vin = g_ark1668e_vin;
  767. return vin->dvr_dev->carback_signal;
  768. }
  769. EXPORT_SYMBOL(dvr_detect_carback_signal);
  770. int dvr_get_layer_status(void)
  771. {
  772. struct ark1668e_vin_device* vin = NULL;
  773. vin = g_ark1668e_vin;
  774. return vin->dvr_dev->layer_status;
  775. }
  776. EXPORT_SYMBOL(dvr_get_layer_status);
  777. void ark_vin_scale_work(struct work_struct *work)
  778. {
  779. struct ark1668e_vin_device* vin = NULL;
  780. int format,oformat,dstaddr;
  781. vin = g_ark1668e_vin;
  782. if (vin->dvr_dev->work_status){
  783. memset(&scale_param,0,sizeof(struct ark_scale_param));
  784. format = ARK_SCALE_FORMAT_Y_UV420;
  785. oformat = ARK_SCALE_OUT_FORMAT_YUYV;
  786. dstaddr = vin->dvr_dev->scalebuf_phyaddr[vin->dvr_dev->scale_framebuf_index];
  787. vin->dvr_dev->scale_framebuf_index = (vin->dvr_dev->scale_framebuf_index + 1) % ITU656_SCALE_FRAME_NUM;
  788. //int readaddr;
  789. //readaddr = ark_vin_get_display_addr();
  790. //if(readaddr == dstaddr){
  791. // ark1668e_lcdc_wait_for_vsync();
  792. //}
  793. scale_param.iyaddr = vin->dvr_dev->scale_in_yphyaddr;
  794. scale_param.iuaddr = vin->dvr_dev->scale_in_yphyaddr + vin->dvr_dev->src_width * vin->dvr_dev->src_height;
  795. scale_param.ivaddr = 0;
  796. scale_param.ix = 0;
  797. scale_param.iy = 0;
  798. scale_param.iwinwidth = vin->dvr_dev->src_width;
  799. scale_param.iwinheight = vin->dvr_dev->src_height;
  800. scale_param.iwidth = vin->dvr_dev->src_width;
  801. scale_param.iheight = vin->dvr_dev->src_height;
  802. scale_param.iformat = format;
  803. scale_param.left_cut = 0;
  804. scale_param.right_cut = 25;
  805. scale_param.up_cut = 0;
  806. scale_param.bottom_cut = 15;
  807. scale_param.owidth = vin->dvr_dev->screen_width;
  808. scale_param.oheight = vin->dvr_dev->screen_height;
  809. scale_param.oyaddr = dstaddr;
  810. scale_param.ouaddr = 0;
  811. scale_param.ovaddr = 0;
  812. scale_param.oformat = oformat;
  813. scale_param.rotate = 0;
  814. ark_scale_start(scale_context,&scale_param);
  815. ark_vin_display_addr(dstaddr);
  816. vin->dvr_dev->vin_buffer_status = 1;
  817. }
  818. }
  819. int ark_vin_display_int_handler(void)
  820. {
  821. struct ark1668e_vin_device* vin = NULL;
  822. unsigned int count = 0;
  823. int i,frame_id;
  824. vin = g_ark1668e_vin;
  825. if(!vin || !vin->dvr_dev || !vin->dvr_dev->work_status)
  826. return -1;
  827. if(!vin->stream_flag){
  828. wait_event_interruptible(vin->dvr_dev->frame_finish_waitq, vin->dvr_dev->frame_finish_count > 0);
  829. if(!vin->dvr_dev->carback_exit_status){
  830. count = min((size_t)1, (size_t)vin->dvr_dev->frame_finish_count);
  831. if(vin->dvr_dev->framebuf_status[vin->dvr_dev->frame_finish[0]] == FRAMEBUF_STATUS_READY)
  832. {
  833. vin->dvr_dev->framebuf_status[vin->dvr_dev->frame_finish[0]] = FRAMEBUF_STATUS_BUSY;
  834. }
  835. else
  836. {
  837. printk(KERN_ALERT "### ark1668e vin read error state:%hhd\n", vin->dvr_dev->framebuf_status[vin->dvr_dev->frame_finish[0]]);
  838. goto exit;
  839. }
  840. for(i=0; i<count; i++)
  841. {
  842. frame_id = vin->dvr_dev->frame_finish[i];
  843. vin->dvr_dev->scale_in_yphyaddr = vin->dvr_dev->framebuf_phyaddr[frame_id];
  844. queue_work(vin->dvr_dev->scale_queue, &vin->dvr_dev->scale_work);
  845. if (vin->dvr_dev->framebuf_status[frame_id] == FRAMEBUF_STATUS_BUSY) {
  846. vin->dvr_dev->framebuf_status[frame_id] = FRAMEBUF_STATUS_FREE;
  847. } else {
  848. printk(KERN_ALERT "ark1668e vin free no-ready buf %d. status:%d\n", i, vin->dvr_dev->framebuf_status[i]);
  849. }
  850. break;
  851. }
  852. exit:
  853. vin->dvr_dev->frame_finish_count -= count;
  854. if (vin->dvr_dev->frame_finish_count > 0) {
  855. int i;
  856. char tmp;
  857. for (i = 0; i < vin->dvr_dev->frame_finish_count; i++) {
  858. tmp = vin->dvr_dev->frame_finish[count + i];
  859. vin->dvr_dev->frame_finish[i] = tmp;
  860. }
  861. }
  862. }
  863. }
  864. return 0;
  865. }
  866. EXPORT_SYMBOL(ark_vin_display_int_handler);
  867. static void vin_push_frame_buffer(struct dvr_dev *dvr_dev, int frame_id)
  868. {
  869. unsigned int val;
  870. //printk("dvr_push_frame_buffer %d.\n", frame_id);
  871. if (frame_id >= 0 && frame_id < dvr_dev->framebuf_num) {
  872. vin_writel(ARK1668E_ITU656_DRAM_DEST1,dvr_dev->framebuf_phyaddr[frame_id]);
  873. val = dvr_dev->framebuf_phyaddr[frame_id] + dvr_dev->src_width*dvr_dev->src_height;
  874. vin_writel(ARK1668E_ITU656_DRAM_DEST1,val);
  875. }
  876. }
  877. static int arkvin_frame_test_and_push(struct dvr_dev *dvr_dev, int frame_id)
  878. {
  879. int i;
  880. int tmp;
  881. tmp = frame_id;
  882. for(i=0; i<dvr_dev->framebuf_num; i++){
  883. tmp ++;
  884. tmp %= 4;
  885. if (dvr_dev->framebuf_status[tmp] == FRAMEBUF_STATUS_FREE){
  886. vin_push_frame_buffer(dvr_dev, tmp);
  887. break;
  888. }
  889. }
  890. if (i == dvr_dev->framebuf_num) {
  891. tmp = frame_id;
  892. for(i=0; i<dvr_dev->framebuf_num; i++){
  893. tmp ++;
  894. tmp %= 4;
  895. if (dvr_dev->framebuf_status[tmp] == FRAMEBUF_STATUS_READY){
  896. dvr_dev->framebuf_status[tmp] = FRAMEBUF_STATUS_FREE;
  897. vin_push_frame_buffer(dvr_dev, tmp);
  898. printk(KERN_ALERT "### reuse ready framebuf:%d.\n", tmp);
  899. break;
  900. }
  901. }
  902. if (i == dvr_dev->framebuf_num) {
  903. printk(KERN_ALERT "### err: no free and ready framebuf, reuse default frame_id:%d framebuf.\n", frame_id);
  904. dvr_dev->framebuf_status[frame_id] = FRAMEBUF_STATUS_FREE;
  905. vin_push_frame_buffer(dvr_dev, frame_id);
  906. }
  907. }
  908. return 0;
  909. }
  910. static irqreturn_t ark_vin_int_handler(int irq, void *dev_id)
  911. {
  912. u32 intr_stat;
  913. struct dvr_dev* dvr_dev = (struct dvr_dev *)dev_id;
  914. struct ark1668e_vin_device* vin = NULL;
  915. struct vb2_buffer *vb = NULL;
  916. int push_frame_state = 0;
  917. static int frame_id = 0;
  918. vin = g_ark1668e_vin;
  919. intr_stat = vin_readl(ARK1668E_ITU656_ISR);
  920. vin_writel(ARK1668E_ITU656_ICR, 0x1fff);
  921. //spin_lock_irqsave(&dvr_dev->spin_lock, flags);
  922. if(intr_stat & (1<<10))
  923. {
  924. printk(KERN_ALERT "pop error.\n");
  925. arkvin_frame_test_and_push(dvr_dev, frame_id);
  926. push_frame_state = 1;
  927. }
  928. if(intr_stat & TOTAL_LINE_CHANGED_INTERRUPT)
  929. {
  930. dvr_dev->show_video = 0;
  931. if(!vin->stream_flag)
  932. ark_vin_display_init(DISPLAY_LAYER,0,0,0,0);
  933. if (dvr_dev->itu656in.tvout)
  934. ark_disp_set_layer_en(TVOUT_LAYER, 0);
  935. ark_vin_disable_write();
  936. if(vin->dvr_dev->chip_info == TYPE_RN6752)
  937. mod_timer(&dvr_dev->timer, jiffies + msecs_to_jiffies(150));
  938. else
  939. mod_timer(&dvr_dev->timer, jiffies + msecs_to_jiffies(50));
  940. }
  941. if (!dvr_dev->work_status) goto end;
  942. //printk(KERN_ALERT "ark_vin_int_handler--intr_stat=0x%0x\n",intr_stat);
  943. if (intr_stat & (FIELD_INTERRUPT | FRAME_INTERRUPT_INTERRUPT)) {
  944. if(vin->stream_flag){
  945. spin_lock(&vin->ark_queue_lock);
  946. if (vin->cur_frm) {
  947. //printk(KERN_DEBUG "v4l2 streaming vb2_buffer_done...\n");
  948. vb = &vin->cur_frm->vb.vb2_buf;
  949. vb->timestamp = ktime_get_ns();
  950. vin->cur_frm->vb.sequence = vin->sequence++;
  951. vb2_buffer_done(vb, VB2_BUF_STATE_DONE);
  952. vin->cur_frm = NULL;
  953. }
  954. if (!list_empty(&vin->ark_queue) && !vin->stop) {
  955. vin->cur_frm = list_first_entry(&vin->ark_queue,
  956. struct vin_buffer, list);
  957. //printk(KERN_DEBUG "INT->get out buf: %p\n",vin->cur_frm->vb.vb2_buf.planes[0].mem_priv);
  958. list_del(&vin->cur_frm->list);
  959. vin_setaddr(vin);
  960. }
  961. if (vin->stop)
  962. complete(&vin->comp);
  963. spin_unlock(&vin->ark_queue_lock);
  964. }
  965. if(!vin->stream_flag){
  966. unsigned int yaddr = vin_readl(ARK1668E_ITU656_DRAM_DEST1);
  967. for (frame_id = 0; frame_id < vin->dvr_dev->framebuf_num; frame_id++) {
  968. if (yaddr == vin->dvr_dev->framebuf_phyaddr[frame_id])
  969. break;
  970. }
  971. if(frame_id >= vin->dvr_dev->framebuf_num){
  972. goto end;
  973. }
  974. if(vin->dvr_dev->framebuf_status[frame_id] != FRAMEBUF_STATUS_FREE) {
  975. //printk(KERN_INFO "### frame_id:%d != free, status:%d, all(%d,%d,%d,%d)\n", frame_id, g_ark1668e_vin->dvr_dev->framebuf_status[frame_id], g_ark1668e_vin->dvr_dev->framebuf_status[0],g_ark1668e_vin->dvr_dev->framebuf_status[1],g_ark1668e_vin->dvr_dev->framebuf_status[2],g_ark1668e_vin->dvr_dev->framebuf_status[3]);
  976. if(!push_frame_state){
  977. arkvin_frame_test_and_push(dvr_dev, frame_id);
  978. goto end;
  979. }
  980. }
  981. if (dvr_dev->discard_frame > 0) {
  982. dvr_dev->discard_frame--;
  983. goto end;
  984. }
  985. vin->dvr_dev->framebuf_status[frame_id] = FRAMEBUF_STATUS_READY;
  986. if(!push_frame_state)
  987. arkvin_frame_test_and_push(dvr_dev, frame_id);
  988. dvr_dev->cur_frame = frame_id;
  989. if (dvr_dev->frame_finish_count >= dvr_dev->framebuf_num)
  990. dvr_dev->frame_finish_count = dvr_dev->framebuf_num - 1;
  991. dvr_dev->frame_finish[dvr_dev->frame_finish_count++] = dvr_dev->cur_frame;
  992. wake_up_interruptible(&dvr_dev->frame_finish_waitq);
  993. }
  994. //spin_unlock_irqrestore(&dvr_dev->spin_lock, flags);
  995. }
  996. end:
  997. return IRQ_HANDLED;
  998. }
  999. static void ark_vin_pad_select(struct dvr_dev *dvr_dev)
  1000. {
  1001. unsigned int val;
  1002. if (dvr_dev->itu601en) {
  1003. //hsync, vsync
  1004. val = vin_readl_sys(ARK1668E_SYS_PAD_CTRL04);
  1005. val &= ~(0x3f<<24);
  1006. val |=(1<<24)|(1<<27);
  1007. vin_writel_sys(ARK1668E_SYS_PAD_CTRL04, vin_readl_sys(ARK1668E_SYS_PAD_CTRL04)|val);
  1008. }
  1009. if (dvr_dev->itu_channel== ITU656_CH0) {
  1010. val = vin_readl_sys(ARK1668E_SYS_PAD_CTRL02);
  1011. val &= ~(0x7ffffff<<3);
  1012. val |= (0x1<<3)|(0x1<<6)|(0x1<<9)|(0x1<<12)|(0x1<<15)|(0x1<<18)|(0x1<<21)|(0x1<<24)|(0x1<<27); //choose one pad of the channel 0
  1013. vin_writel_sys(ARK1668E_SYS_PAD_CTRL02, val);
  1014. } else if (dvr_dev->itu_channel == ITU656_CH1) {
  1015. val = vin_readl_sys(ARK1668E_SYS_PAD_CTRL03);
  1016. val |= 0x01249249; //choose one pad of the channel 1
  1017. vin_writel_sys(ARK1668E_SYS_PAD_CTRL03, val);
  1018. val = vin_readl_sys(ARK1668E_SYS_PAD_CTRL0F);
  1019. val |= (1<<24)|(1<<26);
  1020. vin_writel_sys(ARK1668E_SYS_PAD_CTRL0F, val);
  1021. } else if(dvr_dev->itu_channel == ITU656_CH2){
  1022. val = vin_readl_sys(ARK1668E_SYS_PAD_CTRL03);
  1023. val |= 0x08000000; //choose one pad of the channel 2
  1024. vin_writel_sys(ARK1668E_SYS_PAD_CTRL03, val);
  1025. val = vin_readl_sys(ARK1668E_SYS_PAD_CTRL04);
  1026. val |= 0x249249;
  1027. vin_writel_sys(ARK1668E_SYS_PAD_CTRL04, val);
  1028. }
  1029. }
  1030. static void ark_vin_reg_init(struct dvr_dev *dvr_dev)
  1031. {
  1032. unsigned int val;
  1033. val = vin_readl(ARK1668E_ITU656_MODULE_EN);
  1034. val |= (1 << 2);
  1035. vin_writel(ARK1668E_ITU656_MODULE_EN, val);
  1036. if (dvr_dev->itu601en) {
  1037. vin_writel(ARK1668E_ITU656_MODULE_EN, vin_readl(ARK1668E_ITU656_MODULE_EN) | 1);
  1038. val = vin_readl(ARK1668E_ITU656_INPUT_SEL);
  1039. val = 0;
  1040. vin_writel(ARK1668E_ITU656_INPUT_SEL, val);
  1041. //polarity
  1042. //val = (1 << 13) | (1 << 12);
  1043. //vin_writel(ARK1668E_ITU656_SEP_MODE_SEL, val);
  1044. }else{
  1045. val = vin_readl(ARK1668E_ITU656_INPUT_SEL);
  1046. val = 0x00000001;
  1047. vin_writel(ARK1668E_ITU656_INPUT_SEL, val);
  1048. }
  1049. val = vin_readl(ARK1668E_ITU656_IMR);
  1050. val = 0;
  1051. vin_writel(ARK1668E_ITU656_IMR, val);
  1052. val = vin_readl(ARK1668E_ITU656_YUV_TYPESEL);
  1053. val = 0;
  1054. vin_writel(ARK1668E_ITU656_YUV_TYPESEL, val);
  1055. val = vin_readl(ARK1668E_ITU656_SEP_MODE_SEL);
  1056. val |= 1<<3;
  1057. vin_writel(ARK1668E_ITU656_SEP_MODE_SEL, val);
  1058. val = vin_readl(ARK1668E_ITU656_ENABLE_REG);
  1059. val = 0x0000200a;//0x0000600a;
  1060. vin_writel(ARK1668E_ITU656_ENABLE_REG, val);
  1061. val = vin_readl(ARK1668E_ITU656_MIRR_SET);
  1062. val = g_ark1668e_vin->dvr_dev->vin_mirror_config;
  1063. vin_writel(ARK1668E_ITU656_MIRR_SET, val);
  1064. val = vin_readl(ARK1668E_ITU656_OUTPUT_TYPE);
  1065. val = 0;
  1066. vin_writel(ARK1668E_ITU656_OUTPUT_TYPE, val);
  1067. /********************************************************/
  1068. #if 0
  1069. val = 0x4c01;
  1070. vin_writel(ARK1668E_ITU656_YUV_TYPESEL11, val);
  1071. val = vin_readl(ARK1668E_ITU656_MODULE_EN);
  1072. val |= 1;
  1073. vin_writel(ARK1668E_ITU656_MODULE_EN, val);
  1074. #endif
  1075. /********************************************************/
  1076. val = vin_readl(ARK1668E_ITU656_IMR);
  1077. val |= (FIFO_POP_ERROR) | (TOTAL_LINE_CHANGED_INTERRUPT) | (ACTIVE_LINE_CHANGED_INTERRUPT) | (1<<3) | (1<<0);
  1078. vin_writel(ARK1668E_ITU656_IMR, val);
  1079. }
  1080. static void ark_vin_enable(struct dvr_dev *dvr_dev)
  1081. {
  1082. vin_writel(ARK1668E_ITU656_ENABLE_REG, vin_readl(ARK1668E_ITU656_ENABLE_REG)| (1 << 0));
  1083. }
  1084. static void deinterlace_reset(void)
  1085. {
  1086. }
  1087. static void deinterlace_init(void)
  1088. {
  1089. deinterlace_reset();
  1090. }
  1091. static void dither_timeout_timer(struct timer_list *t)
  1092. {
  1093. struct dvr_dev *dvr_dev = from_timer(dvr_dev, t, timer);
  1094. struct ark1668e_vin_device* vin = NULL;
  1095. int line,pixel,activeLine, activePix,i;
  1096. vin = g_ark1668e_vin;
  1097. //spin_lock_irqsave(&dvr_dev->spin_lock, flags);
  1098. if (!dvr_dev->work_status) {
  1099. //spin_unlock_irqrestore(&dvr_dev->spin_lock, flags);
  1100. return;
  1101. }
  1102. line = vin_readl(ARK1668E_ITU656_LINE_NUM_PER_FIELD) & 0x7FF;
  1103. if (dvr_dev->itu601en)
  1104. pixel = vin_readl(ARK1668E_ITU656_PIX_NUM_PER_LINE) & 0xFFF;
  1105. else
  1106. pixel = (vin_readl(ARK1668E_ITU656_PIX_NUM_PER_LINE) & 0xFFE) >> 1;
  1107. printk(KERN_ALERT "[ITU] line = %d, pixel=%d\r\n", line, pixel);
  1108. dvr_dev->src_width = activePix = pixel;
  1109. dvr_dev->src_height = activeLine = line;
  1110. if (dvr_dev->interlace) {
  1111. if (line >= 230 && line <= 250)
  1112. dvr_dev->system = NTSC;
  1113. else if (line >= 278 && line < 298)
  1114. dvr_dev->system = PAL;
  1115. else
  1116. dvr_dev->system = NTSC;
  1117. if(dvr_dev->system == NTSC)
  1118. {
  1119. activeLine = 240;
  1120. activePix = 720;
  1121. }
  1122. else
  1123. {
  1124. activeLine = 288;
  1125. activePix = 720;
  1126. }
  1127. }
  1128. vin_writel(ARK1668E_ITU656_OUTLINE_NUM_PER_FIELD, activeLine);
  1129. vin_writel(ARK1668E_ITU656_TOTAL_PIX_OUT, activeLine*activePix);
  1130. vin_writel(ARK1668E_ITU656_TOTAL_PIX, activeLine*activePix);
  1131. vin_writel(ARK1668E_ITU656_SIZE, activePix<<16);
  1132. dvr_dev->src_width = activePix;
  1133. dvr_dev->src_height = activeLine;
  1134. dvr_dev->discard_frame = START_DISCARD_FRAME;
  1135. dvr_dev->cur_frame = 0;
  1136. dvr_dev->show_video = 1;
  1137. for (i = 0; i < vin->dvr_dev->framebuf_num; i++){
  1138. vin_push_frame_buffer(dvr_dev,i);
  1139. vin->dvr_dev->framebuf_status[i] = FRAMEBUF_STATUS_FREE;
  1140. }
  1141. ark_vin_enable_write();
  1142. //spin_unlock_irqrestore(&dvr_dev->spin_lock, flags);
  1143. }
  1144. static int vin_start(struct dvr_dev *dvr_dev)
  1145. {
  1146. struct ark1668e_vin_device* vin = NULL;
  1147. int ret = 0;
  1148. vin = g_ark1668e_vin;
  1149. if(!dvr_dev->work_status){
  1150. dvr_dev->work_status = 1;
  1151. dvr_dev->discard_frame = START_DISCARD_FRAME;
  1152. dvr_dev->cur_frame = 0;
  1153. dvr_dev->vin_buffer_status = 0;
  1154. deinterlace_init();
  1155. ret = v4l2_subdev_call(vin->current_subdev->sd,video,s_routing,dvr_dev->channel,0,0);
  1156. if(ret < 0){
  1157. printk(KERN_ALERT "%s %d: v4l2_subdev_call error \n",__FUNCTION__, __LINE__);
  1158. return ret;
  1159. }
  1160. ark_vin_pad_select(dvr_dev);
  1161. ark_vin_reg_init(dvr_dev);
  1162. ark_vin_enable(dvr_dev);
  1163. }
  1164. return ret;
  1165. }
  1166. static int vin_exit(void)
  1167. {
  1168. struct ark1668e_vin_device* vin = NULL;
  1169. int ret;
  1170. vin = g_ark1668e_vin;
  1171. vin->dvr_dev->carback_exit_status = 1;
  1172. vin->stream_flag = vin->vin_status;
  1173. ark_disp_set_layer_en(DISPLAY_LAYER, 0);
  1174. spin_lock(&vin->dvr_dev->spin_lock);
  1175. vin->dvr_dev->vin_mirror_config = MIRROR_NO;
  1176. vin->dvr_dev->work_status = 0;
  1177. vin->dvr_dev->scale_framebuf_index = 0;
  1178. vin->dvr_dev->show_video = 0;
  1179. vin->dvr_dev->carback_signal = 0;
  1180. vin->dvr_dev->layer_status = 0;
  1181. msleep(20);
  1182. ark_vin_disable_write(); /*stop write data back*/
  1183. ark_vin_disable();
  1184. spin_unlock(&vin->dvr_dev->spin_lock);
  1185. if(vin->dvr_dev->chip_info == TYPE_RN6752){
  1186. ret = v4l2_subdev_call(vin->current_subdev->sd,core,ioctl,VIDIOC_EXIT_CARBACK,0);
  1187. if(ret < 0){
  1188. printk(KERN_ALERT "%s %d: v4l2_subdev_call error \n",__FUNCTION__, __LINE__);
  1189. return ret;
  1190. }
  1191. }
  1192. return 0;
  1193. }
  1194. static void vin_init(struct ark1668e_vin_device *vin, struct vin_para *para)
  1195. {
  1196. struct dvr_dev* dvr_dev = vin->dvr_dev;
  1197. memcpy(&dvr_dev->itu656in, para, sizeof(struct vin_para));
  1198. dvr_dev->interlace = !dvr_dev->itu656in.progressive;
  1199. dvr_dev->itu601en = dvr_dev->itu656in.itu601en;
  1200. switch (para->source) {
  1201. case DVR_SOURCE_DVD:
  1202. dvr_dev->channel = ARK7116_AV2;
  1203. break;
  1204. case DVR_SOURCE_AUX:
  1205. dvr_dev->channel = ARK7116_AV1;
  1206. break;
  1207. case DVR_SOURCE_CAMERA:
  1208. default:
  1209. dvr_dev->channel = ARK7116_AV0;
  1210. break;
  1211. }
  1212. }
  1213. static int vin_aux_start(struct dvr_dev *dvr_dev)
  1214. {
  1215. struct ark1668e_vin_device* vin = NULL;
  1216. int ret = 0;
  1217. vin = g_ark1668e_vin;
  1218. if(!dvr_dev->work_status){
  1219. dvr_dev->work_status = 1;
  1220. dvr_dev->discard_frame = START_DISCARD_FRAME;
  1221. dvr_dev->cur_frame = 0;
  1222. dvr_dev->vin_buffer_status = 0;
  1223. ret = v4l2_subdev_call(vin->current_subdev->sd,video,s_routing,vin->app_channel_set,0,0);
  1224. if(ret < 0){
  1225. printk(KERN_ALERT "%s %d: v4l2_subdev_call error \n",__FUNCTION__, __LINE__);
  1226. return ret;
  1227. }
  1228. deinterlace_init();
  1229. ark_vin_pad_select(dvr_dev);
  1230. ark_vin_reg_init(dvr_dev);
  1231. ark_vin_enable(dvr_dev);
  1232. }
  1233. return ret;
  1234. }
  1235. static void vin_aux_exit(void)
  1236. {
  1237. struct ark1668e_vin_device* vin = NULL;
  1238. int ret;
  1239. vin = g_ark1668e_vin;
  1240. spin_lock(&vin->dvr_dev->spin_lock);
  1241. vin->dvr_dev->carback_exit_status = 1;
  1242. vin->stream_flag = vin->vin_status;
  1243. vin->dvr_dev->show_video = 0;
  1244. vin->dvr_dev->carback_signal = 0;
  1245. vin->dvr_dev->work_status = 0;
  1246. vin->dvr_dev->layer_status = 0;
  1247. ark_disp_set_layer_en(DISPLAY_LAYER, 0);
  1248. vin->dvr_dev->scale_framebuf_index = 0;
  1249. spin_unlock(&vin->dvr_dev->spin_lock);
  1250. msleep(20);
  1251. ark_vin_disable_write(); /*stop write data back*/
  1252. ark_vin_disable();
  1253. if(vin->dvr_dev->chip_info == TYPE_RN6752){
  1254. ret = v4l2_subdev_call(vin->current_subdev->sd,core,ioctl,VIDIOC_EXIT_CARBACK,0);
  1255. if(ret < 0)
  1256. printk(KERN_ALERT "%s %d: v4l2_subdev_call error \n",__FUNCTION__, __LINE__);
  1257. }
  1258. }
  1259. static irqreturn_t ark_deinterlace_int_handler(int irq, void *dev_id)
  1260. {
  1261. return IRQ_HANDLED;
  1262. }
  1263. static int vin_async_bound(struct v4l2_async_notifier *notifier,
  1264. struct v4l2_subdev *subdev,
  1265. struct v4l2_async_subdev *asd)
  1266. {
  1267. struct vin_subdev_entity *subdev_entity = NULL;
  1268. struct ark1668e_vin_device *ark_vin = NULL;
  1269. subdev_entity = container_of(notifier, struct vin_subdev_entity, notifier);
  1270. ark_vin = container_of(notifier->v4l2_dev,struct ark1668e_vin_device, v4l2_dev);
  1271. if (video_is_registered(&ark_vin->video_dev)) {
  1272. v4l2_err(&ark_vin->v4l2_dev, "only supports one sub-device.\n");
  1273. return -EBUSY;
  1274. }
  1275. subdev_entity->sd = subdev;
  1276. return 0;
  1277. }
  1278. static void vin_async_unbind(struct v4l2_async_notifier *notifier,
  1279. struct v4l2_subdev *subdev,
  1280. struct v4l2_async_subdev *asd)
  1281. {
  1282. struct ark1668e_vin_device *ark_vin = NULL;
  1283. ark_vin = container_of(notifier->v4l2_dev,struct ark1668e_vin_device, v4l2_dev);
  1284. cancel_work_sync(&ark_vin->awb_work);
  1285. video_unregister_device(&ark_vin->video_dev);
  1286. }
  1287. static int vin_set_default_fmt(struct ark1668e_vin_device *vin)
  1288. {
  1289. struct v4l2_format f = {
  1290. .type = V4L2_BUF_TYPE_VIDEO_CAPTURE,
  1291. .fmt.pix = {
  1292. .width = DISPLAY_WIDTH,
  1293. .height = DISPLAY_HEIGHT,
  1294. .field = V4L2_FIELD_ANY,
  1295. .pixelformat = V4L2_PIX_FMT_YUYV,
  1296. },
  1297. };
  1298. vin->fmt = f;
  1299. return 0;
  1300. }
  1301. static int vin_async_complete(struct v4l2_async_notifier *notifier)
  1302. {
  1303. int ret,support_max_resolution,chipinfo;
  1304. struct i2c_client *sd_client = NULL;
  1305. struct ark1668e_vin_device *ark_vin = container_of(notifier->v4l2_dev,struct ark1668e_vin_device, v4l2_dev);
  1306. ark_vin->current_subdev = container_of(notifier,struct vin_subdev_entity, notifier);
  1307. sd_client = v4l2_get_subdevdata(ark_vin->current_subdev->sd);
  1308. if(!sd_client){
  1309. printk(KERN_ALERT "get subdev data error .\n");
  1310. return -EINVAL;
  1311. }
  1312. printk("subdev addr is %p, name is %s.\n",ark_vin->current_subdev->sd,sd_client->name);
  1313. /* Register subdev device node */
  1314. ret = v4l2_device_register_subdev_nodes(&ark_vin->v4l2_dev);
  1315. if (ret < 0) {
  1316. printk(KERN_ALERT "v4l2_device_register_subdev_nodes error\n");
  1317. return ret;
  1318. }
  1319. ret = v4l2_subdev_call(ark_vin->current_subdev->sd,core,ioctl,VIDIOC_GET_CHIPINFO,&chipinfo);
  1320. if(ret < 0){
  1321. printk(KERN_ALERT "%s %d: v4l2_subdev_call error \n",__FUNCTION__, __LINE__);
  1322. return ret;
  1323. }
  1324. if(chipinfo == TYPE_RN6752){
  1325. printk(KERN_ALERT "decoder chip is rn6752\n");
  1326. ark_vin->dvr_dev->chip_info = TYPE_RN6752;
  1327. ark_vin->dvr_dev->framebuf_num = 8;
  1328. }else if(chipinfo == TYPE_ARK7116){
  1329. printk(KERN_ALERT "decoder chip is ark7116\n");
  1330. ark_vin->dvr_dev->chip_info = TYPE_ARK7116;
  1331. }else if(chipinfo == TYPE_PR2000){
  1332. printk(KERN_ALERT "decoder chip is pr2000\n");
  1333. ark_vin->dvr_dev->chip_info = TYPE_ARK7116;
  1334. }else{
  1335. printk(KERN_ALERT "no find decoder chip info\n");
  1336. }
  1337. ret = v4l2_subdev_call(ark_vin->current_subdev->sd,core,ioctl,VIDIOC_GET_RESOLUTION,&support_max_resolution);
  1338. if(ret < 0){
  1339. printk(KERN_ALERT "%s %d: v4l2_subdev_call error \n",__FUNCTION__, __LINE__);
  1340. return ret;
  1341. }
  1342. if(support_max_resolution == TYPE_1080P){
  1343. if(ark_vin->dvr_dev->chip_info == TYPE_RN6752)
  1344. ark_vin->dvr_dev->buffer_size = ITU656_PROGRESSIVE_FRAME_SIZE_1080P*ark_vin->dvr_dev->framebuf_num;
  1345. else
  1346. ark_vin->dvr_dev->buffer_size = ITU656_PROGRESSIVE_FRAME_SIZE_1080P*ITU656_FRAME_NUM;
  1347. }
  1348. else if(support_max_resolution == TYPE_720P){
  1349. if(ark_vin->dvr_dev->chip_info == TYPE_RN6752)
  1350. ark_vin->dvr_dev->buffer_size = ITU656_PROGRESSIVE_FRAME_SIZE*ark_vin->dvr_dev->framebuf_num;
  1351. else
  1352. ark_vin->dvr_dev->buffer_size = ITU656_PROGRESSIVE_FRAME_SIZE*ITU656_FRAME_NUM;
  1353. }
  1354. else{
  1355. if(ark_vin->dvr_dev->chip_info == TYPE_RN6752)
  1356. ark_vin->dvr_dev->buffer_size = ITU656_FRAME_SIZE*ark_vin->dvr_dev->framebuf_num;
  1357. else
  1358. ark_vin->dvr_dev->buffer_size = ITU656_FRAME_SIZE*ITU656_FRAME_NUM;
  1359. }
  1360. ark_vin->dvr_dev->scale_buffer_size = ark_vin->dvr_dev->scale_alloc_width*ark_vin->dvr_dev->scale_alloc_height*2*ark_vin->dvr_dev->scale_framebuf_num;
  1361. vin_alloc_buf(support_max_resolution);
  1362. mutex_init(&ark_vin->lock);
  1363. init_completion(&ark_vin->comp);
  1364. /* Initialize videobuf2 queue */
  1365. ark_vin->vb2_vidq.type = V4L2_BUF_TYPE_VIDEO_CAPTURE;
  1366. ark_vin->vb2_vidq.io_modes = VB2_MMAP | VB2_DMABUF | VB2_READ;
  1367. ark_vin->vb2_vidq.drv_priv = ark_vin;
  1368. ark_vin->vb2_vidq.buf_struct_size = sizeof(struct vin_buffer);
  1369. ark_vin->vb2_vidq.ops = &vin_vb2_ops;
  1370. ark_vin->vb2_vidq.mem_ops = &vb2_dma_contig_memops;
  1371. ark_vin->vb2_vidq.timestamp_flags = V4L2_BUF_FLAG_TIMESTAMP_MONOTONIC;
  1372. ark_vin->vb2_vidq.lock = &ark_vin->lock;
  1373. ark_vin->vb2_vidq.min_buffers_needed = 1;
  1374. ark_vin->vb2_vidq.dev = ark_vin->dev;
  1375. ret = vb2_queue_init(&ark_vin->vb2_vidq);
  1376. if (ret < 0) {
  1377. v4l2_err(&ark_vin->v4l2_dev,
  1378. "vb2_queue_init() failed: %d\n", ret);
  1379. return ret;
  1380. }
  1381. /* Init video dma queues */
  1382. INIT_LIST_HEAD(&ark_vin->ark_queue);
  1383. spin_lock_init(&ark_vin->ark_queue_lock);
  1384. ret = vin_set_default_fmt(ark_vin);
  1385. if (ret) {
  1386. v4l2_err(&ark_vin->v4l2_dev, "Could not set default format\n");
  1387. return ret;
  1388. }
  1389. /* Register video device */
  1390. strlcpy(ark_vin->video_dev.name, ARK_VIN_NAME, sizeof(ark_vin->video_dev.name));
  1391. ark_vin->video_dev.release = video_device_release_empty;
  1392. ark_vin->video_dev.fops = &vin_fops;
  1393. ark_vin->video_dev.ioctl_ops = &vin_ioctl_ops;
  1394. ark_vin->video_dev.v4l2_dev = &ark_vin->v4l2_dev;
  1395. ark_vin->video_dev.vfl_dir = VFL_DIR_RX;
  1396. ark_vin->video_dev.queue = &ark_vin->vb2_vidq;
  1397. ark_vin->video_dev.lock = &ark_vin->lock;
  1398. ark_vin->video_dev.device_caps = V4L2_CAP_STREAMING | V4L2_CAP_VIDEO_CAPTURE;
  1399. video_set_drvdata(&ark_vin->video_dev, ark_vin);
  1400. ret = video_register_device(&ark_vin->video_dev, VFL_TYPE_GRABBER, -1);
  1401. if (ret < 0) {
  1402. v4l2_err(&ark_vin->v4l2_dev,
  1403. "video_register_device failed: %d\n", ret);
  1404. return ret;
  1405. }
  1406. return 0;
  1407. }
  1408. static const struct v4l2_async_notifier_operations vin_graph_notify_ops = {
  1409. .bound = vin_async_bound,
  1410. .unbind = vin_async_unbind,
  1411. .complete = vin_async_complete,
  1412. };
  1413. static int vin_driver_init(struct device *dev)
  1414. {
  1415. int value;
  1416. struct ark1668e_vin_device* vin = NULL;
  1417. vin = g_ark1668e_vin;
  1418. vin->dvr_dev = devm_kzalloc(dev, sizeof(struct dvr_dev), GFP_KERNEL);
  1419. if (vin->dvr_dev == NULL) {
  1420. dev_err(dev, "%s %d: failed to allocate memory\n",
  1421. __FUNCTION__, __LINE__);
  1422. return -ENOMEM;
  1423. }
  1424. vin->dvr_dev->work_status = 0;
  1425. vin->dvr_dev->layer_status = 0;
  1426. vin->dvr_dev->signal_flag = 0;
  1427. vin->dvr_dev->first_show_flag = 1;
  1428. vin->dvr_dev->system = NTSC;
  1429. vin->dvr_dev->cur_buffer = 0;
  1430. vin->dvr_dev->carback_signal = 0;
  1431. vin->dvr_dev->frame_finish_count = 0;
  1432. vin->dvr_dev->scale_framebuf_index = 0;
  1433. vin->dvr_dev->vin_buffer_status = 0;
  1434. vin->dvr_dev->vin_mirror_config = MIRROR_NO;
  1435. vin->dvr_dev->framebuf_num = ITU656_FRAME_NUM;
  1436. vin->dvr_dev->scale_framebuf_num = ITU656_SCALE_FRAME_NUM;
  1437. vin->dvr_dev->carback_exit_status = 1;
  1438. vin->aux_flag = 0;
  1439. vin->aux_status = 0;
  1440. vin->stream_flag = false;
  1441. vin->sd_init = 0;
  1442. if(!of_property_read_u32(dev->of_node, "width", &value)) {
  1443. if(value > 0){
  1444. of_property_read_u32(dev->of_node, "x_pos", &value);
  1445. vin->dvr_dev->screen_xpos = value;
  1446. of_property_read_u32(dev->of_node, "y_pos", &value);
  1447. vin->dvr_dev->screen_ypos = value;
  1448. of_property_read_u32(dev->of_node, "width", &value);
  1449. vin->dvr_dev->screen_width = value;
  1450. of_property_read_u32(dev->of_node, "height", &value);
  1451. vin->dvr_dev->screen_height = value;
  1452. printk("++++++ x_pos = %d,y_pos = %d,width = %d,height = %d",vin->dvr_dev->screen_xpos,vin->dvr_dev->screen_ypos,vin->dvr_dev->screen_width,vin->dvr_dev->screen_height);
  1453. }
  1454. }else{
  1455. vin->dvr_dev->screen_xpos = 0;
  1456. vin->dvr_dev->screen_ypos = 0;
  1457. ark_vin_get_screen_info(&vin->dvr_dev->screen_width,&vin->dvr_dev->screen_height);
  1458. }
  1459. vin->dvr_dev->scale_alloc_width = vin->dvr_dev->screen_width;
  1460. vin->dvr_dev->scale_alloc_height = vin->dvr_dev->screen_height;
  1461. init_waitqueue_head(&vin->dvr_dev->frame_finish_waitq);
  1462. spin_lock_init(&vin->dvr_dev->spin_lock);
  1463. return 0;
  1464. }
  1465. static int vin_parse_dt(struct device *dev, struct ark1668e_vin_device *ark_vin)
  1466. {
  1467. struct device_node *np = dev->of_node;
  1468. struct device_node *epn = NULL, *rem;
  1469. struct v4l2_fwnode_endpoint v4l2_epn;
  1470. struct vin_subdev_entity *subdev_entity;
  1471. unsigned int flags;
  1472. int ret;
  1473. INIT_LIST_HEAD(&ark_vin->subdev_entities);
  1474. while (1) {
  1475. epn = of_graph_get_next_endpoint(np, epn);
  1476. if (!epn)
  1477. return 0;
  1478. rem = of_graph_get_remote_port_parent(epn);
  1479. if (!rem) {
  1480. dev_notice(dev, "Remote device at %pOF not found\n",
  1481. epn);
  1482. continue;
  1483. }
  1484. ret = v4l2_fwnode_endpoint_parse(of_fwnode_handle(epn),
  1485. &v4l2_epn);
  1486. if (ret) {
  1487. of_node_put(rem);
  1488. ret = -EINVAL;
  1489. dev_err(dev, "Could not parse the endpoint\n");
  1490. break;
  1491. }
  1492. subdev_entity = devm_kzalloc(dev,
  1493. sizeof(*subdev_entity), GFP_KERNEL);
  1494. if (!subdev_entity) {
  1495. of_node_put(rem);
  1496. ret = -ENOMEM;
  1497. break;
  1498. }
  1499. subdev_entity->asd = devm_kzalloc(dev,
  1500. sizeof(*subdev_entity->asd), GFP_KERNEL);
  1501. if (!subdev_entity->asd) {
  1502. of_node_put(rem);
  1503. ret = -ENOMEM;
  1504. break;
  1505. }
  1506. flags = v4l2_epn.bus.parallel.flags;
  1507. subdev_entity->asd->match_type = V4L2_ASYNC_MATCH_FWNODE;
  1508. subdev_entity->asd->match.fwnode = of_fwnode_handle(rem);
  1509. /* Adds an instance to the linked list*/
  1510. list_add_tail(&subdev_entity->list, &ark_vin->subdev_entities);
  1511. }
  1512. of_node_put(epn);
  1513. return ret;
  1514. }
  1515. static void vin_subdev_cleanup(struct ark1668e_vin_device *vin)
  1516. {
  1517. struct vin_subdev_entity *subdev_entity;
  1518. list_for_each_entry(subdev_entity, &vin->subdev_entities, list)
  1519. v4l2_async_notifier_unregister(&subdev_entity->notifier);
  1520. INIT_LIST_HEAD(&vin->subdev_entities);
  1521. }
  1522. static int ark1668e_vin_probe(struct platform_device *pdev)
  1523. {
  1524. struct device *dev = &pdev->dev;
  1525. struct vin_subdev_entity *subdev_entity;
  1526. struct ark1668e_vin_device* ark_vin;
  1527. struct resource *res;
  1528. void __iomem *regs;
  1529. int ret,value;
  1530. ark_vin = devm_kzalloc(dev, sizeof(*ark_vin), GFP_KERNEL);
  1531. if (!ark_vin)
  1532. return -ENOMEM;
  1533. g_ark1668e_vin = ark_vin;
  1534. platform_set_drvdata(pdev, ark_vin);
  1535. ark_vin->dev = dev;
  1536. ret = v4l2_device_register(dev,&ark_vin->v4l2_dev);
  1537. if (ret) {
  1538. printk(KERN_ALERT "unable to register v4l2 device.\n");
  1539. }
  1540. ret = vin_parse_dt(dev, ark_vin);
  1541. if (ret)
  1542. printk(KERN_ALERT "fail to parse device tree\n");
  1543. vin_driver_init(dev);
  1544. if (list_empty(&ark_vin->subdev_entities)) {
  1545. printk(KERN_ALERT "no subdev found \n");
  1546. ret = -ENODEV;
  1547. }
  1548. /*find and prepare the async subdev notifier and register it */
  1549. list_for_each_entry(subdev_entity, &ark_vin->subdev_entities, list) {
  1550. subdev_entity->notifier.subdevs = &subdev_entity->asd;
  1551. subdev_entity->notifier.num_subdevs = 1;
  1552. subdev_entity->notifier.ops = &vin_graph_notify_ops;
  1553. ret = v4l2_async_notifier_register(&ark_vin->v4l2_dev,
  1554. &subdev_entity->notifier);
  1555. if (ret) {
  1556. printk(KERN_ALERT "fail to register async notifier\n");
  1557. }
  1558. if (video_is_registered(&ark_vin->video_dev))
  1559. break;
  1560. }
  1561. res = platform_get_resource(pdev, IORESOURCE_MEM, 0);
  1562. if (IS_ERR(res)) {
  1563. ret = PTR_ERR(res);
  1564. }
  1565. regs = devm_ioremap_resource(&pdev->dev, res);
  1566. if (IS_ERR(regs)) {
  1567. ret = PTR_ERR(regs);
  1568. }
  1569. ark_vin->dvr_dev->context.itu656_base = regs;
  1570. res = platform_get_resource(pdev, IORESOURCE_MEM, 1);
  1571. if (IS_ERR(res)) {
  1572. ret = PTR_ERR(res);
  1573. }
  1574. regs = ioremap(res->start, resource_size(res)); /* baseaddr conflict */
  1575. if (IS_ERR(regs)) {
  1576. ret = PTR_ERR(regs);
  1577. }
  1578. ark_vin->dvr_dev->context.sys_base = regs;
  1579. res = platform_get_resource(pdev, IORESOURCE_MEM, 2);
  1580. if (IS_ERR(res)) {
  1581. ret = PTR_ERR(res);
  1582. }
  1583. regs = ioremap(res->start, resource_size(res)); /* baseaddr conflict */
  1584. if (IS_ERR(regs)) {
  1585. ret = PTR_ERR(regs);
  1586. }
  1587. ark_vin->dvr_dev->context.deinterlace_base = regs;
  1588. res = platform_get_resource(pdev, IORESOURCE_MEM, 3);
  1589. if (IS_ERR(res)) {
  1590. ret = PTR_ERR(res);
  1591. }
  1592. regs = ioremap(res->start, resource_size(res)); /* baseaddr conflict */
  1593. if (IS_ERR(regs)) {
  1594. ret = PTR_ERR(regs);
  1595. }
  1596. ark_vin->dvr_dev->context.lcd_base = regs;
  1597. ark_vin->dvr_dev->context.itu656_irq = platform_get_irq(pdev, 0);
  1598. if (ark_vin->dvr_dev->context.itu656_irq < 0) {
  1599. dev_err(&pdev->dev, "%s %d: can't get itu656_irq resource.\n", __FUNCTION__, __LINE__);
  1600. }
  1601. ret = devm_request_irq(
  1602. &pdev->dev,
  1603. ark_vin->dvr_dev->context.itu656_irq,
  1604. ark_vin_int_handler,
  1605. IRQF_SHARED,
  1606. "ark1668e_vin",
  1607. ark_vin->dvr_dev
  1608. );
  1609. if(ret){
  1610. dev_err(&pdev->dev, "%s %d: can't get assigned vin %d, error %d\n",
  1611. __FUNCTION__, __LINE__, ark_vin->dvr_dev->context.itu656_irq, ret);
  1612. }
  1613. ark_vin->dvr_dev->context.deinterlace_irq = platform_get_irq(pdev, 1);
  1614. if (ark_vin->dvr_dev->context.deinterlace_irq < 0) {
  1615. dev_err(&pdev->dev, "%s %d: can't get deinterlace_irq resource.\n", __FUNCTION__, __LINE__);
  1616. }
  1617. ret = devm_request_irq(
  1618. &pdev->dev,
  1619. ark_vin->dvr_dev->context.deinterlace_irq,
  1620. ark_deinterlace_int_handler,
  1621. IRQF_SHARED,
  1622. "vin_deinterlace",
  1623. ark_vin->dvr_dev
  1624. );
  1625. if(ret){
  1626. dev_err(&pdev->dev, "%s %d: can't get assigned deinterlace_irq %d, error %d\n",
  1627. __FUNCTION__, __LINE__, ark_vin->dvr_dev->context.deinterlace_irq, ret);
  1628. }
  1629. timer_setup(&ark_vin->dvr_dev->timer, dither_timeout_timer, 0);
  1630. timer_setup(&ark_vin->dvr_dev->signal_timer, vin_get_signal_time, 0);
  1631. ark_vin->dvr_dev->detect_queue = create_singlethread_workqueue("detect_queue");
  1632. if(!ark_vin->dvr_dev->detect_queue) {
  1633. printk(KERN_ERR "%s %d: , create_singlethread_workqueue fail.\n",__FUNCTION__, __LINE__);
  1634. return -1;
  1635. }
  1636. INIT_WORK(&ark_vin->dvr_dev->detect_work, vin_get_signal_work);
  1637. mod_timer(&ark_vin->dvr_dev->signal_timer, jiffies + msecs_to_jiffies(10));
  1638. ark_vin->dvr_dev->scale_queue = create_singlethread_workqueue("scale_queue");
  1639. if(!ark_vin->dvr_dev->scale_queue) {
  1640. printk(KERN_ERR "%s %d: , create_singlethread_workqueue fail.\n",__FUNCTION__, __LINE__);
  1641. return -1;
  1642. }
  1643. INIT_WORK(&ark_vin->dvr_dev->scale_work, ark_vin_scale_work);
  1644. ark_vin->dvr_dev->itu_channel = ITU656_CH1;
  1645. if(!of_property_read_u32(pdev->dev.of_node, "channel", &value)) {
  1646. if(value >= ITU656_CH0 && value <= ITU656_CH2)
  1647. ark_vin->dvr_dev->itu_channel = value;
  1648. }
  1649. return 0;
  1650. }
  1651. static int ark1668e_vin_remove(struct platform_device *pdev)
  1652. {
  1653. struct ark1668e_vin_device *vin = platform_get_drvdata(pdev);
  1654. struct dvr_dev *dvr_dev = vin->dvr_dev;
  1655. #if 0
  1656. free_pages((unsigned long)dvr_dev->buffer_virtaddr, get_order(dvr_dev->buffer_size));
  1657. free_pages((unsigned long)dvr_dev->scale_out_yaddr, get_order(dvr_dev->scale_alloc_width*dvr_dev->scale_alloc_height*2));
  1658. #else
  1659. if(vin->dvr_dev->buffer_virtaddr)
  1660. dma_free_wc(vin->dev, vin->dvr_dev->buffer_size, vin->dvr_dev->buffer_virtaddr,vin->dvr_dev->buffer_phyaddr);
  1661. if(vin->dvr_dev->scale_out_yaddr)
  1662. dma_free_wc(vin->dev, vin->dvr_dev->scale_buffer_size,vin->dvr_dev->scale_out_yaddr,vin->dvr_dev->scale_out_yphyaddr);
  1663. #endif
  1664. iounmap(dvr_dev->context.lcd_base);
  1665. iounmap(dvr_dev->context.deinterlace_base);
  1666. iounmap(dvr_dev->context.sys_base);
  1667. del_timer(&vin->dvr_dev->timer);
  1668. del_timer(&vin->dvr_dev->signal_timer);
  1669. unregister_chrdev_region(MKDEV(dvr_dev->dev_major, dvr_dev->dev_minor), 1);
  1670. g_ark1668e_vin = NULL;
  1671. vin_subdev_cleanup(vin);
  1672. v4l2_device_unregister(&vin->v4l2_dev);
  1673. return 0;
  1674. }
  1675. static const struct of_device_id ark1668e_vin_of_match[] = {
  1676. { .compatible = "arkmicro,ark1668e-vin", },
  1677. { }
  1678. };
  1679. MODULE_DEVICE_TABLE(of, ark1668e_vin_of_match);
  1680. static struct platform_driver ark1668e_vin_driver = {
  1681. .driver = {
  1682. .name = "ark1668e-vin",
  1683. .of_match_table = of_match_ptr(ark1668e_vin_of_match),
  1684. },
  1685. .probe = ark1668e_vin_probe,
  1686. .remove = ark1668e_vin_remove,
  1687. };
  1688. static int __init ark_vin_init(void)
  1689. {
  1690. return platform_driver_register(&ark1668e_vin_driver);
  1691. }
  1692. device_initcall(ark_vin_init);
  1693. MODULE_AUTHOR("arkmicro");
  1694. MODULE_DESCRIPTION("The V4L2 driver for arkmicro");
  1695. MODULE_LICENSE("GPL v2");