Received: by 2002:a25:4158:0:0:0:0:0 with SMTP id o85csp378397yba; Fri, 12 Apr 2019 05:33:53 -0700 (PDT) X-Google-Smtp-Source: APXvYqwYCKMmIKAEpr2ea1ZLnF1IpJZ2v0ITNUEXPXUPQfe3hSisZHyW1xuayqS3pMgR+uHIEVCZ X-Received: by 2002:a62:424f:: with SMTP id p76mr56535287pfa.141.1555072433809; Fri, 12 Apr 2019 05:33:53 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1555072433; cv=none; d=google.com; s=arc-20160816; b=p7TSnESKeinB4x+sqX/CLCjCnwB3vuinCVHVz95e7O43sYf058win18cnuSg0ZbdaY E0GBqs8aZZumj5jmTL7S7DL6RyLSx+4gju8JRsiePJIF872wu85a56iUKFKe+ss/TOop Z5zcmIiXVFh5H07AUYYkQjF8pALGj4DAteHOQnX5gKAgMMzsaW+45q9a9bzkr9tmCxVY Meb9otdQz8GUjFAI0fEGLcNhJOf8TojgSSm+MFGQZ+aW5tBeBFG4NQDZc1TRaoXeKXzM 9wiA+Sf/MkPdBVQ8fuU25dMErUaKJd26lkh+05kK6cjC6IIjmPgoj+b1DthZ4n8ZUfA6 JGrg== 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 :content-language:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject; bh=C0EI2ktW8Vv65rUKC7MSapsGgZ71/Y4Q5DvnGL7IedA=; b=t9ZBOems7rTHclZKBHSP+X/sp5SrkURf4L8WYETcJL2190mOLfEAogKL/AzCEHj/vc PCCMsAp1MOBp3mfYdTrIEHaoPB4vSnzmdLC5s5e4KrXuuF81f+ZGYgcCiMyI9jR06bpG VyH5voc29jdzzJglLi7MJzkD0yoTNPB9hQZg0NYofe6T1W/hXTLJu14C4C5Ag3xcZHVw /FsiNNO3v/er9i4qgNq1ZyUUdmnHyqsJl3aEjAOoPu2ch4Icm7wNpyNzZgX6qedGYhyX fgE/6Zt+CDt+TdFpqPtDf2TDxK3mxas62u93q3cRIKFcXfd+b/+Z15QCjI2v495feD3p RxhQ== ARC-Authentication-Results: i=1; mx.google.com; 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 i63si36914759pge.151.2019.04.12.05.33.35; Fri, 12 Apr 2019 05:33:53 -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; 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 S1726843AbfDLMcU convert rfc822-to-8bit (ORCPT + 99 others); Fri, 12 Apr 2019 08:32:20 -0400 Received: from vegas.theobroma-systems.com ([144.76.126.164]:41509 "EHLO mail.theobroma-systems.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726327AbfDLMcU (ORCPT ); Fri, 12 Apr 2019 08:32:20 -0400 X-Greylist: delayed 1156 seconds by postgrey-1.27 at vger.kernel.org; Fri, 12 Apr 2019 08:32:18 EDT Received: from ip092042140082.rev.nessus.at ([92.42.140.82]:49335 helo=cmuellner.local) by mail.theobroma-systems.com with esmtpsa (TLS1.2:RSA_AES_128_CBC_SHA1:128) (Exim 4.80) (envelope-from ) id 1hEvLl-0003bM-Ex; Fri, 12 Apr 2019 14:32:09 +0200 Subject: Re: [PATCH v1 1/6] clk: rockchip: Add supprot to limit input rate for fractional divider To: =?UTF-8?Q?Heiko_St=c3=bcbner?= Cc: Elaine Zhang , mturquette@baylibre.com, sboyd@kernel.org, linux-clk@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-rockchip@lists.infradead.org, linux-kernel@vger.kernel.org, xxx@rock-chips.com, xf@rock-chips.com, huangtao@rock-chips.com, Finley Xiao References: <1554284549-24916-1-git-send-email-zhangqing@rock-chips.com> <8338364.h4JqnAax9Z@diego> <818a6e0a-d99b-7350-9c4a-9e0a0d12122a@theobroma-systems.com> <3395739.hcHkC3K37q@diego> From: =?UTF-8?Q?Christoph_M=c3=bcllner?= Message-ID: <0e47770b-fa20-74f9-8548-c07aebdcaa53@theobroma-systems.com> Date: Fri, 12 Apr 2019 14:32:08 +0200 User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10.13; rv:60.0) Gecko/20100101 Thunderbird/60.6.1 MIME-Version: 1.0 In-Reply-To: <3395739.hcHkC3K37q@diego> Content-Type: text/plain; charset=utf-8 Content-Language: en-US Content-Transfer-Encoding: 8BIT Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 12.04.19 14:21, Heiko Stübner wrote: > Hi Christoph, > > Am Freitag, 12. April 2019, 14:12:52 CEST schrieb Christoph Müllner: >> On 12.04.19 13:52, Heiko Stübner wrote: >>> Am Mittwoch, 3. April 2019, 11:42:24 CEST schrieb Elaine Zhang: >>>> From: Finley Xiao >>>> >>>> From Rockchips fractional divider usage, some clocks can be generated >>>> by fractional divider, but the input clock frequency of fractional >>>> divider should be less than a specified value. >>>> >>>> Signed-off-by: Finley Xiao >>>> Signed-off-by: Elaine Zhang >>> >>> can you tell me where these maximum input values come from? >>> >>> I talked to Christoph from Theobroma (Cc'ed) last week and he mentioned >>> that they're using the fractional divider with a higher input frequency >>> to create a very specific frequency [some details are gone from my memory >>> though] they can't get otherwise. >>> >>> So I really don't want to break their working setup by introducing barriers >>> that are not strictly necessary. >>> >>> @Christoph: can you describe the bits from your fractional setup that >>> I've forgotten please? >> >> We need to set the I2S0 clock to 24.56 MHz. >> >> When restricting the input frequency to a maximum of 600 Mhz, >> we could use the integer divider to get 400 Mhz (dividing by 2). >> However, with the 400 Mhz as input to the frac divider, >> we run into the problem, that the maximum possible output frequency >> is 20 MHz (there is another restriction which states that the >> fraction input : output frequency must be >= 20). > > just for clarification, what is the current input frequency you > already use sucessfully? Our working setup uses the integer divider to reduce to 400 MHz and uses the frac divider to get something near 24.56 MHz. I have to admit I have never measured what's on the clock line. >>> >>>> diff --git a/drivers/clk/rockchip/clk-px30.c b/drivers/clk/rockchip/clk-px30.c >>>> index 601a77f1af78..ccabce35580b 100644 >>>> --- a/drivers/clk/rockchip/clk-px30.c >>>> +++ b/drivers/clk/rockchip/clk-px30.c >>>> @@ -21,6 +21,7 @@ >>>> #include "clk.h" >>>> >>>> #define PX30_GRF_SOC_STATUS0 0x480 >>>> +#define PX30_FRAC_MAX_PRATE 600000000 >>> >>> >>>> diff --git a/drivers/clk/rockchip/clk-rk3368.c b/drivers/clk/rockchip/clk-rk3368.c >>>> index 7c4d242f19c1..67c2da5e7d61 100644 >>>> --- a/drivers/clk/rockchip/clk-rk3368.c >>>> +++ b/drivers/clk/rockchip/clk-rk3368.c >>>> @@ -20,6 +20,9 @@ >>>> #include "clk.h" >>>> >>>> #define RK3368_GRF_SOC_STATUS0 0x480 >>>> +#define RK3368_I2S_FRAC_MAX_PRATE 600000000 >>>> +#define RK3368_UART_FRAC_MAX_PRATE 600000000 >>>> +#define RK3368_SPDIF_FRAC_MAX_PRATE 600000000 >>> >>>> diff --git a/drivers/clk/rockchip/clk-rk3399.c b/drivers/clk/rockchip/clk-rk3399.c >>>> index 5a628148f3f0..1d81382bd3e0 100644 >>>> --- a/drivers/clk/rockchip/clk-rk3399.c >>>> +++ b/drivers/clk/rockchip/clk-rk3399.c >>>> @@ -21,6 +21,12 @@ >>>> #include >>>> #include "clk.h" >>>> >>>> +#define RK3399_I2S_FRAC_MAX_PRATE 600000000 >>>> +#define RK3399_UART_FRAC_MAX_PRATE 600000000 >>>> +#define RK3399_SPDIF_FRAC_MAX_PRATE 600000000 >>>> +#define RK3399_VOP_FRAC_MAX_PRATE 600000000 >>>> +#define RK3399_WIFI_FRAC_MAX_PRATE 600000000 >>>> + >>> >>> >>> >> > > > >