From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1755663AbdKNRA4 (ORCPT ); Tue, 14 Nov 2017 12:00:56 -0500 Received: from mx1.redhat.com ([209.132.183.28]:57882 "EHLO mx1.redhat.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752092AbdKNRAs (ORCPT ); Tue, 14 Nov 2017 12:00:48 -0500 Date: Tue, 14 Nov 2017 18:00:36 +0100 From: Cornelia Huck To: Tony Krowiak Cc: linux-s390@vger.kernel.org, linux-kernel@vger.kernel.org, kvm@vger.kernel.org, freude@de.ibm.com, schwidefsky@de.ibm.com, heiko.carstens@de.ibm.com, borntraeger@de.ibm.com, kwankhede@nvidia.com, bjsdjshi@linux.vnet.ibm.com, pbonzini@redhat.com, alex.williamson@redhat.com, pmorel@linux.vnet.ibm.com, alifm@linux.vnet.ibm.com, mjrosato@linux.vnet.ibm.com, qemu-s390x@nongnu.org, jjherne@linux.vnet.ibm.com, thuth@redhat.com, pasic@linux.vnet.ibm.com Subject: Re: [RFC 05/19] s390/zcrypt: base implementation of AP matrix device driver Message-ID: <20171114180036.262eff80.cohuck@redhat.com> In-Reply-To: <06ddee4e-e1b8-ba17-5e3e-241e4dcf7cd0@linux.vnet.ibm.com> References: <1507916344-3896-1-git-send-email-akrowiak@linux.vnet.ibm.com> <1507916344-3896-6-git-send-email-akrowiak@linux.vnet.ibm.com> <20171114134040.3fcd6efd.cohuck@redhat.com> <06ddee4e-e1b8-ba17-5e3e-241e4dcf7cd0@linux.vnet.ibm.com> Organization: Red Hat GmbH MIME-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: 7bit X-Greylist: Sender IP whitelisted, not delayed by milter-greylist-4.5.16 (mx1.redhat.com [10.5.110.39]); Tue, 14 Nov 2017 17:00:48 +0000 (UTC) Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Tue, 14 Nov 2017 11:37:05 -0500 Tony Krowiak wrote: > On 11/14/2017 07:40 AM, Cornelia Huck wrote: > > On Fri, 13 Oct 2017 13:38:50 -0400 > > Tony Krowiak wrote: > >> diff --git a/drivers/s390/crypto/ap_matrix_bus.c b/drivers/s390/crypto/ap_matrix_bus.c > >> index 4eb1e3c..66bfa54 100644 > >> --- a/drivers/s390/crypto/ap_matrix_bus.c > >> +++ b/drivers/s390/crypto/ap_matrix_bus.c > >> @@ -75,10 +75,18 @@ static int ap_matrix_dev_create(void) > >> return 0; > >> } > >> > >> +struct ap_matrix *ap_matrix_get_device(void) > >> +{ > >> + return matrix; > > See the comments I had for the previous patch. In particular, I think > > it is better to retrieve a pointer to the matrix device via driver core > > methods. > I got some objections to creating a new bus and since there will only ever > be a single AP matrix device, I decided there really wasn't a need for an > AP matrix bus and got rid of it. I opted instead to create the matrix > device > in the init function of the vfio_ap_matrix driver. Rather than passing > around a > pointer, I put the following in vfio_ap_matrix_private.h: > > struct ap_matrix { > struct device device; > spinlock_t qlock; > struct list_head queues; > }; > > extern struct ap_matrix ap_matrix; > > ... and declared the ap_matrix in the driver (vfio_ap_matrix_drv.c) > file as: > > struct ap_matrix ap_matrix; > > Does this seem like a reasonable approach? Getting rid of the bus as overhead is not unreasonable. I'm feeling a bit queasy about the extern, however. I'd prefer a getter function (that also makes sure refcounting rules are followed). We can't get around referencing this device from multiple files, can we?