Re: [PATCH] serial/arc-uart: Add new driver

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Friday 26 October 2012 12:06 AM, Greg KH wrote:
> On Thu, Oct 25, 2012 at 12:00:08PM +0530, Vineet.Gupta1@xxxxxxxxxxxx wrote:
>> From: Vineet Gupta <vgupta@xxxxxxxxxxxx>
>>
>> Driver for non-standard on-chip UART, instantiated in the ARC (Synopsys)
>> FPGA Boards such as ARCAngel4/ML50x
>>
>> Signed-off-by: Vineet Gupta <vgupta@xxxxxxxxxxxx>
>> ---
>>  drivers/tty/serial/Kconfig       |   25 ++
>>  drivers/tty/serial/Makefile      |    1 +
>>  drivers/tty/serial/arc_uart.c    |  747 ++++++++++++++++++++++++++++++++++++++
>>  include/uapi/linux/serial_core.h |    2 +
>>  4 files changed, 775 insertions(+), 0 deletions(-)
>>  create mode 100644 drivers/tty/serial/arc_uart.c
>>
>> diff --git a/drivers/tty/serial/Kconfig b/drivers/tty/serial/Kconfig
>> index 2a53be5..efee7fe 100644
>> --- a/drivers/tty/serial/Kconfig
>> +++ b/drivers/tty/serial/Kconfig
>> @@ -1423,4 +1423,29 @@ config SERIAL_EFM32_UART_CONSOLE
>>  	depends on SERIAL_EFM32_UART=y
>>  	select SERIAL_CORE_CONSOLE
>>  
>> +config SERIAL_ARC
>> +	bool "ARC UART driver support"
>> +	select SERIAL_CORE
>> +	default y
>> +	help
>> +	  Driver for on-chip UART for ARC(Synopsys) for the legacy
>> +	  FPGA Boards (ML50x/ARCAngel4)
> Unless you will break a user's box, NEVER define a default value for a
> new configuration option as y.

OK !

> And why can't I select this driver as a module?

Because it's missing the equivalent of following (plus some more changes)
-       bool "ARC UART driver support"
+      tristate "ARC UART driver support"

ARC platform (where this driver originates from) always had system
console on UART - thus we never had the need for making it a loadable
module. But I guess as a matter of principle it nevertheless needs to
work - fixed in the next revision !

>> +
>> +config SERIAL_ARC_CONSOLE
>> +	bool
>> +	select SERIAL_CORE_CONSOLE
>> +	depends on SERIAL_ARC=y
>> +	default y
>> +	help
>> +	  Enable system Console on ARC UART
>> +
>> +config SERIAL_ARC_NR_PORTS
>> +	int 'Number of ports'
>> +	range 1 3
>> +	default 1
>> +	depends on SERIAL_ARC
>> +	help
>> +	  Set this to the number of serial ports you want the driver
>> +	  to support.
>> +
>>  endmenu
>> diff --git a/drivers/tty/serial/Makefile b/drivers/tty/serial/Makefile
>> index 4f694da..df1b998 100644
>> --- a/drivers/tty/serial/Makefile
>> +++ b/drivers/tty/serial/Makefile
>> @@ -82,3 +82,4 @@ obj-$(CONFIG_SERIAL_XILINX_PS_UART) += xilinx_uartps.o
>>  obj-$(CONFIG_SERIAL_SIRFSOC) += sirfsoc_uart.o
>>  obj-$(CONFIG_SERIAL_AR933X)   += ar933x_uart.o
>>  obj-$(CONFIG_SERIAL_EFM32_UART) += efm32-uart.o
>> +obj-$(CONFIG_SERIAL_ARC)	+= arc_uart.o
>> diff --git a/drivers/tty/serial/arc_uart.c b/drivers/tty/serial/arc_uart.c
>> new file mode 100644
>> index 0000000..9215bf4
>> --- /dev/null
>> +++ b/drivers/tty/serial/arc_uart.c
>> @@ -0,0 +1,747 @@
>> +/*
>> + * ARC On-Chip(fpga) UART Driver
>> + *
>> + * Copyright (C) 2010-2012 Synopsys, Inc. (www.synopsys.com)
>> + *
>> + * This program is free software; you can redistribute it and/or modify
>> + * it under the terms of the GNU General Public License version 2 as
>> + * published by the Free Software Foundation.
>> + *
>> + * vineetg: July 10th 2012
>> + *  -Decoupled the driver from arch/arc
>> + *    +Using platform_get_resource() for irq/membase (thx to bfin_uart.c)
>> + *    +Using early_platform_xxx() for early console (thx to mach-shmobile/xxx)
>> + *
>> + * Vineetg: Aug 21st 2010
>> + *  -Is uart_tx_stopped() not done in tty write path as it has already been
>> + *   taken care of, in serial core
>> + *
>> + * Vineetg: Aug 18th 2010
>> + *  -New Serial Core based ARC UART driver
>> + *  -Derived largely from blackfin driver albiet with some major tweaks
>> + *
>> + * TODO:
>> + *  -check if sysreq works
>> + */
>> +
>> +#if defined(CONFIG_SERIAL_ARC_CONSOLE) && defined(CONFIG_MAGIC_SYSRQ)
>> +#define SUPPORT_SYSRQ
>> +#endif
> Are you sure this works?  Don't you usually need to include some .h
> files before you check these config values?

