Received: by 2002:a05:6a10:8c0a:0:0:0:0 with SMTP id go10csp3620687pxb; Sun, 31 Jan 2021 23:26:52 -0800 (PST) X-Google-Smtp-Source: ABdhPJx5MhG/eG9g3Gtkl5JcqukCvWh8FYeBLMmDcOirZX0TSUOXnscO7XdUD35lvZUWV07UVAfN X-Received: by 2002:a17:906:e0cd:: with SMTP id gl13mr17012178ejb.17.1612164412347; Sun, 31 Jan 2021 23:26:52 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1612164412; cv=none; d=google.com; s=arc-20160816; b=lQUo2h0AkukpgQK049vI8lQFczDFd/toDfQE+ixPDzBkQlWetZjytxiF03Y4eZbO6c bjPNO/AEMVZiR7qI+UPOdhmHJr+jNutwjc7IZ4fIgZRhMkhHobgOzkcFr1lQwZTKUMXx 11BEnl/rrmIfftywtAiYCdKe2Y5SpNYYjEUCmJDlnGXBBarS3wDReXPLOCAKJKhxK+Tg ntExaWfwTEskcJYWzgRX6620PHqxm1IyRdAtqQH7eSF9UZx8N1GvVlJ9vbGVIeAcdJ1R zRiDAXcniZIbdLqiA/4PWzw1NqnUlk+CaK51X3NGvN/v7ftux2kqpxyEhpUuAnw7gjLa 3TzQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-language:content-transfer-encoding :in-reply-to:mime-version:user-agent:date:message-id:from:references :cc:to:subject:dkim-signature; bh=KlyzdQzXl3aPikAn68T+MmyWRqw+d/cvL92qDQmx7IA=; b=VMGg/UaYhv7kFZkXlFKlaUJCqprU3eSNxvEbVemQctP1wHZEYsVDhKPYOB7nZcEpOH /LTnKIWj0ROZOdiSSH6LZ/xoejghDgTb15o91MDARwWgonq7jCU1eUp9j2gCTHdmtgxU OZy9q1Mr/Jyj65p3jRVezeRXicL03g6mug0CWD+AXFl6D4qBfZW7yuJXG4NxFrE9FQc4 +QGtosVJflP55ea7LxjkI2DNM2/0BLVpwTzo4h44Qis0tVzsC5fnhX+KFQuI3vFvZ0zJ i9hxCxST870Vgu57yfrJUr1y1MJWpLJr4K4yVmeEpS0UXOVNr3MaaJbaz9VN2JfHhfLe eKrw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@redhat.com header.s=mimecast20190719 header.b=UZEJIo+4; 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=NONE sp=NONE dis=NONE) header.from=redhat.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id bx15si4052993edb.59.2021.01.31.23.26.28; Sun, 31 Jan 2021 23:26:52 -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=@redhat.com header.s=mimecast20190719 header.b=UZEJIo+4; 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=NONE sp=NONE dis=NONE) header.from=redhat.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231740AbhBAHZD (ORCPT + 99 others); Mon, 1 Feb 2021 02:25:03 -0500 Received: from us-smtp-delivery-124.mimecast.com ([63.128.21.124]:42210 "EHLO us-smtp-delivery-124.mimecast.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231566AbhBAHYi (ORCPT ); Mon, 1 Feb 2021 02:24:38 -0500 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com; s=mimecast20190719; t=1612164190; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=KlyzdQzXl3aPikAn68T+MmyWRqw+d/cvL92qDQmx7IA=; b=UZEJIo+486TRV7L87+hiZYC8D5/nXckB2PDs0dOpwd7eyoJDAZX0iu5vzO+08++Aor9kUh mjtG5Q768TOY+BtGbnktMnUVpGz+ChxisoSP37fhUFffv9nOOrbJu6zVAkoMbIYwugqp9z FXnZf5Egd4ZEmm8ENtrOWv8TzTixeFw= Received: from mimecast-mx01.redhat.com (mimecast-mx01.redhat.com [209.132.183.4]) (Using TLS) by relay.mimecast.com with ESMTP id us-mta-234-i0x7hE8ZM4yi-n9XoYSA0A-1; Mon, 01 Feb 2021 02:23:08 -0500 X-MC-Unique: i0x7hE8ZM4yi-n9XoYSA0A-1 Received: from smtp.corp.redhat.com (int-mx01.intmail.prod.int.phx2.redhat.com [10.5.11.11]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by mimecast-mx01.redhat.com (Postfix) with ESMTPS id C6FD3800D55; Mon, 1 Feb 2021 07:23:07 +0000 (UTC) Received: from [10.72.13.120] (ovpn-13-120.pek2.redhat.com [10.72.13.120]) by smtp.corp.redhat.com (Postfix) with ESMTP id D94226F44F; Mon, 1 Feb 2021 07:23:02 +0000 (UTC) Subject: Re: [PATCH 2/2] vdpa/mlx5: Restore the hardware used index after change map To: Eli Cohen Cc: mst@redhat.com, virtualization@lists.linux-foundation.org, netdev@vger.kernel.org, linux-kernel@vger.kernel.org, lulu@redhat.com References: <20210128134130.3051-1-elic@nvidia.com> <20210128134130.3051-3-elic@nvidia.com> <54239b51-918c-3475-dc88-4da1a4548da8@redhat.com> <20210131185536.GA164217@mtl-vdi-166.wap.labs.mlnx> <0c99f35c-7644-7201-cd11-7d486389a182@redhat.com> <20210201055247.GA184807@mtl-vdi-166.wap.labs.mlnx> <20210201063835.GA185985@mtl-vdi-166.wap.labs.mlnx> From: Jason Wang Message-ID: Date: Mon, 1 Feb 2021 15:23:01 +0800 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:68.0) Gecko/20100101 Thunderbird/68.10.0 MIME-Version: 1.0 In-Reply-To: <20210201063835.GA185985@mtl-vdi-166.wap.labs.mlnx> Content-Type: text/plain; charset=utf-8; format=flowed Content-Transfer-Encoding: 8bit Content-Language: en-US X-Scanned-By: MIMEDefang 2.79 on 10.5.11.11 Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 2021/2/1 下午2:38, Eli Cohen wrote: > On Mon, Feb 01, 2021 at 02:00:35PM +0800, Jason Wang wrote: >> On 2021/2/1 下午1:52, Eli Cohen wrote: >>> On Mon, Feb 01, 2021 at 11:36:23AM +0800, Jason Wang wrote: >>>> On 2021/2/1 上午2:55, Eli Cohen wrote: >>>>> On Fri, Jan 29, 2021 at 11:49:45AM +0800, Jason Wang wrote: >>>>>> On 2021/1/28 下午9:41, Eli Cohen wrote: >>>>>>> When a change of memory map occurs, the hardware resources are destroyed >>>>>>> and then re-created again with the new memory map. In such case, we need >>>>>>> to restore the hardware available and used indices. The driver failed to >>>>>>> restore the used index which is added here. >>>>>>> >>>>>>> Fixes 1a86b377aa21 ("vdpa/mlx5: Add VDPA driver for supported mlx5 devices") >>>>>>> Signed-off-by: Eli Cohen >>>>>> A question. Does this mean after a vq is suspended, the hw used index is not >>>>>> equal to vq used index? >>>>> Surely there is just one "Used index" for a VQ. What I was trying to say >>>>> is that after the VQ is suspended, I read the used index by querying the >>>>> hardware. The read result is the used index that the hardware wrote to >>>>> memory. >>>> Just to make sure I understand here. So it looks to me we had two index. The >>>> first is the used index which is stored in the memory/virtqueue, the second >>>> is the one that is stored by the device. >>>> >>> It is the structures defined in the virtio spec in 2.6.6 for the >>> available ring and 2.6.8 for the used ring. As you know these the >>> available ring is written to by the driver and read by the device. The >>> opposite happens for the used index. >> >> Right, so for used index it was wrote by device. And the device should have >> an internal used index value that is used to write to the used ring. And the >> code is used to sync the device internal used index if I understand this >> correctly. >> >> >>> The reason I need to restore the last known indices is for the new >>> hardware objects to sync on the last state and take over from there. >> >> Right, after the vq suspending, the questions are: >> >> 1) is hardware internal used index might not be the same with the used index >> in the virtqueue? >> > Generally the answer is no because the hardware is the only one writing > it. New objects start up with the initial value configured to them upon > creation. This value was zero before this change. > You could argue that since the hardware has access to virtqueue memory, > it could just read the value from there but it does not. I see. > >> or >> >> 2) can we simply sync the virtqueue's used index to the hardware's used >> index? >> > Theoretically it could be done but that's not how the hardware works. > One reason is that is not supposed to read from that area. But it is > really hardware implementation detail. I get you now. So Acked-by: Jason Wang Thanks >>>>> After the I create the new hardware object, I need to tell it >>>>> what is the used index (and the available index) as a way to sync it >>>>> with the existing VQ. >>>> For avail index I understand that the hardware index is not synced with the >>>> avail index stored in the memory/virtqueue. The question is used index, if >>>> the hardware one is not synced with the one in the virtqueue. It means after >>>> vq is suspended,  some requests is not completed by the hardware (e.g the >>>> buffer were not put to used ring). >>>> >>>> This may have implications to live migration, it means those unaccomplished >>>> requests needs to be migrated to the destination and resubmitted to the >>>> device. This looks not easy. >>>> >>>> Thanks >>>> >>>> >>>>> This sync is especially important when a change of map occurs while the >>>>> VQ was already used (hence the indices are likely to be non zero). This >>>>> can be triggered by hot adding memory after the VQs have been used. >>>>> >>>>>> Thanks >>>>>> >>>>>> >>>>>>> --- >>>>>>> drivers/vdpa/mlx5/net/mlx5_vnet.c | 7 +++++++ >>>>>>> 1 file changed, 7 insertions(+) >>>>>>> >>>>>>> diff --git a/drivers/vdpa/mlx5/net/mlx5_vnet.c b/drivers/vdpa/mlx5/net/mlx5_vnet.c >>>>>>> index 549ded074ff3..3fc8588cecae 100644 >>>>>>> --- a/drivers/vdpa/mlx5/net/mlx5_vnet.c >>>>>>> +++ b/drivers/vdpa/mlx5/net/mlx5_vnet.c >>>>>>> @@ -87,6 +87,7 @@ struct mlx5_vq_restore_info { >>>>>>> u64 device_addr; >>>>>>> u64 driver_addr; >>>>>>> u16 avail_index; >>>>>>> + u16 used_index; >>>>>>> bool ready; >>>>>>> struct vdpa_callback cb; >>>>>>> bool restore; >>>>>>> @@ -121,6 +122,7 @@ struct mlx5_vdpa_virtqueue { >>>>>>> u32 virtq_id; >>>>>>> struct mlx5_vdpa_net *ndev; >>>>>>> u16 avail_idx; >>>>>>> + u16 used_idx; >>>>>>> int fw_state; >>>>>>> /* keep last in the struct */ >>>>>>> @@ -804,6 +806,7 @@ static int create_virtqueue(struct mlx5_vdpa_net *ndev, struct mlx5_vdpa_virtque >>>>>>> obj_context = MLX5_ADDR_OF(create_virtio_net_q_in, in, obj_context); >>>>>>> MLX5_SET(virtio_net_q_object, obj_context, hw_available_index, mvq->avail_idx); >>>>>>> + MLX5_SET(virtio_net_q_object, obj_context, hw_used_index, mvq->used_idx); >>>>>>> MLX5_SET(virtio_net_q_object, obj_context, queue_feature_bit_mask_12_3, >>>>>>> get_features_12_3(ndev->mvdev.actual_features)); >>>>>>> vq_ctx = MLX5_ADDR_OF(virtio_net_q_object, obj_context, virtio_q_context); >>>>>>> @@ -1022,6 +1025,7 @@ static int connect_qps(struct mlx5_vdpa_net *ndev, struct mlx5_vdpa_virtqueue *m >>>>>>> struct mlx5_virtq_attr { >>>>>>> u8 state; >>>>>>> u16 available_index; >>>>>>> + u16 used_index; >>>>>>> }; >>>>>>> static int query_virtqueue(struct mlx5_vdpa_net *ndev, struct mlx5_vdpa_virtqueue *mvq, >>>>>>> @@ -1052,6 +1056,7 @@ static int query_virtqueue(struct mlx5_vdpa_net *ndev, struct mlx5_vdpa_virtqueu >>>>>>> memset(attr, 0, sizeof(*attr)); >>>>>>> attr->state = MLX5_GET(virtio_net_q_object, obj_context, state); >>>>>>> attr->available_index = MLX5_GET(virtio_net_q_object, obj_context, hw_available_index); >>>>>>> + attr->used_index = MLX5_GET(virtio_net_q_object, obj_context, hw_used_index); >>>>>>> kfree(out); >>>>>>> return 0; >>>>>>> @@ -1602,6 +1607,7 @@ static int save_channel_info(struct mlx5_vdpa_net *ndev, struct mlx5_vdpa_virtqu >>>>>>> return err; >>>>>>> ri->avail_index = attr.available_index; >>>>>>> + ri->used_index = attr.used_index; >>>>>>> ri->ready = mvq->ready; >>>>>>> ri->num_ent = mvq->num_ent; >>>>>>> ri->desc_addr = mvq->desc_addr; >>>>>>> @@ -1646,6 +1652,7 @@ static void restore_channels_info(struct mlx5_vdpa_net *ndev) >>>>>>> continue; >>>>>>> mvq->avail_idx = ri->avail_index; >>>>>>> + mvq->used_idx = ri->used_index; >>>>>>> mvq->ready = ri->ready; >>>>>>> mvq->num_ent = ri->num_ent; >>>>>>> mvq->desc_addr = ri->desc_addr;