[00:44] <gnurou> ezequielg: looks like it does yes
[00:44] <gnurou> ezequielg: sorry btw, still need to review your series >_<
[15:32] *** benjiG has left 
[15:52] *** jmondi has quit IRC (Read error: Connection reset by peer)
[18:40] <ndufresne> Kwiboo: in the HEVC uAPI, max_dec_pic_buffering_minus1, max_num_reorder_pics and max_latency_increase_plus1 should have been arrays in the SPS, since these values can differ per sub-layers
[19:51] <ndufresne> I wonder why the slice_params have in HEVC have diverged so much from H264
[19:52] <ndufresne> paulk-leonov: mripard: Any reason for this ? Also in H264, there is a byte offset in the case the slices are not in their own buffer each, how come this is done in HEVC ?
[19:59] <paulk-leonov> ndufresne: well, HEVC API is more or less still at draft stage
[19:59] <paulk-leonov> it indeed has diverged
[19:59] <ndufresne> well, the question is why
[19:59] <ndufresne> was it intentional, was there a rationale ?
[20:00] <ndufresne> or just that the bulk was copied form a different source ?
[20:00] <ndufresne> I'm thinking of stripping all the pp_ sps_ and slice_ prefix to the the struct named Sps, Pps and Slice ....
[20:01] <paulk-leonov> ndufresne: I guess the rationale is that it wasn't needed for cedrus?
[20:01] <paulk-leonov> the fields were derived from the spec mostly
[20:01] <ndufresne> well, using the same name for the same thing isn't driver specific
[20:01] <ndufresne> just basic consitency
[20:01] <jernej> paulk-leonov: can I ask you for VP8 review?
[20:02] <paulk-leonov> ndufresne: not sure I really understood the issue
[20:02] <paulk-leonov> is byte offset missing in HEVC?
[20:05] <ndufresne> yes
[20:05] <ndufresne> which means you have to place each slices in it's own buffer for cedrus
[20:06] <ndufresne> for frame base decoder it does not matter, since we only read the invariants from the first slice header
[20:06] <paulk-leonov> ndufresne: the HEVC spec I sent didn't have slice support to begin with
[20:06] <ndufresne> everything else is ignored, so it's pretty much all about cedrus
[20:06] <paulk-leonov> well I mean, it's in the same state as stateless before you guys fixed it
[20:06] <paulk-leonov> (the initial state for cedrus where all slices have to follow eachother)
[20:07] <paulk-leonov> same state as h264*
[20:07] <paulk-leonov> so that's a major issue
[20:07] <ndufresne> hmm, might not have followed the evolution then
[20:07] <paulk-leonov> well, IIRC it was fixed before h264 got merged
[20:08] <paulk-leonov> but the general idea was that there was no slice/frame distinction
[20:08] <ndufresne> I guess HEVC was just never reviewed much
[20:08] <ndufresne> well, there will be
[20:08] <ndufresne> that is something we'll introduce later
[20:09] <ndufresne> all the slice invariants will got in a decode_params, so that for frame based this will be sufficient, and for slice based, you can reduce the amount of ctr data you send
[20:09] <ndufresne> there is a patch for h264 (the finalization serie)
[20:10] <paulk-leonov> (switched computer, wifi stopped working for some reason)
[20:10] <ndufresne> now, I was suprise that no VPS data is passed, also clearly we assume that num layers == 1
[20:10] <paulk-leonov> yes lack of layering support is another issue
[20:11] <ndufresne> right now, adding it later is not possible without break, so we have to be careful with that
[20:11] <paulk-leonov> if you look at the cover for the HEVC series I've tried to enumerate missing/broken things
[20:11] <ndufresne> it's quite possible it's also a problem on H264, I'm not yet familiar with that part
[20:11] <paulk-leonov> can we stop caring about breaking the API?
[20:11] <paulk-leonov> it was meant to be broken later on
[20:11] <paulk-leonov> the HEVC API was really an early draft
[20:12] <ndufresne> well, I care about breaking it in the right direciton, hence the me checking if there is any rationale ;-P
[20:12] <paulk-leonov> ah :)
[20:12] <paulk-leonov> makes sense yes
[20:12] <paulk-leonov> what I mean that it's indeed known that it's broken now
[20:12] <paulk-leonov> ndufresne: for H.264 it's an extension as far as I know
[20:13] <paulk-leonov> the current H.264 spec is about H.264 AVC which does not include layers, as far as I understood
[20:13] <ndufresne> and ideally if we can do that all at once, so that we have a clear cut, and be able to communicate that up to kernel X use let's say gst Y, and kernel Z+ is now stable
[20:14] <ndufresne> paulk-leonov: right, I think I was thinking about the enhancement nal
[20:14] <paulk-leonov> I would love to be able to say that someday, yes
[20:14] <paulk-leonov> ndufresne: IIRC layers or so are in MVC
[20:14] <paulk-leonov> in H.264
[20:14] <paulk-leonov> but in H.265 they are part of the main spec
[20:15] <ndufresne> do you think we should ignore mvc and bring on H264_MVC_SLICE format if we need it ?
[20:15] <paulk-leonov> well, at least I think we should thing it through it before declaring anything stable :)
[20:15] <paulk-leonov> think*
[20:15] <paulk-leonov> but yes another control seems like a good idea
[20:15] <ndufresne> indeed, note that I don't have HW with MVC profiles, rkvdec is stereo though
[20:16] <paulk-leonov> ndufresne: frankly I have lots of doubts about current H.264 spec, I'm quite unhappy about how hantro-specific fields are handled and a few other things
[20:16] <ndufresne> there is only 2 hantro specific fields
[20:16] <paulk-leonov> ndufresne: me neither, and as far as I know even ffmpeg support for MVC is q bit experimental
[20:16] <paulk-leonov> ndufresne: right
[20:17] <paulk-leonov> ndufresne: anyway I'll switch to private for more context if you're interested
[20:18] <ndufresne> paulk-leonov: you can still speak up, we discussed these two fields over and over, and we thought it was more efficient then adding the related syntax element (which are not needed of course) and golum encode them to compute their sizes
[20:18] <ndufresne> of course from a VAAPI point of view, these syntax element are not there, so if you don't do like pH5 (which is to extend VAAPI), you endup having to deep parse in the VAAPI driver
[20:18] <paulk-leonov> ndufresne: it's just that we're making an exception by adding these fields in the "common" API
[20:19] <paulk-leonov> ndufresne: yeah I've actually worked with your patches recently :)
[20:19] <paulk-leonov> so I have a pretty clear idea of the userspace side of things
[20:19] <ndufresne> trust me, Hantro IP is not an exception, it's found even in PCs ;-P
[20:19] <paulk-leonov> ndufresne: well, I mean, the IP needs these two size information fields, which are not bitstream elements
[20:20] <paulk-leonov> any other IP could need any other size for whatever reason
[20:20] <paulk-leonov> I totally agree we absolutely need a solution that works for hantro
[20:20] <paulk-leonov> but I'm starting to think hantro-specific controls would make more sense
[20:20] <jernej> which fields are that?
[20:21] <ndufresne> realisticly, if you don't implement it in userspace, your code will only work on cedrus, which is already different from all the currently existing others
[20:21] <paulk-leonov> ndufresne: just because I'm afraid some other IP will need more of these specific fields and it'll be too late to add them to the common API
[20:21] <paulk-leonov> ndufresne: we definitely need to implement it in userspace
[20:22] <paulk-leonov> I just don't like that we pass it as part of the common H.264 controls
[20:22] <paulk-leonov> jernej: mhh let me dig them
[20:22] <ndufresne> jernej: .dec_ref_pic_marking_bit_size and .pic_order_cnt_bit_size ;-D
[20:22] <paulk-leonov> ah thanks :)
[20:23] <paulk-leonov> ndufresne: I mean, it wouldn't hurt so bad for userspace to have an extra control for hantro with these two fields
[20:23] <paulk-leonov> other hardware has specific controls
[20:23] <ndufresne> as I worked on the software behind it in gstreamer recently, I have pretty good understanding why the accelerator do not need this information
[20:23] <paulk-leonov> (exynos MFC IIRC)
[20:23] <ndufresne> paulk-leonov: and then rkvdec implement an Hantro control or you fork it for rkvdec ?
[20:23] <paulk-leonov> I'd say one per driver
[20:24] <ndufresne> but it's identical, do you relaize the userspace mess ?
[20:24] <paulk-leonov> but maybe we can also make it a common "extra info" control with lots of TBD fields to fit future needs to
[20:24] <paulk-leonov> too
[20:24] <paulk-leonov> ndufresne: no, it's not identical
[20:24] <paulk-leonov> an uAPI spec is meant to be hardware-independent
[20:24] <paulk-leonov> these two fields clearly aren't
[20:24] <ndufresne> well, both uses this iirc
[20:25] <paulk-leonov> if we make this exception for hantro we must be able to make the same exception for future hardware
[20:25] <paulk-leonov> ndufresne: it's definitely not part of the spec
[20:25] <ndufresne> with such a strict rules, you'd have to remove anything (even if it's in the syntax) that isn't used by all HW, that make no sense
[20:25] <paulk-leonov> I don't follow
[20:25] <ndufresne> paulk-leonov: how is the calculate size of a specified set of values not part of the spec ?
[20:26] <paulk-leonov> ndufresne: because it's not a bitstream field or something derived from a bitstream field needed for decoding?
[20:26] <paulk-leonov> I mean, these two fields don't show up on the spec
[20:26] <paulk-leonov> they are hardware-specific
[20:26] <ndufresne> it's derived from the parsing of sets of bitstream fields
[20:26] <paulk-leonov> yes but not part of the spec
[20:27] <paulk-leonov> I mean there are limitless combinations of sizes that can be derived
[20:27] <paulk-leonov> we can't include them all
[20:27] <ndufresne> there are far from random or even odd
[20:27] <paulk-leonov> what if some other hardware needs some other size?
[20:27] <paulk-leonov> them it would have to be part of the main spec
[20:27] <ndufresne> ref_pic_marking and poc calculation is explicitly out of scope of the accellerators
[20:28] <ndufresne> why would you make some HW to parse it if it's just to throw away the result
[20:28] <paulk-leonov> yes but the reason to provide them is because the hardware needs to skip them
[20:28] <ndufresne> I don't see how you can make a small frame based accelerator that does not need this information
[20:28] <paulk-leonov> well it could definitely parse it
[20:28] <paulk-leonov> deciding to provide a size to skip it is an implementation choice
[20:28] <ndufresne> but then you have a bigger design, rememer these design are mostly run on FPGA
[20:28] <paulk-leonov> to gain a few clock cycles
[20:29] <paulk-leonov> my point is that it cannot be generalized
[20:29] <ndufresne> it's not about speed, it's about fpga bitstream size
[20:29] <paulk-leonov> what if some hardware has a more limited set of supported features and wants to skip other fields?
[20:29] <ndufresne> I think it can
[20:29] <paulk-leonov> I don't think it makes sense to accomodate that in the main spec
[20:29] <ndufresne> all other fields in the slice are used for the remaining decoding process
[20:29] <ndufresne> so good luck wiht that
[20:30] <paulk-leonov> not really
[20:30] <ndufresne> example ?
[20:30] <paulk-leonov> there are a few that aren't actually needed
[20:30] <paulk-leonov> 1 sec
[20:30] <paulk-leonov> hey_there_420
[20:30] <paulk-leonov> oops
[20:31] <paulk-leonov> slice_qs_delta
[20:31] <ndufresne> you mean slice_qp_delta ?
[20:31] <paulk-leonov> no, _qs
[20:31] <paulk-leonov> _qs is more MVC as far as I know
[20:31] <paulk-leonov> is for*
[20:31] <paulk-leonov> there's also pic_init_qs_minus26 in pps
[20:32] <ndufresne> "slice_qs_delta specifies the value of QS Y for all the macroblocks in SP and SI slices." Per macrosblock is the low step of the decoding process
[20:32] <paulk-leonov> we don't support SP and SI slices
[20:33] <ndufresne> that's probably a bug no ?
[20:33] <paulk-leonov> no, it's a field that's only useful for MVC
[20:33] <paulk-leonov> we could remove it
[20:33] <paulk-leonov> but the point is that the hardware might also want to skip it
[20:34] <paulk-leonov> ndufresne: anyway that's not the major thing I care about regarding H.264 spec
[20:34] <paulk-leonov> and I don't really mind that we keep it or not
[20:34] <paulk-leonov> I just feel like it would be better to separate it
[20:34] <paulk-leonov> just because that would give us head room
[20:34] <ndufresne> this one is a bad example, since you don't have to skip it, if it's not supported it should not be in the bitstream
[20:34] <paulk-leonov> to add more of these
[20:34] <paulk-leonov> ndufresne: IIRC bitstream always has the field regardless
[20:34] <paulk-leonov> (it's not conditional)
[20:35] <ndufresne> if it's a if in the spec I'm reading
[20:35] <ndufresne> if( slice_type = = SP | | slice_type = = SI ) {
[20:35] <paulk-leonov> ah!
[20:35] <ndufresne> otherwise it's not there
[20:35] <paulk-leonov> my bad then
[20:35] <paulk-leonov> (I was a bit surprised too :p)
[20:35] <paulk-leonov> anyway
[20:35] <ndufresne> specially H264, they been compressing the header so much ...
[20:35] <paulk-leonov> my point is mostly that by separating them, we make it easier to add more extra information if needed later
[20:36] <paulk-leonov> by adding lots of reserved bits aside
[20:36] <ndufresne> if they could save one bit by splitting something in half and replacing with a formula, then they did it
[20:36] <paulk-leonov> hehe
[20:37] <paulk-leonov> so either adding a specific control, allows adding more such controls as needed later, or by having a single control with extra reserved bits
[20:37] <paulk-leonov> I think it would be a bit fragile to bet that no hardware will need extra info in the future
[20:37] <paulk-leonov> even if we can't think of it now
[20:37] <ndufresne> you don't need these reserve bits, with the ext_ctrl, you can add more controls as needed, though software is not going to be forward compatible with these addition, for decoding that's not possible anyway
[20:38] <paulk-leonov> ndufresne: yeah so in this case I'm just saying we should make this a separate control already
[20:38] <paulk-leonov> for consistency
[20:38] <ndufresne> I mean, that you split it now or not does not make any difference, making it vendor is a problem though, for these two at least
[20:38] <ndufresne> cause we already have 2 of the 2 frame base vendor HW
[20:39] <paulk-leonov> yeah, granted if both rkdec and hantro need it, it would gain to not be hantro-specific
[20:39] <ndufresne> I think if we split, we should keep these two generic, but find a way to have sort what is not needed by slice base decoder, and move these two along with all the frame base only decoder info
[20:39] <ndufresne> but is it really worth the hassle ?
[20:40] <paulk-leonov> it's just for consistency, for the sake of having a common API that doesn't carry hardware implementation details
[20:40] <ndufresne> I think overall it's around 20bytes delta, that's not going to be visible on any benchmark
[20:40] <paulk-leonov> it's not really about perf
[20:40] <paulk-leonov> just about keeping the spec tidy
[20:41] <paulk-leonov> anyway, if I find the courage to follow-up on the recent developments to finalize the spec, I'll bring this up
[20:41] <ndufresne> well, read through latest serie from ezequielg if you have some time
[20:42] <paulk-leonov> I should
[20:42] <ndufresne> as this is what we believe is right for turning that API public
[20:42] <paulk-leonov> I think I have a few notes of things that left to be discussed
[20:43] <paulk-leonov> that are*
[20:43] <ndufresne> but, we also have homework on studying MVC and also the optional NAL (enhancement)
[20:43] <paulk-leonov> MVC and other extensions handling is one thing
[20:43] <paulk-leonov> tes
[20:43] <paulk-leonov> yes
[20:43] <paulk-leonov> removing the SI/SP fields could be a good idea too
[20:43] <ndufresne> if you find these notes, just paste them as reply of Ezequiel cover, we'll do the research
[20:44] <paulk-leonov> and I've also seen some stuff from the microsoft H.264 hw decoding implementation that we seem to have missed
[20:44] <paulk-leonov> ndufresne: thanks for offering to do the heavy lifting
[20:44] <ndufresne> I thought I had compare it against DXVA2, but I can redu the excersize
[20:45] <paulk-leonov> tbh I wish I was more involved with all this, but I just plain failed at keeping up
[20:45] <paulk-leonov> although I've been working with hantro some time ago
[20:45] <ezequielg> \o
[20:45] <paulk-leonov> the upside is that I have a hantro encoder implementation working
[20:45] <paulk-leonov> and soon mipi-csi2 on sunxi
[20:45] <ezequielg> paulk-leonov: that's nice to hear.
[20:45] <ndufresne> we've been working with hantro more deeply then we really wanted to now ;-P
[20:46] <paulk-leonov> hey ezequielg :)
[20:46] <ezequielg> hantro over what version of the ip block, if i may ask?
[20:46] <paulk-leonov> ezequielg: whatever's in the PX30
[20:46] <ndufresne> ok, so a RK3399 like I think
[20:46] <paulk-leonov> AFAIK similar to rk3399
[20:46] <paulk-leonov> yeah :)
[20:46] <ndufresne> so the hantro without the hantro regs
[20:46] <paulk-leonov> indeed
[20:46] <paulk-leonov> ah I have some high-profile decoding issues too btw
[20:47] <ezequielg> not sure what you've implemented, but a solution via a v4l plugin is already implmented by google.
[20:47] <ezequielg> that is for encoding.
[20:47] <paulk-leonov> ezequielg: yeah I know
[20:47] <ezequielg> we have that working as well, and it's shipped on chromeos.
[20:47] <paulk-leonov> I've more or less based my work on that
[20:47] <ndufresne> we believe it was perhaps a mistake to make it part of hantro, we know it's the same-ish G1/H1, with different regs
[20:47] <paulk-leonov> but that's not fit for upstream
[20:47] <ezequielg> why not?
[20:47] <paulk-leonov> (for the encoder I mean)
[20:47] <ezequielg> yeah, why not?
[20:47] <paulk-leonov> well, it's very very hardware-specific
[20:48] <ezequielg> you mean the parameters?
[20:48] <ndufresne> you are using the checkpoints ?
[20:48] <paulk-leonov> and the hantro encoder also has needs that userspace can't guess at all
[20:48] <paulk-leonov> yeah checkpoints, feedback data
[20:48] <paulk-leonov> but also the fact that it generates slices with given constraints
[20:48] <paulk-leonov> and the slice header needs to reflect those
[20:48] <ndufresne> some of the feedback is pretty generic, but you cannot assume all HW will provide it
[20:48] <paulk-leonov> ndufresne: some of it, but it's hard to generalize
[20:48] <paulk-leonov> I've tried
[20:49] <ndufresne> the MAD feedback is very specific to the RC model they wanted to use
[20:49] <paulk-leonov> and concluded that it cannot work
[20:49] <paulk-leonov> yes
[20:49] <ndufresne> an in fact, that no longer exist on recent hantro (now verisillicon) HW
[20:49] <ezequielg> and do you think it's insane to have hw specific controls?
[20:49] <ezequielg> i.e. private controls?
[20:49] <paulk-leonov> yeah I've seen they have given up
[20:49] <paulk-leonov> and now they do RC in a more normal way
[20:49] <paulk-leonov> ezequielg: well it would just be a driver-specific API
[20:50] <ndufresne> despite having all the doc, we still haven't figure-out what their HW feedback is, the code we received is not using it ;-P
[20:50] <ezequielg> i haven't thought a great deal on how we'll upstream that, but i remember thinking a solution based on public pps/sps + private controls would work.
[20:50] <paulk-leonov> the best alternative I see is to have the kernel generate the bitstream
[20:50] <ezequielg> paulk-leonov: yeah, just like any DRM driver.
[20:50] <paulk-leonov> ezequielg: which is exactly what we should try to avoid :p
[20:50] <ezequielg> why?
[20:51] <ndufresne> I'm in contact with Sree at Intel, it seems customers are unhappy of the variation between gens for HW drive rate control
[20:51] <paulk-leonov> ezequielg: because we can avoid it
[20:51] <ndufresne> so he's starting a project, which is a collection of RC algorithm that are not covered by any patents
[20:52] <paulk-leonov> ndufresne: ah nice!
[20:52] <paulk-leonov> ezequielg: because generic API is better than vendor API?
[20:52] <paulk-leonov> because it's a wide-open door to proprietary implementations and making free software yet again a second class citizen?
[20:52] <paulk-leonov> all that :)
[20:52] <ndufresne> the idea is to get that to work frame base, standalone, and later on introduce feedback channel that can use feedback as describe on the the major papers
[20:52] <ndufresne> as long as they are usable without using the patents of course
[20:53] <ndufresne> (e.g. the patent need to be only used by the HW, not the SW) that's their rule
[20:53] <ezequielg> not saying generating a few headers in the driver is all too difficult, but i also don't think pushing stuff to the kernel to avoid a userspace is an easy choice.
[20:53] <paulk-leonov> ndufresne: the idea sounds nice in theory but having a common feedback channel seems near impossible in practice
[20:53] <ndufresne> if you have scene detection, that's pretty boolean ;-P
[20:54] <paulk-leonov> there's also ROI stuff for example
[20:54] <ndufresne> that bit is quite generic, the number of ROI is what varies
[20:54] <paulk-leonov> right
[20:54] <paulk-leonov> one other aspec is exposing constraints
[20:54] <paulk-leonov> aspect
[20:55] <ezequielg> paulk-leonov: so, back to h264 decoder uapi: the only thing on my mind is field encoding support.
[20:55] <paulk-leonov> like, what will the hardware actually choose to do and how it has to be reflected in the slice header
[20:55] <ezequielg> i don't want to leave this uapi private much longer.
[20:55] <ndufresne> yes, some of it will be as simple as using the existing control min/max, or menu items
[20:56] <paulk-leonov> ezequielg: I would really like that it stays private until we have a good understanding and coverage of the H.264 spec, as well as a good number of samples that reflect the possible diversity tested
[20:56] <ezequielg> we can't keep the uapi private for ever.
[20:56] <paulk-leonov> ndufresne: there's a lot that's missing
[20:56] <ezequielg> but we can extend it in the future.
[20:56] <ndufresne> we don't have to gamble
[20:56] <ndufresne> I'm working on harnessing the ITU conformance into gst
[20:56] <paulk-leonov> oh nice
[20:57] <paulk-leonov> sure we can't keep it private for ever, but I just don't think it's ready
[20:57] <ndufresne> if we  say MVC is out of scope -> new format, we pick the right ITU subset, pass it, and we are good
[20:57] <paulk-leonov> (granted I haven't caught up with recent development)
[20:57] <paulk-leonov> yes for MVC it's not too worrying
[20:57] <ezequielg> paulk-leonov if you can't catch up then that's fine.
[20:57] <ezequielg> but as i friend recently said, the train is leaving the station.
[20:57] <ndufresne> There is a lot of work that ezequielg, Kwiboo and jernej did recently, you may have missed some I guess
[20:57] <paulk-leonov> definitely
[20:58] <paulk-leonov> but I'm still unclear on a few aspects
[20:58] <ezequielg> if there are things we are missing, we'll have to introduce v2 or new controls.
[20:58] <ezequielg> gotta go. funny (or sad) i'm debugging some hantro-like hw at the moment.
[20:58] <ndufresne> tbf, I'm not effraid of a v2 if we find out that strictly needed, but remember this is a legacy codec
[20:59] <ezequielg> let's try to move discussion to public ML as much as possible.
[20:59] <paulk-leonov> my general feeling is that I lack good understanding of the whole thing and feel like there are grey areas all around, which really isn't a good mindset for me to be confident that things are good to go
[20:59] <paulk-leonov> maybe I just need to be reassured
[20:59] <ndufresne> we need a fair in the field coverage, and at this stage, the codec is so legacy that I assume if there is no HW supporting some feature, they won't be implemented later
[21:00] <ndufresne> paulk-leonov: you can read through VAAPI, and DXVA2, you'll have the same feeling, they aren't perfect, there is few oops and workaround, but these API have lived for over 10years, and folks are fine wiht it
[21:01] <paulk-leonov> yeah but that's vendor stuff, I just hoped we could do better...
[21:01] <ndufresne> as for new feature, they just introduce new profiles, which comes with new version of header structure, and they keep going like this
[21:03] <ndufresne> it's also possible that V2 endup being done with DRM model, as clearly we ended up reinventing few things with the request and still suffer some overhead for high rate
[21:03] <paulk-leonov> one of the reasons I'm interested in doing mainline is that we usually don't settle for the quick and dirty solution -- I'm not saying it's the case here but I don't feel we have a good enough grasp on it, and most of what we have comes from the chromeos stuff
[21:03] <paulk-leonov> ndufresne: I'm not too worried about new profiles/versions indeed
[21:03] <paulk-leonov> same as MVC
[21:05] <ndufresne> it's been 5 years, of course we spend more time with the request -> job -> request then on the codec itself
[21:05] <ndufresne> but clearly not quick
[21:05] <paulk-leonov> I know...
[21:06] <paulk-leonov> it's not like I have a better solution anyway
[21:07] <paulk-leonov> this is a highly complex topic, I think it's challenging for everyone
[21:07] <paulk-leonov> and I understand we need to stop at some point and get it in