Hi Steve, On Tue, Apr 19, 2016 at 1:06 PM, Steve deRosier <derosier@xxxxxxxxx> wrote: > Hi Julian, > > First off, let me say I do appreciate your comments and I do > understand your perspective. I also generally prefer not to let users > shoot-themselves in the foot if it's avoidable. > > In this case, however, I don't happen to agree with you. For one > specific reason: I don't want to say what baud rates are "safe" > because I think that's even more dangerous than not checking - because > we have no way of actually knowing what is or isn't for a particular > chip. > > Oddly enough I thought this all out before I ever sent the patch up. I questioned this change because it looked like you hadn't. You didn't mention this in the patch description and the change itself didn't imply this to me. >> I'm of the opinion that one should never underestimate the ability of >> people to attempt to shoot themselves in the foot. However this is >> only a debugging interface so you do make a good point. >> >> I guess I'm worried that some idiot is going to set it to 2 baud or 2 >> billion baud for some dumb reason then come complaining to us when >> their wireless card crashes or locks up or something. >> >> Maybe we can just sweep this all under the carpet by putting all the >> debug uart stuff behind some nice #ifdef. > > Well, first off the debugging stuff was never under some #ifdef. So, > we should make it even more complicated and add an #ifdef and yet > another kconfig option? Having debug options under an #ifdef is pretty common. > AFAIK, the firmware would be perfectly happy with 2 baud. I'm not in > my lab to try it right now, but it might well be (though your > throughput would be crap). Nor do I know the upper limit of the > register the firmware uses. This is kinda what I was looking for when I asked the question in the first place. You don't know for certain which rates are safe and which aren't and you don't know the limits of the hardware / firmware. > My firmware guy wanted 115200, and I could've hard-coded it to that > value, but I figured a bit of flexibility was warranted and would be > more upstreamable. I don't know every single valid or invalid value > for every ar6xxx chip. If we have it check for the value, then we have > some obligation to know the values we let in are valid for either all > or at least the chip the user is using. I don't know what was invalid > for many species of 6002. Or even all of the 6003 and 6004s and I've > been working with both the firmware and driver for these chips for 3 > years now. What might be valid on the yet to be imagined 6009? To be honest, I wouldn't have questioned this if you'd hardcoded it to 115200. Practically all serial hardware these days is capable of that rate, it's standard and it's sensible. > If we check, we are saying, "these are safe values and we want you to use them". > > 99.999% of users don't have access to this pin without a soldering > iron. I think someone who is going to tack a wire to their 6k chip is > entitled to set even stupid values if they think they have a reason. True, but the other side of this is that 99.999% of the people who will be using this will be using a standard baud rate. I personally cannot think of any sensible use case for a rate other than 115200 unless Qualcomm themselves produce hardware that interfaces with this and isn't capable of that rate. (And anyone doing firmware debugging will also be doing kernel development or be next to someone who is, so an #ifdef shouldn't be an issue.) > Again, simply my perspective. > > On a compromise: do you have a specific list of baud rates you'd like > to support and you know are valid across a wide swath of ath6kl chips? > Every rate I've tried, normal or weird, works fine. Granted, I haven't > tried anything slower than 9600, nor have I bothered checking the > clock error on the weird rates. If you have said list, I'd be happy to > code it up. But I think that specifically checking for rates is the > same as saying "this rate is supported" and I don't know that, so I > hope you do know what ones are valid. I don't know which ones are valid. 9600 to 115200 inclusive sounds like a sensible range to me. I was hoping that Kalle or someone knew or could talk to the hardware / firmware people (assuming they're still available. ath6k is obsolete IIRC.) and ask them. > Maybe you agree with my line of thinking (now that you know what it > is) or maybe not. That's OK. ;) I see your points. I agree with most of them. I don't agree with your logic that it should be unrestricted however. I consider this matter closed unless you decide to change the patch or someone else has comments. I don't decide if this is to be merged or not, so I'll leave this up to them. Thanks, -- Julian Calaby Email: julian.calaby@xxxxxxxxx Profile: http://www.google.com/profiles/julian.calaby/ -- To unsubscribe from this list: send the line "unsubscribe linux-wireless" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html