From mboxrd@z Thu Jan 1 00:00:00 1970 From: David Cohen Subject: Re: [PATCH 2/2] mrst_max3110: fix SPI UART interrupt parameters Date: Wed, 23 Oct 2013 11:10:48 -0700 Message-ID: <52681128.2010404@linux.intel.com> References: <1382470930-13807-1-git-send-email-david.a.cohen@linux.intel.com> <5266E070.2060408@linux.intel.com> <5267041F.2090905@linux.intel.com> <1382509666.28248007@f107.i.mail.ru> Mime-Version: 1.0 Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 7bit Return-path: Received: from mga01.intel.com ([192.55.52.88]:5071 "EHLO mga01.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751727Ab3JWSGg (ORCPT ); Wed, 23 Oct 2013 14:06:36 -0400 In-Reply-To: <1382509666.28248007@f107.i.mail.ru> Sender: linux-serial-owner@vger.kernel.org List-Id: linux-serial@vger.kernel.org To: Alexander Shiyan Cc: gregkh@linuxfoundation.org, jslaby@suse.cz, ning.li@intel.com, ivan.gorinov@intel.com, linux-kernel@vger.kernel.org, linux-serial@vger.kernel.org On 10/22/2013 11:27 PM, Alexander Shiyan wrote: >> On 10/22/2013 01:30 PM, David Cohen wrote: >>> On 10/22/2013 12:46 PM, Alexander Shiyan wrote: >>>>> The change in the max3110 driver makes the IRQ handling threaded, now >>>>> the handler is called only once per received character. Without that >>>>> change, we had many (more than 100) interrupts per one received >>>>> character. >>>>> >>>>> Unfortunately, SFI interface does not support IRQ polarity and >>>>> triggering modes, so we have to keep the hacks as hard-coded device >>>>> names and IRQ numbers until we switch to ACPI. >>>>> >>>>> Edge-triggered IRQ still supported to keep old platforms working. >>>>> Use platform data to pass the irq mode argument. >>>>> >>>>> Signed-off-by: Ivan Gorinov >>>>> Signed-off-by: Li Ning >>>>> Signed-off-by: David Cohen >>>> ... >>>>> +++ b/include/linux/serial_max3110.h >>>>> @@ -0,0 +1,16 @@ >>>>> +#ifndef _LINUX_SERIAL_MAX3110_H >>>>> +#define _LINUX_SERIAL_MAX3110_H >>>>> + >>>>> +/** >>>>> + * struct plat_max3110 - MAX3110 SPI UART platform data >>>>> + * @irq_edge_trigger: if IRQ is edge triggered >>>>> + * >>>>> + * You should use this structure in your machine description to specify >>>>> + * how the MAX3110 is connected. >>>>> + * >>>>> + */ >>>>> +struct plat_max3110 { >>>>> + int irq_edge_triggered; >>>>> +}; >>>>> + >>>>> +#endif >>>>> -- >>>> >>>> Is just resource->flags for IRQ can be reused for handle such case? >>> >>> I believe your suggestion makes perfect sense. I'll rework it. >> >> Looks like isp_device has no place for 'resource'. In this case pdata >> seems to be the way to go here. >> Or maybe there's a better way to recommend? > > What do you mean by the isp_device? Allow me to correct my typo: I meant spi_device (this is a spi device/driver). > > My idea is always use threaded irq and passing flags into request. > Like as: > unsigned long flags = res->flags & IORESOURCE_BITS; > ... > request_threaded_irq(max->irq, serial_m3110_irq, IRQF_ONESHOT | flags, "max3110", max); Oh, maybe we were talking about different things afterall :) The reason this struct plat_max3110 was created is to allow platform code (located under arch/x86/platform/intel-mid/device_libs/) to define the irq edge type. When I saw your comment I though you were referring to struct resource (which has IORESOURCE_IRQ_* flags). But unlike platform_device, spi_device has no struct resource * to replace the need of struct plat_max3110. OTOH your suggestion can replace this piece of code: @@ -68,6 +69,7 @@ struct uart_max3110 { u8 clock; u8 parity, word_7bits; u16 irq; + u16 irq_edge_triggered; unsigned long uart_flags; I'll check again the patch and possibly make the changes. Thanks, David Cohen