Received: by 10.223.164.221 with SMTP id h29csp237774wrb; Mon, 16 Oct 2017 02:00:13 -0700 (PDT) X-Google-Smtp-Source: AOwi7QBY1JY6jct/lAqDgRobPPDme660BTUW5xxyob8qZipQWbJjhQh7aeN1uOnjiNs2w5FAqHq1 X-Received: by 10.99.113.29 with SMTP id m29mr7736037pgc.309.1508144413012; Mon, 16 Oct 2017 02:00:13 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1508144412; cv=none; d=google.com; s=arc-20160816; b=yYq8AZtAcqc/nxPeas52nwX4QunTPOhMwzixvEc8myG1YYVkEHc0+N+Gk6ZFQweQHX mf0MzR06Dtt/rbqou6qcx1UuE9RMakMEJfdDtCBmsKNdtQKrNC1EQt7ToP1H1f6fdvD0 tFvO6yPpHBdIX2/PYP0NDWs476lC3pf4vHbU7jTy3DWBp5FhoM3ItcHUJInSo5CLbQ8y GuSfu3NQULRUWx8SNrY1It7KLF7cguIEMveAccP56S5Q/bAscKg17cU7QhW2XnLGLO4V 1CIabzmEwg9DVJ/q96vTnOILxr7dQzkKdxu1AEGArqOTVu55FNJDfGVt/goHtBqs8lSR h+rw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:message-id:content-transfer-encoding :mime-version:references:in-reply-to:subject:cc:to:from:date :arc-authentication-results; bh=wpASqXqrZ90inpaweQo+pGeiQycNNyZqsShMzx/TCOE=; b=i+kaOUYXhdA3Ks8vNgjs7H9/OdZQBapzrUfAtQiyVOkX/YZtg9EVayu9LZkbZAYUuO 7qYBtP8qStnjyTotDElW124enBCIg9hXlVXI3l1M4i9uoQjYNS0nmkQ0N8vg4qVnTPlg CwmCjmM2WPLV0skyuytHn5/2tta3DI8GnH+XYpH9Iq6KPh/IWNdpi444C1oKhVxUFWE/ HppjtPaVtNsRcBjPmuF/tHFjpQLNcAurGhVu49FMkJIL95UllFHwMsijdIMo7lRfpK74 1/lYTl3gKtROXvFZIkpYwjKOtG6txfxD745/LgazMXnmb4J9p4H3gqT8W4ShKBoB6Jog zdMg== 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=ibm.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id l91si4304731plb.678.2017.10.16.01.59.58; Mon, 16 Oct 2017 02:00:12 -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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=ibm.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751871AbdJPI7f (ORCPT + 99 others); Mon, 16 Oct 2017 04:59:35 -0400 Received: from mx0b-001b2d01.pphosted.com ([148.163.158.5]:34798 "EHLO mx0a-001b2d01.pphosted.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1751410AbdJPI7d (ORCPT ); Mon, 16 Oct 2017 04:59:33 -0400 Received: from pps.filterd (m0098420.ppops.net [127.0.0.1]) by mx0b-001b2d01.pphosted.com (8.16.0.21/8.16.0.21) with SMTP id v9G8x03F059615 for ; Mon, 16 Oct 2017 04:59:33 -0400 Received: from e06smtp13.uk.ibm.com (e06smtp13.uk.ibm.com [195.75.94.109]) by mx0b-001b2d01.pphosted.com with ESMTP id 2dmqr6w7yp-1 (version=TLSv1.2 cipher=AES256-SHA bits=256 verify=NOT) for ; Mon, 16 Oct 2017 04:59:32 -0400 Received: from localhost by e06smtp13.uk.ibm.com with IBM ESMTP SMTP Gateway: Authorized Use Only! Violators will be prosecuted for from ; Mon, 16 Oct 2017 09:59:30 +0100 Received: from b06cxnps3075.portsmouth.uk.ibm.com (9.149.109.195) by e06smtp13.uk.ibm.com (192.168.101.143) with IBM ESMTP SMTP Gateway: Authorized Use Only! Violators will be prosecuted; Mon, 16 Oct 2017 09:59:27 +0100 Received: from d06av26.portsmouth.uk.ibm.com (d06av26.portsmouth.uk.ibm.com [9.149.105.62]) by b06cxnps3075.portsmouth.uk.ibm.com (8.14.9/8.14.9/NCO v10.0) with ESMTP id v9G8xQKH31916162; Mon, 16 Oct 2017 08:59:26 GMT Received: from d06av26.portsmouth.uk.ibm.com (unknown [127.0.0.1]) by IMSVA (Postfix) with ESMTP id AB234AE053; Mon, 16 Oct 2017 09:53:37 +0100 (BST) Received: from d06av26.portsmouth.uk.ibm.com (unknown [127.0.0.1]) by IMSVA (Postfix) with ESMTP id 33F77AE051; Mon, 16 Oct 2017 09:53:37 +0100 (BST) Received: from mschwideX1 (unknown [9.152.212.220]) by d06av26.portsmouth.uk.ibm.com (Postfix) with ESMTP; Mon, 16 Oct 2017 09:53:37 +0100 (BST) Date: Mon, 16 Oct 2017 10:59:24 +0200 From: Martin Schwidefsky To: Tony Krowiak Cc: linux-s390@vger.kernel.org, linux-kernel@vger.kernel.org, kvm@vger.kernel.org, freude@de.ibm.com, heiko.carstens@de.ibm.com, borntraeger@de.ibm.com, cohuck@redhat.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 In-Reply-To: <1507916344-3896-6-git-send-email-akrowiak@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> X-Mailer: Claws Mail 3.13.2 (GTK+ 2.24.30; x86_64-pc-linux-gnu) MIME-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: 7bit X-TM-AS-GCONF: 00 x-cbid: 17101608-0012-0000-0000-000005822D43 X-IBM-AV-DETECTION: SAVI=unused REMOTE=unused XFE=unused x-cbparentid: 17101608-0013-0000-0000-000018FC6525 Message-Id: <20171016105924.0662b311@mschwideX1> X-Proofpoint-Virus-Version: vendor=fsecure engine=2.50.10432:,, definitions=2017-10-16_03:,, signatures=0 X-Proofpoint-Spam-Details: rule=outbound_notspam policy=outbound score=0 spamscore=0 suspectscore=0 malwarescore=0 phishscore=0 adultscore=0 bulkscore=0 classifier=spam adjust=0 reason=mlx scancount=1 engine=8.0.1-1707230000 definitions=main-1710160128 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Fri, 13 Oct 2017 13:38:50 -0400 Tony Krowiak wrote: > diff --git a/drivers/s390/crypto/Makefile b/drivers/s390/crypto/Makefile > index 87646ca..1983afa 100644 > --- a/drivers/s390/crypto/Makefile > +++ b/drivers/s390/crypto/Makefile > @@ -13,4 +13,8 @@ obj-$(CONFIG_ZCRYPT) += zcrypt_pcixcc.o zcrypt_cex2a.o zcrypt_cex4.o > > # pkey kernel module > pkey-objs := pkey_api.o > -obj-$(CONFIG_PKEY) += pkey.o > \ No newline at end of file > +obj-$(CONFIG_PKEY) += pkey.o > + > +# adjunct processor matrix > +vfio_ap_matrix-objs := vfio_ap_matrix_drv.o > +obj-$(CONFIG_VFIO_AP_MATRIX) += vfio_ap_matrix.o With the fix to patch #3 the newline quirk will be gone. > 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; > +} > +EXPORT_SYMBOL(ap_matrix_get_device); > + > int __init ap_matrix_init(void) > { > int ret; > > + matrix = NULL; > + > ap_matrix_root_device = root_device_register(AP_MATRIX_BUS_NAME); > ret = PTR_RET(ap_matrix_root_device); > if (ret) The global variable "matrix" is already NULL at the time ap_matrix_init is called. No need to set it again. And I would appreciate if the global variable would be named "ap_matrix". > diff --git a/drivers/s390/crypto/ap_matrix_bus.h b/drivers/s390/crypto/ap_matrix_bus.h > index 225db4f..c2aff23 100644 > --- a/drivers/s390/crypto/ap_matrix_bus.h > +++ b/drivers/s390/crypto/ap_matrix_bus.h > @@ -16,6 +16,6 @@ struct ap_matrix { > struct device device; > }; > > -int ap_matrix_init(void); > +struct ap_matrix *ap_matrix_get_device(void); > > #endif /* _AP_MATRIX_BUS_H_ */ > diff --git a/drivers/s390/crypto/vfio_ap_matrix_drv.c b/drivers/s390/crypto/vfio_ap_matrix_drv.c > new file mode 100644 > index 0000000..760ed56 > --- /dev/null > +++ b/drivers/s390/crypto/vfio_ap_matrix_drv.c > @@ -0,0 +1,102 @@ > +/* > + * VFIO based AP Matrix device driver > + * > + * Copyright IBM Corp. 2017 > + * > + * Author(s): Tony Krowiak > + */ > + > +#include > +#include > +#include > + > +#include "ap_bus.h" > +#include "ap_matrix_bus.h" > +#include "vfio_ap_matrix_private.h" > + > +#define VFIO_AP_MATRIX_DRV_NAME "vfio_ap_queue" > + > +MODULE_AUTHOR("IBM Corporation"); > +MODULE_DESCRIPTION("AP Matrix device driver, Copyright IBM Corp. 2017"); > +MODULE_LICENSE("GPL v2"); > + > +static struct ap_device_id ap_queue_ids[] = { > + { .dev_type = AP_DEVICE_TYPE_CEX4, > + .match_flags = AP_DEVICE_ID_MATCH_QUEUE_TYPE }, > + { .dev_type = AP_DEVICE_TYPE_CEX5, > + .match_flags = AP_DEVICE_ID_MATCH_QUEUE_TYPE }, > + { .dev_type = AP_DEVICE_TYPE_CEX6, > + .match_flags = AP_DEVICE_ID_MATCH_QUEUE_TYPE }, > + { /* end of list */ }, > +}; > + > +MODULE_DEVICE_TABLE(ap_matrix, ap_queue_ids); > + > +static struct ap_matrix_driver { > + struct ap_driver ap_drv; > + struct ap_matrix *ap_matrix; > +} vfio_ap_matrix_drv; > + > +static int ap_matrix_queue_dev_probe(struct ap_device *apdev) > +{ > + struct vfio_ap_queue *vapq; > + struct ap_queue *apq = to_ap_queue(&apdev->device); > + struct ap_matrix *ap_matrix = vfio_ap_matrix_drv.ap_matrix; > + > + vapq = kzalloc(sizeof(*vapq), GFP_KERNEL); > + if (!vapq) > + return -ENOMEM; > + > + INIT_LIST_HEAD(&vapq->list); > + vapq->queue = apq; > + spin_lock_bh(&ap_matrix->qlock); > + list_add_tail(&vapq->list, &ap_matrix->queues); > + spin_unlock_bh(&ap_matrix->qlock); > + > + return 0; > +} > + > +static void ap_matrix_queue_dev_remove(struct ap_device *apdev) > +{ > + struct vfio_ap_queue *vapq; > + struct ap_queue *apq = to_ap_queue(&apdev->device); > + struct ap_matrix *ap_matrix = vfio_ap_matrix_drv.ap_matrix; > + > + vapq = find_vapq(ap_matrix, apq->qid); > + > + if (vapq) { > + spin_lock_bh(&ap_matrix->qlock); > + list_del_init(&vapq->list); > + spin_unlock_bh(&ap_matrix->qlock); > + kfree(vapq); > + } > +} I would opt for a quick exit if find_vapq can not find the device. The un-indent the actual remove code. > + > +int __init ap_matrix_init(void) > +{ > + > + int ret; > + > + vfio_ap_matrix_drv.ap_matrix = ap_matrix_get_device(); > + if (!vfio_ap_matrix_drv.ap_matrix) > + return -ENODEV; > + > + vfio_ap_matrix_drv.ap_drv.probe = ap_matrix_queue_dev_probe; > + vfio_ap_matrix_drv.ap_drv.remove = ap_matrix_queue_dev_remove; > + vfio_ap_matrix_drv.ap_drv.ids = ap_queue_ids; > + > + ret = ap_driver_register(&vfio_ap_matrix_drv.ap_drv, > + THIS_MODULE, VFIO_AP_MATRIX_DRV_NAME); > + if (ret) > + return ret; > + > + return ret; > +} > + > +void __exit ap_matrix_exit(void) > +{ > + ap_driver_unregister(&vfio_ap_matrix_drv.ap_drv); > +} > + > +module_init(ap_matrix_init); > +module_exit(ap_matrix_exit); > diff --git a/drivers/s390/crypto/vfio_ap_matrix_private.h b/drivers/s390/crypto/vfio_ap_matrix_private.h > new file mode 100644 > index 0000000..11c5e02 > --- /dev/null > +++ b/drivers/s390/crypto/vfio_ap_matrix_private.h > @@ -0,0 +1,47 @@ > +/* > + * Private data and functions for adjunct processor VFIO matrix driver. > + * > + * Copyright IBM Corp. 2016 > + * Author(s): Tony Krowiak > + */ > + > +#ifndef _VFIO_AP_PRIVATE_H_ > +#define _VFIO_AP_PRIVATE_H_ > + > +#include > + > +#include "ap_bus.h" > +#include "ap_matrix_bus.h" > + > +#define VFIO_AP_MATRIX_MODULE_NAME "vfio_ap_matrix" > + > +struct vfio_ap_queue { > + struct ap_queue *queue; > + struct list_head list; > +}; > + > +static inline struct vfio_ap_queue *to_vapq(struct ap_device *ap_dev) > +{ > + struct ap_queue *ap_queue = to_ap_queue(&ap_dev->device); > + struct vfio_ap_queue *vapq; > + > + vapq = container_of(&ap_queue, struct vfio_ap_queue, queue); > + > + return vapq; > +} This can be shortened a bit return container_of(&ap_queue, struct vfio_ap_queue, queue); > + > +static inline struct vfio_ap_queue *find_vapq(struct ap_matrix *ap_matrix, > + ap_qid_t qid) > +{ > + struct vfio_ap_queue *vapq; > + > + if (!list_empty(&ap_matrix->queues)) { > + list_for_each_entry(vapq, &ap_matrix->queues, list) > + if (vapq->queue->qid == qid) > + return vapq; > + } > + > + return NULL; > +} > + > +#endif /* _VFIO_AP_PRIVATE_H_ */ -- blue skies, Martin. "Reality continues to ruin my life." - Calvin. From 1581165332668656184@xxx Fri Oct 13 17:46:07 +0000 2017 X-GM-THRID: 1581165332668656184 X-Gmail-Labels: Inbox,Category Forums