Hi, On 11/3/20 1:05 AM, Coiby Xu wrote: > On Tue, Oct 27, 2020 at 11:09:11AM +0100, Hans de Goede wrote: >> Hi, >> > ... >> >> So I see 2 ways to move forward with his: >> >> 1. Just disable the debounce filter for level type IRQs; or >> 2. Add a helper to sanitize the debounce pulse-duration setting and >> call that when setting the IRQ type. >> This helper would read the setting check it is not crazy long for >> an IRQ-line (lets say anything above 1 ms is crazy long) and if it >> is crazy long then overwrite it with a saner value. >> >> 2. is a bit tricky, because if the IRQ line comes from a chip then >> obviously max 1ms debouncing to catch eletrical interference should be >> fine. But sometimes cheap buttons for things like volume up/down on tablets >> are directly connected to GPIOs and then we may want longer debouncing... >> >> So if we do 2. we may want to limit it to only level type IRQs too. >> >> Note I have contacted AMD about this and asked them for some input on this, >> ideally they can tell us how exactly we should program the debounce filter >> and based on which data we should do that. > > Is there any update from AMD? I'm afraid not. > Based on the discussion, I'm going to > submit a patch to disable debounce filter for both level and edge > type IRQs, i.e. to remove relevant code in amd_gpio_irq_set_type of > drivers/pinctrl/pinctrl-amd.c since setting debounce filter is > orthogonal to setting irq type and Andy has submitted the patch to > support setting debounce setting supplied by ACPI in gpiolib-acpi.c Ok. > Btw, did you contact AMD through a representative? Yes I'm using Red Hat's contacts in to AMD's server department, which are putting me in contact with AMD'se client department. > Obviously CC them > didn't get their attention. There is an inconsistency for configuring > debounce timeout in pinctrl-amd as was spotted by Andy [1]. I also need > their feedback for this matter. > > [1] https://lore.kernel.org/patchwork/comment/1522675/ This is a case where Andy is obviously right and you should just use the higher precision "unit = 15625" value (except probably that is wrong too, see below). We have had similar issues with the docs for getting the TSC frequency on some Intel chips, where the docs said 16.6 MHz for a certain register value, where what they meant was 100/6 MHz which really is significantly different. This was leading to a time drift of 5 minutes / day on non networked (so no NTP) Linux systems. I think this is what Andy was referring to when he wrote: "What the heck with HW companies! (Just an emotion based on the experience)" So the lesson learned there is when you can be reasonable certain that the value really is a/b and the resulting digits of the value in the hw doc match that taking the lousy precision into account then you should probably assume the value really is a/b and not the lousy precision value given in the docs (or the code comment in this case). I mean 15.6 msec has 3 significant numbers, that gives an imprecision / error of approx. 1000 ppm where as a decent clock crystal is in the order of 50 ppm, so the hardware has a drift / error of approx. 50 ppm which makes using a value with an error of 1000 ppm in the code really really bad. Actually all the values look somewhat suspect. The comment: > Debounce Debounce Timer Max > TmrLarge TmrOutUnit Unit Debounce > Time > 0 0 61 usec (2 RtcClk) 976 usec > 0 1 244 usec (8 RtcClk) 3.9 msec > 1 0 15.6 msec (512 RtcClk) 250 msec > 1 1 62.5 msec (2048 RtcClk) 1 sec Helpfully gives the values in RtcClks. A typical RTC clock crystal is 32 KHz which gives us 31.25 usec per tick, so I would expect the values to be: 0 0 62.500 usec (2 RtcClk) 0 1 250.00 usec (8 RtcClk) 1 0 16.000 msec (512 RtcClk) 1 1 64.000 msec (2048 RtcClk) And the max multiplier seems to be 15, not 16 as is used for the Max Debounce Time's in the comment, so those are wrong too. I have a feeling the table was build the wrong way around (minus the RtcClk parts). They started with a Max Debounce Time of 1 sec, then divided that by 16 given them 62.5 msec, where as in reality we have 2048 ticks of a 32 KHz clock giving us 64 millisec, etc. I also wonder if the 0-15 divider really is a 0-15 divider or a 1-16 divider... This suggests: if (debounce < 61) { pin_reg |= 1; It really is a 0-15 divider, so without docs we should just assume that it is 0-15 for now, which makes the divide 1 second by 16 thing which got them 62.5 msec (or so I believe) a bit suspect. Either the divide by 16 is wrong, or the divider really is a 1-16 divider... Regards, Hans