<!-- 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