Received: by 2002:a25:ad19:0:0:0:0:0 with SMTP id y25csp1699716ybi; Wed, 17 Jul 2019 20:21:45 -0700 (PDT) X-Google-Smtp-Source: APXvYqxpGIQZN3aAofAfVoyAtm55aN1mb6EzsN9/OBVzxbHEZV94kb8yytfnQlaCyP41Y1cG8gGL X-Received: by 2002:a17:902:aa5:: with SMTP id 34mr49063282plp.166.1563420105471; Wed, 17 Jul 2019 20:21:45 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1563420105; cv=none; d=google.com; s=arc-20160816; b=jtlUuKtPq8dUeGJS8ELXCKHsuJDZ97MW3g83rxca0OISiwPcCVrp7VJ2SKUkPfJ6lX ppcvjyjXZ9gAld5wmLbo6xAnQl3abHI2rFequ9vTwZeR+ITcb7s3MEGB+3gpN8htD2sE 3KsQOYtdwsRcEQeSTLEJbm24DkAEpfjYLknTT5vyOozPtZwa7DK6UEHI96VGmYYHgRSH VzRoJza+OX0YVbviqdQPgV+S+xIKNZ7Az/nyHABUKoAJV+Q81+ebt5UKjOKRUNhxlRQj yXgXgKnxve9H3sWf0SdUxPYwqCK40JxUWO+E35yGsUv0QJP1Kde29PB4udtFjKQBtVeo 1opA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=YOwK6cRVghkerU+Y/nZHP/r5ep8sa2T/O2Vtra4ZTQU=; b=nE4+IJsebi3Oj18sdCv60NOVbzgCuOuxi/ayVHTD14KtrPRDGQU/xnLu0PrnHkI0dz AQRth2FWkIZb2mDLDar1Uw7xfMdwBwYjYtMgRWk7e04CwweVDEEWLqPztZqtn5iSshoI 9KEG1w3O0Sb0Wcm6hww1e4VvJSSdUPeied9Sur/A7Q/GnJ42SD8YlmUVQK9ThM7AKhkA +W5/LZshylUSEUW516X3BhkoZLjDE0UMw+skTbSMmMRWxMXYRh2SAy2GXhry3wRG2X/c P7SgG6TqH0vXM98Yf3tZAT86+jIDa9ZkHVjqbI73vfY8nr2EkXMhf11by+cPrae9/SRK HNCg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b="LAzhQ/qb"; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id m13si23507296pgv.398.2019.07.17.20.21.29; Wed, 17 Jul 2019 20:21:45 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b="LAzhQ/qb"; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2403928AbfGRDMN (ORCPT + 99 others); Wed, 17 Jul 2019 23:12:13 -0400 Received: from mail.kernel.org ([198.145.29.99]:45804 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2390668AbfGRDLx (ORCPT ); Wed, 17 Jul 2019 23:11:53 -0400 Received: from localhost (115.42.148.210.bf.2iij.net [210.148.42.115]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id C02392053B; Thu, 18 Jul 2019 03:11:51 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1563419512; bh=F+W09GMuNB1aZPvP0x5HIpzQ8p1FmOTAMl8Y7lSSoX4=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=LAzhQ/qbHpGXoZBUz4hm7TxfVCtCEOd6TgqP2AQPKQWFYIcz/G6j8Fcu2kJT4xdIa eGtXuyTzujPI33hagzeXUTqH2B/IQNzi3q2uOp6xwgVtu8oC/0bWZ38Jh1mqeNSOiA zJ2xg/d75zvkbbktb+y4MOyj4PtDVsd3uctM527Q= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Sean Nyekjaer , Marc Kleine-Budde , Sasha Levin Subject: [PATCH 4.9 11/54] can: mcp251x: add support for mcp25625 Date: Thu, 18 Jul 2019 12:01:41 +0900 Message-Id: <20190718030050.065226424@linuxfoundation.org> X-Mailer: git-send-email 2.22.0 In-Reply-To: <20190718030048.392549994@linuxfoundation.org> References: <20190718030048.392549994@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org [ Upstream commit 35b7fa4d07c43ad79b88e6462119e7140eae955c ] Fully compatible with mcp2515, the mcp25625 have integrated transceiver. This patch adds support for the mcp25625 to the existing mcp251x driver. Signed-off-by: Sean Nyekjaer Signed-off-by: Marc Kleine-Budde Signed-off-by: Sasha Levin --- drivers/net/can/spi/Kconfig | 5 +++-- drivers/net/can/spi/mcp251x.c | 25 ++++++++++++++++--------- 2 files changed, 19 insertions(+), 11 deletions(-) diff --git a/drivers/net/can/spi/Kconfig b/drivers/net/can/spi/Kconfig index 148cae5871a6..249d2db7d600 100644 --- a/drivers/net/can/spi/Kconfig +++ b/drivers/net/can/spi/Kconfig @@ -2,9 +2,10 @@ menu "CAN SPI interfaces" depends on SPI config CAN_MCP251X - tristate "Microchip MCP251x SPI CAN controllers" + tristate "Microchip MCP251x and MCP25625 SPI CAN controllers" depends on HAS_DMA ---help--- - Driver for the Microchip MCP251x SPI CAN controllers. + Driver for the Microchip MCP251x and MCP25625 SPI CAN + controllers. endmenu diff --git a/drivers/net/can/spi/mcp251x.c b/drivers/net/can/spi/mcp251x.c index f3f05fea8e1f..d8c448beab24 100644 --- a/drivers/net/can/spi/mcp251x.c +++ b/drivers/net/can/spi/mcp251x.c @@ -1,5 +1,5 @@ /* - * CAN bus driver for Microchip 251x CAN Controller with SPI Interface + * CAN bus driver for Microchip 251x/25625 CAN Controller with SPI Interface * * MCP2510 support and bug fixes by Christian Pellegrin * @@ -41,7 +41,7 @@ * static struct spi_board_info spi_board_info[] = { * { * .modalias = "mcp2510", - * // or "mcp2515" depending on your controller + * // "mcp2515" or "mcp25625" depending on your controller * .platform_data = &mcp251x_info, * .irq = IRQ_EINT13, * .max_speed_hz = 2*1000*1000, @@ -238,6 +238,7 @@ static const struct can_bittiming_const mcp251x_bittiming_const = { enum mcp251x_model { CAN_MCP251X_MCP2510 = 0x2510, CAN_MCP251X_MCP2515 = 0x2515, + CAN_MCP251X_MCP25625 = 0x25625, }; struct mcp251x_priv { @@ -280,7 +281,6 @@ static inline int mcp251x_is_##_model(struct spi_device *spi) \ } MCP251X_IS(2510); -MCP251X_IS(2515); static void mcp251x_clean(struct net_device *net) { @@ -640,7 +640,7 @@ static int mcp251x_hw_reset(struct spi_device *spi) /* Wait for oscillator startup timer after reset */ mdelay(MCP251X_OST_DELAY_MS); - + reg = mcp251x_read_reg(spi, CANSTAT); if ((reg & CANCTRL_REQOP_MASK) != CANCTRL_REQOP_CONF) return -ENODEV; @@ -821,9 +821,8 @@ static irqreturn_t mcp251x_can_ist(int irq, void *dev_id) /* receive buffer 0 */ if (intf & CANINTF_RX0IF) { mcp251x_hw_rx(spi, 0); - /* - * Free one buffer ASAP - * (The MCP2515 does this automatically.) + /* Free one buffer ASAP + * (The MCP2515/25625 does this automatically.) */ if (mcp251x_is_2510(spi)) mcp251x_write_bits(spi, CANINTF, CANINTF_RX0IF, 0x00); @@ -832,7 +831,7 @@ static irqreturn_t mcp251x_can_ist(int irq, void *dev_id) /* receive buffer 1 */ if (intf & CANINTF_RX1IF) { mcp251x_hw_rx(spi, 1); - /* the MCP2515 does this automatically */ + /* The MCP2515/25625 does this automatically. */ if (mcp251x_is_2510(spi)) clear_intf |= CANINTF_RX1IF; } @@ -1007,6 +1006,10 @@ static const struct of_device_id mcp251x_of_match[] = { .compatible = "microchip,mcp2515", .data = (void *)CAN_MCP251X_MCP2515, }, + { + .compatible = "microchip,mcp25625", + .data = (void *)CAN_MCP251X_MCP25625, + }, { } }; MODULE_DEVICE_TABLE(of, mcp251x_of_match); @@ -1020,6 +1023,10 @@ static const struct spi_device_id mcp251x_id_table[] = { .name = "mcp2515", .driver_data = (kernel_ulong_t)CAN_MCP251X_MCP2515, }, + { + .name = "mcp25625", + .driver_data = (kernel_ulong_t)CAN_MCP251X_MCP25625, + }, { } }; MODULE_DEVICE_TABLE(spi, mcp251x_id_table); @@ -1260,5 +1267,5 @@ module_spi_driver(mcp251x_can_driver); MODULE_AUTHOR("Chris Elston , " "Christian Pellegrin "); -MODULE_DESCRIPTION("Microchip 251x CAN driver"); +MODULE_DESCRIPTION("Microchip 251x/25625 CAN driver"); MODULE_LICENSE("GPL v2"); -- 2.20.1