<!-- Some styling for better description lists --><style type='text/css'>dt { font-weight: bold;float: left;display:inline;margin-right: 1em} dd { display:block; margin-left: 2em}</style> ***: Satyricon has quit IRC (Ping timeout: 276 seconds) <br> sailus has quit IRC (*.net *.split) <br> arnd has quit IRC (*.net *.split) nohous: <u>hverkuil</u>: any ideas for new pixel formats naming? I need to define macros for fourccs V210, V410, YUV2 (that one's actually the same as YUYV), 2VYU, V308, V408, V216 <br> <u>hverkuil</u>: and also something for densely-packed 10b a 12b YUV 4:2:2, YUV 4:4:4, RGB, RGBA <br> what i have for the former is like V4L2_PIX_FMT_V308 hverkuil: The name of the define is generally something that is more-or-less descriptive, which V308 is clearly not. At least, I don't know what it means. The fourcc is up to you: if these are already defined somewhere for these formats, and they are not yet used in videodev2.h, then just reuse those. nohous: <u>hverkuil</u>: well, these are fourccs coming from quicktime hverkuil: For the 10 and 12 bit versions I would do something like V4L2_PIX_FMT_YUYV_10BPACK/12BPACK (without the PACK these would take 16 bits per pixel). This more-or-less conforms to existing defines like FMT_Y10 and Y10BPACK. nohous: yes, that seems nice, but how to distinguish between formats where 3 10b components are packed in 32bits with 2 bits of padding vs. densely-packed 10 b formats? hverkuil: We don't really have guidelines for the actual fourcc. The only exception is that big-endian variants are signaled by setting bit 31 (if memory serves). <br> So densely packed would have 4 pixels per 40 bits (or 5 bytes)? nohous: right <br> let me show you picture <br> http://i.imgur.com/cUSNSOw.png <br> densely packed: C.2, padded format: C.3 hverkuil: Hmm, Y10BPACK is exactly that. nohous: this scheme is also agnostic with respect to actual component count per pixel btw, so C.3/C.2 can be used for 4:2:2, 4:4:4, 4:4:4:4, 4:2:2:4.... <br> it is, but we need to define versions of Y10BPACK and the C.3 for YUV422/YUV444/RGB444/RGBA4444/YUVA4224 hverkuil: YUYV_10B vs YUYV_10BPAD vs YUYV_10BPACK <br> <u>10B</u>: use 16 bits per component, 10BPAD: pack in 32 bits with padding, 10BPACK: pack without padding. nohous: <u>hverkuil</u>: ok, great. I guess the names don't have to be absolutely descriptive since formats are detailed in documentation hverkuil: Hmm, make that 10BPAD32. <br> Right. nohous: the "default" endianness is little in v4l2, right? hverkuil: y nohous: i'll do YUYV_422_10BPAD32 and YUYV_444_10BPAD32 <br> argh, with v210 to packing goes on the msbs of uint32_t, whereas in v410 it goes to lsbs <br> so V4L2_PIX_FMT_UYV422_10BPAD32M for MSB padding and V4L2_PIX_FMT_UYV422_10BPAD32L for LSB padding (both are little endian) hverkuil: How about PAD32HI and PAD32LO? That is conform what is used in include/uapi/linux/media-bus-format.h <br> . <br> (media bus formats describe how data passed from one HW block to another, they don't describe the memory layout) <br> But they also need to specific where the padding goes, so let's use the same naming. nohous: ok hverkuil: I would use V4L2_PIX_FMT_YUYV_10BPAD32HI. The 422 is unnecessary since YUYV is implicitly 422. Stick to the names given for the existing 8 bit variants and just add the suffix. nohous: hverkuil, ok, so for 422 formats i'll use four characters for component order (YUYV), whereas for 444 i'll use only chars (e.g. YUV) hverkuil: Right. nohous: btw, is i it a good idea to split the driver into multiple subdevs? one argument is that we're going to have multiple rx / tx channels with possibility for channel aggregation and another is that i could split the sdi pipeline and memory pipeline <br> sdi rx provides some data format which could be exposed via one output pad and memory pixel packer would have an input pad with its own format hverkuil: That's a design decision you are best placed to make. It tends to depend on how independent from one another these blocks are. <br> A good first approximation is to go with the high-level block diagram: if it is a separate block, then it should probably be a separate driver. nohous: ok, i'll have to think this through since we need to support kernels as old as 3.8 and i am not sure in what state is media-bus api there hverkuil: It shouldn't be a problem. 3.8 has the support you need AFAICT. mchehab: <u>hverkuil</u>: just fixed the build issues with media_build, but it seems that there's a problem on your scripts/environment when calling smatch... from your logs: <br> <u>smatch</u>: ERRORS collect2: error: ld returned 1 exit status elf.h:22:18: fatal error: gelf.h: No such file or directory elf.h:22:18: fatal error: gelf.h: No such file or directory elf.h:22:18: fatal error: gelf.h: No such file or directory arch/x86/../../elf.h:22:18: fatal error: gelf.h: No such file or directory hverkuil: <u>mchehab</u>: fixed smatch. I was missing a libelf-dev package for some reason. Probably fallout from an upgrade I did yesterday. mchehab: yeah, sometimes upgrades don't go that well ;) <br> anyway, it won't hurt if you could manually run the script to double check if everything is building well <br> I tested building here only with Kernel 4.4.6 hverkuil: I'll let it run tonight and check the results tomorrow. ***: awalls has left sailus_: <u>mchehab</u>: Obrigado! mchehab: de nada! pinchartl: looks like ELC-E will take place one week later than initially planned broonie: <u>pinchartl</u>: Was there an announcement about that yet? <br> <u>hverkuil</u>: AFAICT it's some changes in the kernel build, same thing has bitten kernelci.org. pinchartl: <u>broonie</u>: there was one in the ELC speakers e-mail that was sent today <br> Tim mentioned he would publish an official notification next week broonie: Ah, I got an attendee e-mail today but it was the usual LF unreadable HTML only on my text mail client. -: broonie wants to book travel! larsc: the speaker mail is readable in plain-text only <br> actually it is much more legible than the html version <br> I was thinking about submiting a talk fo ELC-E: "The future of audio on Linux - The end of an golden age (?)" pinchartl: <u>larsc</u>: please do <br> and feel free to blame Intel in that Intel-sponsored conference :-) <br> they seem to rapidly lose the little common sense they still had headless: <u>pinchartl</u>: I'm prepping the TCON support for posting <br> hi pinchartl: <u>headless</u>: oh ? <br> will I like it ? :-) headless: <u>pinchartl</u>: we'll see <br> the origina code was even tested (but I don't have the test target for my version) <br> original <br> prosit <br> nite