Received: by 2002:a05:6358:d09b:b0:dc:cd0c:909e with SMTP id jc27csp2005354rwb; Mon, 7 Nov 2022 08:07:33 -0800 (PST) X-Google-Smtp-Source: AMsMyM6jApspqUVv+cX0g6CAzQpzNic3QsBQky1kVJ/vkhp8NHGqX+9Iqlp454Jds0K6/6UHVjoB X-Received: by 2002:aa7:cb59:0:b0:461:7378:7be0 with SMTP id w25-20020aa7cb59000000b0046173787be0mr51694299edt.60.1667837253411; Mon, 07 Nov 2022 08:07:33 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1667837253; cv=none; d=google.com; s=arc-20160816; b=qnPLPEKKQN/GrIyezcd4UyQ8cdSr5F3DqA8iGHTFzbdia/1Yu8B9Ul4ChC6WEwMlML t9liZyTazl6GAqfdpMlUwdcgVSOLX2YsTznFUyRlWEHYvsJzFTgE7I6/laorzQ662Zzw r6c8/TXdxGYNVOzIL7tt5pL4hRuNLgLdwQCdFUa7OExkkKOgs9nPNArDP4pGk+6DUdRk k5e+xMsonnngaj9V5VarCW+3rcfVroVdjEndGNhE8hCyZmfgMK8P1+tXcpEOmioxOwgy C6LEsrspp+3v9YImXY8Tvst6FahmHUxO8aQ7Pmude/n1w6yZ6skKEm1Wk527JbxDRJda 8Qdg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:in-reply-to:from :references:cc:to:content-language:subject:user-agent:mime-version :date:message-id:dkim-signature; bh=Udhj9HrxY9ilBvsPPCq9UTkZmfJFo7Gwlp6IoZg3bW4=; b=GTnbEAL9ItKgz7XBDcgaBO1icOiS0GjMQzp85WGxPfAr6FBgP/7F5PZV6iPBfe85wC VNjk7sKfXljKndilJlyH4H3lyi8a9F8pNVUDlxgOng6AGg/BcjOOrjaFSHbMIos5ToTy gfXKHgWOwOR4wc4Vatb1BgRGXMSm++JKPXSq3e6fSLGWvZkNlMEZOPu5RY7uy9YpIHik K/D+lOSRTBinpzskvsmHI1E64Ut0k/2pgRCiNq1WnSCtCUSuqkwHcik1yUgBIbDTKEaj Pspt5oSh8mh+drexMxhs0l07QCCTqyMQrd6JZyefaZVptZ4ORRs0Tg/Td/a+4kQqSa53 bWzg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20210112 header.b="EvzeqIX/"; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id e22-20020a17090658d600b007836ec6999dsi4517333ejs.904.2022.11.07.08.07.06; Mon, 07 Nov 2022 08:07:33 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@gmail.com header.s=20210112 header.b="EvzeqIX/"; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S232861AbiKGPkW (ORCPT + 93 others); Mon, 7 Nov 2022 10:40:22 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:43144 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232915AbiKGPkT (ORCPT ); Mon, 7 Nov 2022 10:40:19 -0500 Received: from mail-wr1-x42b.google.com (mail-wr1-x42b.google.com [IPv6:2a00:1450:4864:20::42b]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 253711F9FA for ; Mon, 7 Nov 2022 07:40:18 -0800 (PST) Received: by mail-wr1-x42b.google.com with SMTP id k8so16865240wrh.1 for ; Mon, 07 Nov 2022 07:40:18 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20210112; h=content-transfer-encoding:in-reply-to:from:references:cc:to :content-language:subject:user-agent:mime-version:date:message-id :from:to:cc:subject:date:message-id:reply-to; bh=Udhj9HrxY9ilBvsPPCq9UTkZmfJFo7Gwlp6IoZg3bW4=; b=EvzeqIX/sx4IZ2/5XI+qSlibo1VZgLeniY1tB65x805quPslSH8hatUa9vFkH2PucZ QyGK0w0xnzQUjUz4rIhHFrlMW0Ge8irENi619PxfUKMFu6p+RxDOJMDansnFoY6dIaQd vZxDmr2/ISMHWRW1pEkCYp7wJbfQ7hEQx/j4wjUyoDF3hgUlnukXbO3qvhrrn9a8QMdS rawTOxt7hR2f7JVUzpNwdHZT7QCs8VCv+LwaFs0cOCr7xKvQ85YC0O2ERqzox0is+Hi2 f2cE5dOJgP7+nY13XNO2LCPIqKg83q3eG8gQLktihcTP06+DaToHOO7t4JkkLWz2brcP +uKA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=content-transfer-encoding:in-reply-to:from:references:cc:to :content-language:subject:user-agent:mime-version:date:message-id :x-gm-message-state:from:to:cc:subject:date:message-id:reply-to; bh=Udhj9HrxY9ilBvsPPCq9UTkZmfJFo7Gwlp6IoZg3bW4=; b=RCn+azNbKGThY+NQx7bCDTE5yUU1gURZC/xmqv9Ahm8sSDFBysdwmnvJxEfdl2oJgW 8q+ISNKsUJ/3Y8nyN8t00fw8TqJLyY3WZEodmArdFa7yJheMZV4ku7nkOmg9lnAX7Spd eXwo4jsblDABf9ii5Z/BqdCx/fk71nc25+66sK0Gn2lKDPpKe7MT8C0rPcgxUF5HSWRi exYknq89gHgIRQodt7yE4EDvR4JoujiyJaBXL+Uw5TBHVpC14Y4hwewgsNJEvx3b9TOJ /fVcwjE2Cyfy8dsL20MyYj/h6142nyxl4yL0rOKL5PVa5yv/wRhd+gwQ9pIMQXBd0KSt isYw== X-Gm-Message-State: ACrzQf39iwiONwO8xAEbck/g/J7lEUIOBjyTAqj8q0ZGud1zcu9NIUMn 0/V0hfU/iiMliG/EHaqV7Yeyv0t6dU5pUw== X-Received: by 2002:a5d:6b02:0:b0:236:d484:2d01 with SMTP id v2-20020a5d6b02000000b00236d4842d01mr25350166wrw.623.1667835616456; Mon, 07 Nov 2022 07:40:16 -0800 (PST) Received: from [192.168.2.177] ([207.188.167.132]) by smtp.gmail.com with ESMTPSA id bw14-20020a0560001f8e00b00240dcd4d1cesm3292971wrb.105.2022.11.07.07.40.14 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Mon, 07 Nov 2022 07:40:15 -0800 (PST) Message-ID: <63f09026-5040-2f8e-ce24-e56ede2f3b24@gmail.com> Date: Mon, 7 Nov 2022 16:40:14 +0100 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:102.0) Gecko/20100101 Thunderbird/102.4.1 Subject: Re: [PATCH] mailbox: mtk-cmdq-mailbox: Use platform data directly instead of copying Content-Language: en-US To: AngeloGioacchino Del Regno , jassisinghbrar@gmail.com Cc: linux-kernel@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-mediatek@lists.infradead.org References: <20221102100736.37815-1-angelogioacchino.delregno@collabora.com> From: Matthias Brugger In-Reply-To: <20221102100736.37815-1-angelogioacchino.delregno@collabora.com> Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 7bit X-Spam-Status: No, score=-2.1 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,FREEMAIL_FROM,NICE_REPLY_A, RCVD_IN_DNSWL_NONE,SPF_HELO_NONE,SPF_PASS autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 02/11/2022 11:07, AngeloGioacchino Del Regno wrote: > Copying platform data to struct cmdq serves to no purpose, as that > data is never modified during runtime: it's worth at this point > storing a pointer to gce_plat in gce and. > > Remove all duplicated `struct gce_plat` members from `struct gce` > and reuse the platform data across the driver to save some memory. > > Signed-off-by: AngeloGioacchino Del Regno Reviewed-by: Matthias Brugger > --- > > This commit applies only on top of series [1] > > [1]: https://patchwork.kernel.org/project/linux-mediatek/list/?series=684195 > > drivers/mailbox/mtk-cmdq-mailbox.c | 88 +++++++++++++----------------- > 1 file changed, 39 insertions(+), 49 deletions(-) > > diff --git a/drivers/mailbox/mtk-cmdq-mailbox.c b/drivers/mailbox/mtk-cmdq-mailbox.c > index c5229f377c5e..a460ee26eb11 100644 > --- a/drivers/mailbox/mtk-cmdq-mailbox.c > +++ b/drivers/mailbox/mtk-cmdq-mailbox.c > @@ -75,15 +75,11 @@ struct cmdq { > struct mbox_controller mbox; > void __iomem *base; > int irq; > - u32 thread_nr; > u32 irq_mask; > + const struct gce_plat *pdata; > struct cmdq_thread *thread; > struct clk_bulk_data clocks[CMDQ_GCE_NUM_MAX]; > bool suspended; > - u8 shift_pa; > - bool control_by_sw; > - bool sw_ddr_en; > - u32 gce_num; > }; > > struct gce_plat { > @@ -96,21 +92,21 @@ struct gce_plat { > > static void cmdq_sw_ddr_enable(struct cmdq *cmdq, bool enable) > { > - WARN_ON(clk_bulk_enable(cmdq->gce_num, cmdq->clocks)); > + WARN_ON(clk_bulk_enable(cmdq->pdata->gce_num, cmdq->clocks)); > > if (enable) > writel(GCE_DDR_EN | GCE_CTRL_BY_SW, cmdq->base + GCE_GCTL_VALUE); > else > writel(GCE_CTRL_BY_SW, cmdq->base + GCE_GCTL_VALUE); > > - clk_bulk_disable(cmdq->gce_num, cmdq->clocks); > + clk_bulk_disable(cmdq->pdata->gce_num, cmdq->clocks); > } > > u8 cmdq_get_shift_pa(struct mbox_chan *chan) > { > struct cmdq *cmdq = container_of(chan->mbox, struct cmdq, mbox); > > - return cmdq->shift_pa; > + return cmdq->pdata->shift; > } > EXPORT_SYMBOL(cmdq_get_shift_pa); > > @@ -144,10 +140,10 @@ static void cmdq_init(struct cmdq *cmdq) > int i; > u32 gctl_regval = 0; > > - WARN_ON(clk_bulk_enable(cmdq->gce_num, cmdq->clocks)); > - if (cmdq->control_by_sw) > + WARN_ON(clk_bulk_enable(cmdq->pdata->gce_num, cmdq->clocks)); > + if (cmdq->pdata->control_by_sw) > gctl_regval = GCE_CTRL_BY_SW; > - if (cmdq->sw_ddr_en) > + if (cmdq->pdata->sw_ddr_en) > gctl_regval |= GCE_DDR_EN; > > if (gctl_regval) > @@ -156,7 +152,7 @@ static void cmdq_init(struct cmdq *cmdq) > writel(CMDQ_THR_ACTIVE_SLOT_CYCLES, cmdq->base + CMDQ_THR_SLOT_CYCLES); > for (i = 0; i <= CMDQ_MAX_EVENT; i++) > writel(i, cmdq->base + CMDQ_SYNC_TOKEN_UPDATE); > - clk_bulk_disable(cmdq->gce_num, cmdq->clocks); > + clk_bulk_disable(cmdq->pdata->gce_num, cmdq->clocks); > } > > static int cmdq_thread_reset(struct cmdq *cmdq, struct cmdq_thread *thread) > @@ -201,7 +197,7 @@ static void cmdq_task_insert_into_thread(struct cmdq_task *task) > prev_task->pkt->cmd_buf_size, DMA_TO_DEVICE); > prev_task_base[CMDQ_NUM_CMD(prev_task->pkt) - 1] = > (u64)CMDQ_JUMP_BY_PA << 32 | > - (task->pa_base >> task->cmdq->shift_pa); > + (task->pa_base >> task->cmdq->pdata->shift); > dma_sync_single_for_device(dev, prev_task->pa_base, > prev_task->pkt->cmd_buf_size, DMA_TO_DEVICE); > > @@ -235,7 +231,7 @@ static void cmdq_task_handle_error(struct cmdq_task *task) > next_task = list_first_entry_or_null(&thread->task_busy_list, > struct cmdq_task, list_entry); > if (next_task) > - writel(next_task->pa_base >> cmdq->shift_pa, > + writel(next_task->pa_base >> cmdq->pdata->shift, > thread->base + CMDQ_THR_CURR_ADDR); > cmdq_thread_resume(thread); > } > @@ -266,7 +262,7 @@ static void cmdq_thread_irq_handler(struct cmdq *cmdq, > else > return; > > - curr_pa = readl(thread->base + CMDQ_THR_CURR_ADDR) << cmdq->shift_pa; > + curr_pa = readl(thread->base + CMDQ_THR_CURR_ADDR) << cmdq->pdata->shift; > > list_for_each_entry_safe(task, tmp, &thread->task_busy_list, > list_entry) { > @@ -289,7 +285,7 @@ static void cmdq_thread_irq_handler(struct cmdq *cmdq, > > if (list_empty(&thread->task_busy_list)) { > cmdq_thread_disable(cmdq, thread); > - clk_bulk_disable(cmdq->gce_num, cmdq->clocks); > + clk_bulk_disable(cmdq->pdata->gce_num, cmdq->clocks); > } > } > > @@ -303,7 +299,7 @@ static irqreturn_t cmdq_irq_handler(int irq, void *dev) > if (!(irq_status ^ cmdq->irq_mask)) > return IRQ_NONE; > > - for_each_clear_bit(bit, &irq_status, cmdq->thread_nr) { > + for_each_clear_bit(bit, &irq_status, cmdq->pdata->thread_nr) { > struct cmdq_thread *thread = &cmdq->thread[bit]; > > spin_lock_irqsave(&thread->chan->lock, flags); > @@ -323,7 +319,7 @@ static int cmdq_suspend(struct device *dev) > > cmdq->suspended = true; > > - for (i = 0; i < cmdq->thread_nr; i++) { > + for (i = 0; i < cmdq->pdata->thread_nr; i++) { > thread = &cmdq->thread[i]; > if (!list_empty(&thread->task_busy_list)) { > task_running = true; > @@ -334,10 +330,10 @@ static int cmdq_suspend(struct device *dev) > if (task_running) > dev_warn(dev, "exist running task(s) in suspend\n"); > > - if (cmdq->sw_ddr_en) > + if (cmdq->pdata->sw_ddr_en) > cmdq_sw_ddr_enable(cmdq, false); > > - clk_bulk_unprepare(cmdq->gce_num, cmdq->clocks); > + clk_bulk_unprepare(cmdq->pdata->gce_num, cmdq->clocks); > > return 0; > } > @@ -346,10 +342,10 @@ static int cmdq_resume(struct device *dev) > { > struct cmdq *cmdq = dev_get_drvdata(dev); > > - WARN_ON(clk_bulk_prepare(cmdq->gce_num, cmdq->clocks)); > + WARN_ON(clk_bulk_prepare(cmdq->pdata->gce_num, cmdq->clocks)); > cmdq->suspended = false; > > - if (cmdq->sw_ddr_en) > + if (cmdq->pdata->sw_ddr_en) > cmdq_sw_ddr_enable(cmdq, true); > > return 0; > @@ -359,10 +355,10 @@ static int cmdq_remove(struct platform_device *pdev) > { > struct cmdq *cmdq = platform_get_drvdata(pdev); > > - if (cmdq->sw_ddr_en) > + if (cmdq->pdata->sw_ddr_en) > cmdq_sw_ddr_enable(cmdq, false); > > - clk_bulk_unprepare(cmdq->gce_num, cmdq->clocks); > + clk_bulk_unprepare(cmdq->pdata->gce_num, cmdq->clocks); > return 0; > } > > @@ -388,7 +384,7 @@ static int cmdq_mbox_send_data(struct mbox_chan *chan, void *data) > task->pkt = pkt; > > if (list_empty(&thread->task_busy_list)) { > - WARN_ON(clk_bulk_enable(cmdq->gce_num, cmdq->clocks)); > + WARN_ON(clk_bulk_enable(cmdq->pdata->gce_num, cmdq->clocks)); > > /* > * The thread reset will clear thread related register to 0, > @@ -398,9 +394,9 @@ static int cmdq_mbox_send_data(struct mbox_chan *chan, void *data) > */ > WARN_ON(cmdq_thread_reset(cmdq, thread) < 0); > > - writel(task->pa_base >> cmdq->shift_pa, > + writel(task->pa_base >> cmdq->pdata->shift, > thread->base + CMDQ_THR_CURR_ADDR); > - writel((task->pa_base + pkt->cmd_buf_size) >> cmdq->shift_pa, > + writel((task->pa_base + pkt->cmd_buf_size) >> cmdq->pdata->shift, > thread->base + CMDQ_THR_END_ADDR); > > writel(thread->priority, thread->base + CMDQ_THR_PRIORITY); > @@ -409,20 +405,20 @@ static int cmdq_mbox_send_data(struct mbox_chan *chan, void *data) > } else { > WARN_ON(cmdq_thread_suspend(cmdq, thread) < 0); > curr_pa = readl(thread->base + CMDQ_THR_CURR_ADDR) << > - cmdq->shift_pa; > + cmdq->pdata->shift; > end_pa = readl(thread->base + CMDQ_THR_END_ADDR) << > - cmdq->shift_pa; > + cmdq->pdata->shift; > /* check boundary */ > if (curr_pa == end_pa - CMDQ_INST_SIZE || > curr_pa == end_pa) { > /* set to this task directly */ > - writel(task->pa_base >> cmdq->shift_pa, > + writel(task->pa_base >> cmdq->pdata->shift, > thread->base + CMDQ_THR_CURR_ADDR); > } else { > cmdq_task_insert_into_thread(task); > smp_mb(); /* modify jump before enable thread */ > } > - writel((task->pa_base + pkt->cmd_buf_size) >> cmdq->shift_pa, > + writel((task->pa_base + pkt->cmd_buf_size) >> cmdq->pdata->shift, > thread->base + CMDQ_THR_END_ADDR); > cmdq_thread_resume(thread); > } > @@ -461,7 +457,7 @@ static void cmdq_mbox_shutdown(struct mbox_chan *chan) > } > > cmdq_thread_disable(cmdq, thread); > - clk_bulk_disable(cmdq->gce_num, cmdq->clocks); > + clk_bulk_disable(cmdq->pdata->gce_num, cmdq->clocks); > > done: > /* > @@ -501,7 +497,7 @@ static int cmdq_mbox_flush(struct mbox_chan *chan, unsigned long timeout) > > cmdq_thread_resume(thread); > cmdq_thread_disable(cmdq, thread); > - clk_bulk_disable(cmdq->gce_num, cmdq->clocks); > + clk_bulk_disable(cmdq->pdata->gce_num, cmdq->clocks); > > out: > spin_unlock_irqrestore(&thread->chan->lock, flags); > @@ -548,7 +544,6 @@ static int cmdq_probe(struct platform_device *pdev) > struct device *dev = &pdev->dev; > struct cmdq *cmdq; > int err, i; > - struct gce_plat *plat_data; > struct device_node *phandle = dev->of_node; > struct device_node *node; > int alias_id = 0; > @@ -567,18 +562,13 @@ static int cmdq_probe(struct platform_device *pdev) > if (cmdq->irq < 0) > return cmdq->irq; > > - plat_data = (struct gce_plat *)of_device_get_match_data(dev); > - if (!plat_data) { > + cmdq->pdata = device_get_match_data(dev); > + if (!cmdq->pdata) { > dev_err(dev, "failed to get match data\n"); > return -EINVAL; > } > > - cmdq->thread_nr = plat_data->thread_nr; > - cmdq->shift_pa = plat_data->shift; > - cmdq->control_by_sw = plat_data->control_by_sw; > - cmdq->sw_ddr_en = plat_data->sw_ddr_en; > - cmdq->gce_num = plat_data->gce_num; > - cmdq->irq_mask = GENMASK(cmdq->thread_nr - 1, 0); > + cmdq->irq_mask = GENMASK(cmdq->pdata->thread_nr - 1, 0); > err = devm_request_irq(dev, cmdq->irq, cmdq_irq_handler, IRQF_SHARED, > "mtk_cmdq", cmdq); > if (err < 0) { > @@ -589,10 +579,10 @@ static int cmdq_probe(struct platform_device *pdev) > dev_dbg(dev, "cmdq device: addr:0x%p, va:0x%p, irq:%d\n", > dev, cmdq->base, cmdq->irq); > > - if (cmdq->gce_num > 1) { > + if (cmdq->pdata->gce_num > 1) { > for_each_child_of_node(phandle->parent, node) { > alias_id = of_alias_get_id(node, clk_name); > - if (alias_id >= 0 && alias_id < cmdq->gce_num) { > + if (alias_id >= 0 && alias_id < cmdq->pdata->gce_num) { > cmdq->clocks[alias_id].id = clk_names[alias_id]; > cmdq->clocks[alias_id].clk = of_clk_get(node, 0); > if (IS_ERR(cmdq->clocks[alias_id].clk)) { > @@ -614,12 +604,12 @@ static int cmdq_probe(struct platform_device *pdev) > } > > cmdq->mbox.dev = dev; > - cmdq->mbox.chans = devm_kcalloc(dev, cmdq->thread_nr, > + cmdq->mbox.chans = devm_kcalloc(dev, cmdq->pdata->thread_nr, > sizeof(*cmdq->mbox.chans), GFP_KERNEL); > if (!cmdq->mbox.chans) > return -ENOMEM; > > - cmdq->mbox.num_chans = cmdq->thread_nr; > + cmdq->mbox.num_chans = cmdq->pdata->thread_nr; > cmdq->mbox.ops = &cmdq_mbox_chan_ops; > cmdq->mbox.of_xlate = cmdq_xlate; > > @@ -627,12 +617,12 @@ static int cmdq_probe(struct platform_device *pdev) > cmdq->mbox.txdone_irq = false; > cmdq->mbox.txdone_poll = false; > > - cmdq->thread = devm_kcalloc(dev, cmdq->thread_nr, > + cmdq->thread = devm_kcalloc(dev, cmdq->pdata->thread_nr, > sizeof(*cmdq->thread), GFP_KERNEL); > if (!cmdq->thread) > return -ENOMEM; > > - for (i = 0; i < cmdq->thread_nr; i++) { > + for (i = 0; i < cmdq->pdata->thread_nr; i++) { > cmdq->thread[i].base = cmdq->base + CMDQ_THR_BASE + > CMDQ_THR_SIZE * i; > INIT_LIST_HEAD(&cmdq->thread[i].task_busy_list); > @@ -647,7 +637,7 @@ static int cmdq_probe(struct platform_device *pdev) > > platform_set_drvdata(pdev, cmdq); > > - WARN_ON(clk_bulk_prepare(cmdq->gce_num, cmdq->clocks)); > + WARN_ON(clk_bulk_prepare(cmdq->pdata->gce_num, cmdq->clocks)); > > cmdq_init(cmdq); >