Received: by 2002:a05:6a10:8c0a:0:0:0:0 with SMTP id go10csp1420504pxb; Thu, 28 Jan 2021 16:35:37 -0800 (PST) X-Google-Smtp-Source: ABdhPJz8Ic5M0SOL1GD2b9V0va4eUhBwY+4qymD5C9y1aI3UecPzJ13BvrR0i5aHuET38RX0Y9oI X-Received: by 2002:a17:906:cedd:: with SMTP id si29mr2151085ejb.426.1611880537705; Thu, 28 Jan 2021 16:35:37 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1611880537; cv=none; d=google.com; s=arc-20160816; b=Jon7fyBZ3VLi4QsGQ+hcmAw5fxv07nNJ4HXuOvU20pPj+WOLZGhDm1I2WMheEYKpV+ UURiPPfdBw76WKkOFKeVSuGVGlpSaA/89BqmVTeaIuDt8sJMYpy3UNZ+AJ/i/okcVHql prtNq6Kv2bHlQDxNpfpkZyuP4/XnSPPceIGIiHoThI9F6ZBe2O12l3ZTUJ5zbPtPAKkc 7yh53+GRzEpo/CHNOL3/fPJ2yuwuk38xji5r1aWp31SbzOMHaZok90Ed7u0M3NZS0KC/ ier0JebYvVmi0OjtOgrb+1hAynWdjyf3RdUYX0h5Z/bQ1MVXRz2xP7x8JmTngkBvzgLh GfDw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:references:in-reply-to:message-id:date:subject :cc:to:from:dkim-signature:dkim-filter; bh=IrbPgxhFp1tp8G4pk2ZMMvQCAjKSOuX7/kdH3ZKnZMM=; b=PJCiX+J3SqQ1uf9I4d4KZS6l37fBGspgasHcAx7jpZxmrt0Cnx1jHPR2qt1Zv0sO+e dHIzQlLin01CMGiPp5DVD366SgaI4rY8nt3qR3JN1C8Y2F8DUdcwNjs+4fg+hg7xCGSq ImspXFavrw59vb92LOmNWwgvpnmZiN6+m3mDNfWPyf1Cj6UJFmlmz8zNFRpJbLkvYwOK mx3G99UWzmmhVEP+OunpWTmJRLJdNY1dPZR0qI30Xm/UBsXb01ZrwSfqjKXbwqlf73k5 4V0Kz542zFOUpiH07kt5UqeNBa1lbyp84nIamuUzGcHB8dIYeWvykOl8n2rprWdSNN1a 1/gg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@broadcom.com header.s=dkimrelay header.b=PZJqEvdi; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=broadcom.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id i7si4162525edg.300.2021.01.28.16.35.13; Thu, 28 Jan 2021 16:35:37 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@broadcom.com header.s=dkimrelay header.b=PZJqEvdi; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=broadcom.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231337AbhA2Aci (ORCPT + 99 others); Thu, 28 Jan 2021 19:32:38 -0500 Received: from relay.smtp-ext.broadcom.com ([192.19.221.30]:42522 "EHLO relay.smtp-ext.broadcom.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231256AbhA2Ab6 (ORCPT ); Thu, 28 Jan 2021 19:31:58 -0500 Received: from lbrmn-lnxub113.broadcom.net (lbrmn-lnxub113.ric.broadcom.net [10.136.13.65]) by relay.smtp-ext.broadcom.com (Postfix) with ESMTP id 813947FFC; Thu, 28 Jan 2021 16:30:50 -0800 (PST) DKIM-Filter: OpenDKIM Filter v2.11.0 relay.smtp-ext.broadcom.com 813947FFC DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=broadcom.com; s=dkimrelay; t=1611880252; bh=G0JtokNm+NFuFyX3E5lg6X/oWOr8kduycb4M3eR02lM=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=PZJqEvdi85TSd63Ly53ndFdEH+VWZyNWAuWq2/zGCGW/16VAxEukWrrdnWvNGGMcK YfAcUSku3I4ehYRwcYYo79DvFvwLHj66HS5kwjnGAr4MXA42YdVvx9XyIALIHx9eYr Th/v2Oe11ZvnYtK1q+XgHkbF9LksTzTFTSyXmuOY= From: Scott Branden To: Arnd Bergmann , Greg Kroah-Hartman , Scott Branden Cc: Kees Cook , linux-kernel@vger.kernel.org, bcm-kernel-feedback-list@broadcom.com, Olof Johansson , Desmond Yan Subject: [PATCH v10 04/13] misc: bcm-vk: add misc device to Broadcom VK driver Date: Thu, 28 Jan 2021 16:30:20 -0800 Message-Id: <20210129003029.10672-5-scott.branden@broadcom.com> X-Mailer: git-send-email 2.17.1 In-Reply-To: <20210129003029.10672-1-scott.branden@broadcom.com> References: <20210129003029.10672-1-scott.branden@broadcom.com> Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Add misc device base support to create and remove devnode. Additional misc functions for open/read/write/release/ioctl/sysfs, etc will be added in follow on commits to allow for individual review. Co-developed-by: Desmond Yan Signed-off-by: Desmond Yan Signed-off-by: Scott Branden Acked-by: Olof Johansson --- drivers/misc/bcm-vk/bcm_vk.h | 2 ++ drivers/misc/bcm-vk/bcm_vk_dev.c | 36 +++++++++++++++++++++++++++++++- 2 files changed, 37 insertions(+), 1 deletion(-) diff --git a/drivers/misc/bcm-vk/bcm_vk.h b/drivers/misc/bcm-vk/bcm_vk.h index c4fb61a84e41..0a366db693c8 100644 --- a/drivers/misc/bcm-vk/bcm_vk.h +++ b/drivers/misc/bcm-vk/bcm_vk.h @@ -7,6 +7,7 @@ #define BCM_VK_H #include +#include #include #include @@ -214,6 +215,7 @@ struct bcm_vk { struct bcm_vk_dauth_info dauth_info; + struct miscdevice miscdev; int devid; /* dev id allocated */ struct workqueue_struct *wq_thread; diff --git a/drivers/misc/bcm-vk/bcm_vk_dev.c b/drivers/misc/bcm-vk/bcm_vk_dev.c index adc3103c7012..4ecd5b5f80d3 100644 --- a/drivers/misc/bcm-vk/bcm_vk_dev.c +++ b/drivers/misc/bcm-vk/bcm_vk_dev.c @@ -7,6 +7,7 @@ #include #include #include +#include #include #include #include @@ -643,6 +644,7 @@ static int bcm_vk_probe(struct pci_dev *pdev, const struct pci_device_id *ent) char name[20]; struct bcm_vk *vk; struct device *dev = &pdev->dev; + struct miscdevice *misc_device; u32 boot_status; vk = kzalloc(sizeof(*vk), GFP_KERNEL); @@ -719,6 +721,19 @@ static int bcm_vk_probe(struct pci_dev *pdev, const struct pci_device_id *ent) vk->devid = id; snprintf(name, sizeof(name), DRV_MODULE_NAME ".%d", id); + misc_device = &vk->miscdev; + misc_device->minor = MISC_DYNAMIC_MINOR; + misc_device->name = kstrdup(name, GFP_KERNEL); + if (!misc_device->name) { + err = -ENOMEM; + goto err_ida_remove; + } + + err = misc_register(misc_device); + if (err) { + dev_err(dev, "failed to register device\n"); + goto err_kfree_name; + } INIT_WORK(&vk->wq_work, bcm_vk_wq_handler); @@ -727,7 +742,7 @@ static int bcm_vk_probe(struct pci_dev *pdev, const struct pci_device_id *ent) if (!vk->wq_thread) { dev_err(dev, "Fail to create workqueue thread\n"); err = -ENOMEM; - goto err_ida_remove; + goto err_misc_deregister; } /* sync other info */ @@ -749,11 +764,20 @@ static int bcm_vk_probe(struct pci_dev *pdev, const struct pci_device_id *ent) } } + dev_dbg(dev, "BCM-VK:%u created\n", id); + return 0; err_destroy_workqueue: destroy_workqueue(vk->wq_thread); +err_misc_deregister: + misc_deregister(misc_device); + +err_kfree_name: + kfree(misc_device->name); + misc_device->name = NULL; + err_ida_remove: ida_simple_remove(&bcm_vk_ida, id); @@ -783,6 +807,7 @@ static void bcm_vk_remove(struct pci_dev *pdev) { int i; struct bcm_vk *vk = pci_get_drvdata(pdev); + struct miscdevice *misc_device = &vk->miscdev; /* * Trigger a reset to card and wait enough time for UCODE to rerun, @@ -797,6 +822,13 @@ static void bcm_vk_remove(struct pci_dev *pdev) dma_free_coherent(&pdev->dev, nr_scratch_pages * PAGE_SIZE, vk->tdma_vaddr, vk->tdma_addr); + /* remove if name is set which means misc dev registered */ + if (misc_device->name) { + misc_deregister(misc_device); + kfree(misc_device->name); + ida_simple_remove(&bcm_vk_ida, vk->devid); + } + cancel_work_sync(&vk->wq_work); destroy_workqueue(vk->wq_thread); @@ -805,6 +837,8 @@ static void bcm_vk_remove(struct pci_dev *pdev) pci_iounmap(pdev, vk->bar[i]); } + dev_dbg(&pdev->dev, "BCM-VK:%d released\n", vk->devid); + pci_release_regions(pdev); pci_free_irq_vectors(pdev); pci_disable_device(pdev); -- 2.17.1