On 21 May 2015 at 22:40, David Härdeman <david@xxxxxxxxxxx> wrote: > On Thu, May 21, 2015 at 05:22:08PM +0300, Antti Seppälä wrote: >>On 21 May 2015 at 15:30, David Härdeman <david@xxxxxxxxxxx> wrote: >>> On 2015-05-21 13:51, Antti Seppälä wrote: >>>> >>>> On 21 May 2015 at 12:14, David Härdeman <david@xxxxxxxxxxx> wrote: >>>>> >>>>> I'm talking about ir_raw_encode_scancode() which is entirely broken in >>>>> its >>>>> current state. It will, given more than one enabled protocol, encode a >>>>> scancode to pulse/space events according to the rules of a randomly >>>>> chosen >>>>> protocol. That random selection will be influenced by things like *module >>>>> load order* (independent of the separate fact that passing multiple >>>>> protocols to it is completely bogus in the first place). >>>>> >>>>> To be clear: the same scancode may be encoded differently depending on if >>>>> you've load the nec decoder before or after the rc5 decoder! That kind of >>>>> behavior can't go into a release kernel (Mauro...). >>>>> >>>> >>>> So... if the ir_raw_handler_list is sorted to eliminate the randomness >>>> caused by module load ordering you will be happy (or happier)? >>> >>> >>> No, cause it's a horrible hack. And the caller of ir_raw_handler_list() >>> still has no idea of knowing (given more than one protocol) which protocol a >>> given scancode will be encoded according to. >>> >> >>Okay, so how about "demuxing" the first protocol before handing them >>to encoder callback? Simply something like below: >> >>- if (handler->protocols & protocols && handler->encode) { >>+ if (handler->protocols & ffs(protocols) && handler->encode) { >> >>Now the behavior is well-defined even when multiple protocols are selected. > > Your patchset introduced ir_raw_encode_scancode() as well as the only > two callers of that function: > > drivers/media/rc/nuvoton-cir.c > drivers/media/rc/rc-loopback.c > > I realize that the sysfs wakeup_protocols file (which bakes several > protocols into one label) makes defining *the* protocol difficult, but > if you're going to add hacks like this, keep them to the sole driver > using the API rather than the core API itself. > > That is, change nvt_ir_raw_change_wakeup_protocol() so that it picks a > single protocol, no matter how many are passed to it (the img-ir driver > already sets a precedent here so it wouldn't be an API change to change > to a set of protocols which might be different than what the user > suggested). (Also...yes, that'll make supporting several versions of > e.g. RC6 impossible with the current sysfs code). > I think that approach too is far from perfect as it leaves us with questions such as: How do we let the user know what variant of protocol the label "rc-6" really means? If in nvt we hardcode it to mean RC6-0-16 and a new driver cames along which chooses RC_TYPE_RC6_6A_24 how do we tell the user that the implementations differ? What if the scancode that was fed was really RC_TYPE_RC6_MCE? If only there were a sysfs api to set the exact variant life would be simpler... > Then change both ir_raw_encode_scancode() to take a single protocol enum > and change the *encode function pointer in struct ir_raw_handler to also > take a single protocol enum. > > That way encoders won't have to guess (using scanmasks...!?) what > protocol they should encode to. > > And Mauro...I strongly suggest you revert all of this encoding stuff > until this has been fixed...it's broken. > Let me shortly recap the points made so far about the encoding stuff: * If user enables multiple wakeup_protocols then the first matching one will be used to do the encoding. "First" being the module that was loaded first. * Currently the encoders use heuristics to determine the intended protocol variant from the scancode that was fed and from the length of the scanmask. This causes the programmer using the encoder to not know which exact variant will be used (until after the encoding is done when the information can be made available if needed). The way current sysfs api works using heuristics was a design choice since we don't have a better way to specify the protocol variant. Hope I didn't miss anything? So yeah.. The code isn't "broken" in a sense that it wouldn't work. It's more a question of what we want the api to look like. Mauro what do you think should be done? -- Antti -- To unsubscribe from this list: send the line "unsubscribe linux-media" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html