We've been using the exact same driver for years - literally.

AFAIK, all the CONFIG_xxx items come in from generated autoconf.h which
is included implicitly by build system via cmd line based -include
kconfig.h, thus any explicit header is not needed for them. Also
SUPPORT_SYSRQ needs to be defined BEFORE including any header because
that is the way serial_core.h build can be influenced in a non-ambiguous
way.

>> +
>> +#include <linux/module.h>
>> +#include <linux/serial.h>
>> +#include <linux/console.h>
>> +#include <linux/sysrq.h>
>> +#include <linux/platform_device.h>
>> +#include <linux/tty.h>
>> +#include <linux/tty_flip.h>
>> +#include <linux/serial_core.h>
>> +#include <linux/io.h>
>> +
>> +/*************************************
>> + * ARC UART Hardware Specs
>> + ************************************/
>> +#define ARC_UART_TX_FIFO_SIZE  1
>> +
>> +/*
>> + * UART Register set (this is not a Standards Compliant IP)
>> + * Also each reg is Word aligned, but only 8 bits wide
>> + */
>> +#define R_ID0	0
>> +#define R_ID1	1
>> +#define R_ID2	2
>> +#define R_ID3	3
>> +#define R_DATA	4
>> +#define R_STS	5
>> +#define R_BAUDL	6
>> +#define R_BAUDH	7
>> +
>> +/* Bits for UART Status Reg (R/W) */
>> +#define RXIENB  0x04	/* Receive Interrupt Enable */
>> +#define TXIENB  0x40	/* Transmit Interrupt Enable */
>> +
>> +#define RXEMPTY 0x20	/* Receive FIFO Empty: No char receivede */
>> +#define TXEMPTY 0x80	/* Transmit FIFO Empty, thus char can be written into */
>> +
>> +#define RXFULL  0x08	/* Receive FIFO full */
>> +#define RXFULL1 0x10	/* Receive FIFO has space for 1 char (tot space=4) */
>> +
>> +#define RXFERR  0x01	/* Frame Error: Stop Bit not detected */
>> +#define RXOERR  0x02	/* OverFlow Err: Char recv but RXFULL still set */
>> +
>> +/* Uart bit fiddling helpers: lowest level */
>> +#define RBASE(uart, reg)      ((unsigned int *)uart->port.membase + reg)
>> +#define UART_REG_SET(u, r, v) writeb((v), RBASE(u, r))
>> +#define UART_REG_GET(u, r)    readb(RBASE(u, r))
> What happens when you run sparse on this driver?

(1) The cast was indeed causing warning - that's now fixed, with an
equivalent of following:

-#define R_ID1  1
-#define R_ID2  2
-#define R_ID3  3
-#define R_DATA 4
-#define R_STS  5
-#define R_BAUDL        6
-#define R_BAUDH        7
+#define R_ID1  4
+#define R_ID2  8
+#define R_ID3  12
+#define R_DATA 16
+#define R_STS  20
+#define R_BAUDL        24
+#define R_BAUDH        28

-#define RBASE(uart, reg)      ((unsigned int *)uart->port.membase + reg)
+#define RBASE(uart, reg)     (uart->port.membase + reg)

(2) Other two seem to be false warnings for imbalance of
spin_lock_irqsave/restore, which otherwise seem OK to me!


>
> thanks,
>
> greg k-h

--
To unsubscribe from this list: send the line "unsubscribe linux-serial" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html


[Index of Archives]     [Kernel Newbies]     [Security]     [Netfilter]     [Bugtraq]     [Linux PPP]     [Linux FS]     [Yosemite News]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Samba]     [Video 4 Linux]     [Linmodem]     [Device Mapper]     [Linux Kernel for ARM]

  Powered by Linux