Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S932693AbaBFNvA (ORCPT ); Thu, 6 Feb 2014 08:51:00 -0500 Received: from mailout4.w1.samsung.com ([210.118.77.14]:58644 "EHLO mailout4.w1.samsung.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S932669AbaBFNu5 (ORCPT ); Thu, 6 Feb 2014 08:50:57 -0500 X-AuditID: cbfec7f5-b7fc96d000004885-44-52f3933ef9d9 Message-id: <52F3933B.9090202@samsung.com> Date: Thu, 06 Feb 2014 14:50:51 +0100 From: Tomasz Figa User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:24.0) Gecko/20100101 Thunderbird/24.1.1 MIME-version: 1.0 To: Naveen Krishna Chatradhi , linux-samsung-soc@vger.kernel.org, linux-i2c@vger.kernel.org Cc: linux-arm-kernel@lists.infradead.org, "devicetree@vger.kernel.org" , naveenkrishna.ch@gmail.com, kgene.kim@samsung.com, grant.likely@secretlab.ca, Wolfram Sang , linux-kernel@vger.kernel.org, taeggyun.ko@samsung.com, balbi@ti.com, cpgs@samsung.com Subject: Re: [PATCH 1/2 v3] i2c: exynos5: add support for HSI2C on Exynos5260 SoC References: <1385100851-32254-1-git-send-email-ch.naveen@samsung.com> <1391688408-8077-1-git-send-email-ch.naveen@samsung.com> <52F38EA4.10805@samsung.com> In-reply-to: <52F38EA4.10805@samsung.com> Content-type: text/plain; charset=ISO-8859-1; format=flowed Content-transfer-encoding: 7bit X-Brightmail-Tracker: H4sIAAAAAAAAA+NgFnrMLMWRmVeSWpSXmKPExsVy+t/xa7p2kz8HGby4Jmtx8H69xd3nhxkt Xh7StJh/5ByrxaszG9ksehdcZbPY9Pgaq0XH3y+MFpd3zWGzmHF+H5PFom3/mS2e/AdyV56Y xezA67Fz1l12j81L6j36tqxi9Pj5Usfj5KknLB7Hb2xn8vi8SS6APYrLJiU1J7MstUjfLoEr Y/sF+YJlihXbpn9nbWB8KdnFyMkhIWAi8WzFI0YIW0ziwr31bF2MXBxCAksZJT4c+cYO4Xxm lNjYPpUNpIpXQEviW+MPMJtFQFVi0+JVLCA2m4CaxOeGR2BxUYEIib/z1jNC1AtK/Jh8D6xG RKBEYseTC4wgQ5kFNjFJdJ97zwySEBYIlpiw6SkLxLb5jBLntx8C6+AU0JTobn0JNolZwFpi 5aRtULa8xOY1b5knMArMQrJkFpKyWUjKFjAyr2IUTS1NLihOSs810itOzC0uzUvXS87P3cQI iZivOxiXHrM6xCjAwajEw7th/acgIdbEsuLK3EOMEhzMSiK8qU2fg4R4UxIrq1KL8uOLSnNS iw8xMnFwSjUwzr4r3BWW/jm3UfCPWZlLrYlMwL+/OuLNU18t3jD1ZubNK/s3VnKftj2hxpV/ 9ZvY6jkpraJvXAv69gbqZ/tfbf45Z2mCz1l/Zv2fFpNnTV25JcXX/ErdqZUmbBNPTEquFav6 td/wzY+TWdNFmVj0f7gVqHB08gi//NF4o+/quc+WOae22y57qMRSnJFoqMVcVJwIAMr4jtt2 AgAA Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Also, please use correct addresses of DT ML and Wolfram's e-mail (fixed in this message). Best regards, Tomasz On 06.02.2014 14:31, Tomasz Figa wrote: > Hi Naveen, > > On 06.02.2014 13:06, Naveen Krishna Chatradhi wrote: >> This patch implements a variant struct to handle the differences >> (like fifo_depths) in the HSI2C modules across SoCs. >> >> Adds a new compatible to support HSI2C module on Exynos5260. >> Also resets the module as an init sequence (Needed by Exynos5260). >> >> Signed-off-by: Naveen Krishna Chatradhi >> --- >> Changes since v2: >> 1. Used variant struct as suggested by Tomasz Figa. >> 2. Change compatible strings from samsung,exynos5-hsi2c to >> samsung,exynos5250-hsi2c based on the first SoC to see the feature. >> 3. Using reset as init sequences. >> 4. Merged the 2 patches into one. >> >> .../devicetree/bindings/i2c/i2c-exynos5.txt | 8 ++- >> drivers/i2c/busses/i2c-exynos5.c | 64 >> ++++++++++++++++---- >> 2 files changed, 58 insertions(+), 14 deletions(-) >> >> diff --git a/Documentation/devicetree/bindings/i2c/i2c-exynos5.txt >> b/Documentation/devicetree/bindings/i2c/i2c-exynos5.txt >> index 056732c..5bc4998 100644 >> --- a/Documentation/devicetree/bindings/i2c/i2c-exynos5.txt >> +++ b/Documentation/devicetree/bindings/i2c/i2c-exynos5.txt >> @@ -5,7 +5,11 @@ at various speeds ranging from 100khz to 3.4Mhz. >> >> Required properties: >> - compatible: value should be. >> - -> "samsung,exynos5-hsi2c", for i2c compatible with exynos5 hsi2c. > > Device tree bindings need to be backwards compatible, so you need to > keep this compatible string supported, just marked as (DEPRECATED). > > Driver-wise, it will use the same driver data / variant struct as > "samsung,exynos5250-hsi2c", just one more entry in OF match table is > needed. > >> + -> "samsung,exynos5250-hsi2c", for i2c compatible with HSI2C >> available >> + on Exynos5250 and Exynos5420 SoCs. >> + -> "samsung,exynos5260-hsi2c", for i2c compatible with HSI2C >> available >> + on Exynos5260 SoCs. >> + >> - reg: physical base address of the controller and length of >> memory mapped >> region. >> - interrupts: interrupt number to the cpu. >> @@ -26,7 +30,7 @@ Optional properties: >> Example: >> >> hsi2c@12ca0000 { >> - compatible = "samsung,exynos5-hsi2c"; >> + compatible = "samsung,exynos5250-hsi2c"; >> reg = <0x12ca0000 0x100>; >> interrupts = <56>; >> clock-frequency = <100000>; > > [snip] > >> @@ -483,6 +514,7 @@ static void exynos5_i2c_message_start(struct >> exynos5_i2c *i2c, int stop) >> u32 i2c_auto_conf = 0; >> u32 fifo_ctl; >> unsigned long flags; >> + unsigned short trig_lvl; >> >> i2c_ctl = readl(i2c->regs + HSI2C_CTL); >> i2c_ctl &= ~(HSI2C_TXCHON | HSI2C_RXCHON); >> @@ -493,13 +525,19 @@ static void exynos5_i2c_message_start(struct >> exynos5_i2c *i2c, int stop) >> >> i2c_auto_conf = HSI2C_READ_WRITE; >> >> - fifo_ctl |= HSI2C_RXFIFO_TRIGGER_LEVEL(HSI2C_DEF_TXFIFO_LVL); >> + trig_lvl = (i2c->msg->len > i2c->variant->fifo_depth) ? >> + (i2c->variant->fifo_depth * 3/4) : i2c->msg->len; >> + fifo_ctl |= HSI2C_RXFIFO_TRIGGER_LEVEL(trig_lvl); >> + > > This is a rather serious semantic change, that doesn't look to belong to > this patch. If this is needed, it should be done in a separate patch. > >> int_en |= (HSI2C_INT_RX_ALMOSTFULL_EN | >> HSI2C_INT_TRAILING_EN); >> } else { >> i2c_ctl |= HSI2C_TXCHON; >> >> - fifo_ctl |= HSI2C_TXFIFO_TRIGGER_LEVEL(HSI2C_DEF_RXFIFO_LVL); >> + trig_lvl = (i2c->msg->len > i2c->variant->fifo_depth) ? >> + (i2c->variant->fifo_depth * 1/4) : i2c->msg->len; >> + fifo_ctl |= HSI2C_TXFIFO_TRIGGER_LEVEL(trig_lvl); >> + > > Ditto. > > Best regards, > Tomasz > -- > To unsubscribe from this list: send the line "unsubscribe > linux-samsung-soc" in > the body of a message to majordomo@vger.kernel.org > More majordomo info at http://vger.kernel.org/majordomo-info.html > -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/