Received: by 2002:a05:6358:11c7:b0:104:8066:f915 with SMTP id i7csp7414451rwl; Thu, 23 Mar 2023 04:08:20 -0700 (PDT) X-Google-Smtp-Source: AK7set9hvGypNpLuEuPB6Th3LG1DR+OjgsJirqLdKpxJ9PayQFkQSKrqQ71gCsq9Kjxhj77smD7R X-Received: by 2002:aa7:de82:0:b0:4fa:e187:64d1 with SMTP id j2-20020aa7de82000000b004fae18764d1mr8446384edv.38.1679569700382; Thu, 23 Mar 2023 04:08:20 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1679569700; cv=none; d=google.com; s=arc-20160816; b=hV7erho1hYFQ33NKscswW8EJk+uJA5Ex+x2AGVaQGhvrVWC4EPrf2YCBHS2YQcO9ZE l58Xy8AM7B+ZBwbNEt+kr7bQpNZx3ZgaTGsG/fn5SNdHe4B6GsDckaiyxeh/FCVUu3pS blUyZvcucFnw1pAIx9PPXaBL76zxBfOgYTjMF/sDs7SScGJegN0X5EOlT83VwclvVcGP qjIzjl2ynJRCxjrDfgudBEP4CmMHmU5mxXut6f7TrmEPTchzekRM+X+fpmrA+xiOkFDM 48cwx9/2fX9x8ge89mZy3RwMkfU0uhlE5gcC3PgNO9XV6GO7e2E97k46W18O+XzX92Lc op1g== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:in-reply-to:content-disposition:mime-version :references:message-id:subject:cc:to:from:date:dkim-signature; bh=MAscxfxWjnWJvYP+PGVC3a50JuQ7qCpSYPPBetUb0UU=; b=tFJBLpyYLqSmQLy/eFNV1FT2V5EhMsuqajWzOqJAmd4XkBceo6zTnI2Ejf9shB/C5x wFPG3nm2Ft+0N1z4kUIrsx4imvS3zSmf0go1MRSxjujGFLitHXbFKBmpe09ZulK4Bi49 s0gMW1GpaooqRvtUGbo4Qq6mXNPfr7A1cXiJdsDQm+ptiVU/ry5LxO9xpuWchpNuON/2 USSHCbophYlGylkUEt+Zueg0FlnGlGY1XDbCht6vwAT+ytLnegVKl6Mui2DTRT6kotLm h7yejp8bshNZNRIdv0siFWQ2BWFZcELsaBWiJqUVsYP3ikufUP964h5tjLkJAL3HIo4q dRog== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@redhat.com header.s=mimecast20190719 header.b=gLQmc0rk; 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=NONE dis=NONE) header.from=redhat.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id g23-20020aa7d1d7000000b004acce6da55bsi18815261edp.33.2023.03.23.04.07.56; Thu, 23 Mar 2023 04:08:20 -0700 (PDT) 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=@redhat.com header.s=mimecast20190719 header.b=gLQmc0rk; 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=NONE dis=NONE) header.from=redhat.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S230316AbjCWLAe (ORCPT + 99 others); Thu, 23 Mar 2023 07:00:34 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:60428 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229616AbjCWLAb (ORCPT ); Thu, 23 Mar 2023 07:00:31 -0400 Received: from us-smtp-delivery-124.mimecast.com (us-smtp-delivery-124.mimecast.com [170.10.129.124]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 2EB8B2659F for ; Thu, 23 Mar 2023 03:59:39 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com; s=mimecast20190719; t=1679569178; 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: in-reply-to:in-reply-to:references:references; bh=MAscxfxWjnWJvYP+PGVC3a50JuQ7qCpSYPPBetUb0UU=; b=gLQmc0rk/8KJ8RIwOehhtFjn0axLjiyz1BTSIhN17k+/FercaZBWhsRJyV0g2krbOsYVT8 9B3Rtv1QH2VqrZLMHEA2nHxMEnfrlK8NJ1O7coFWdt3Po1U1ltuNDy450Zfc3bBsPbvsg5 1AIOdDWcL0BONlPB07LxkOlQlD6aVL0= Received: from mimecast-mx02.redhat.com (mimecast-mx02.redhat.com [66.187.233.88]) by relay.mimecast.com with ESMTP with STARTTLS (version=TLSv1.2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id us-mta-341-5MA8H9wmOtum8LO_aKfnUg-1; Thu, 23 Mar 2023 06:59:34 -0400 X-MC-Unique: 5MA8H9wmOtum8LO_aKfnUg-1 Received: from smtp.corp.redhat.com (int-mx03.intmail.prod.int.rdu2.redhat.com [10.11.54.3]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by mimecast-mx02.redhat.com (Postfix) with ESMTPS id CBE6185A588; Thu, 23 Mar 2023 10:59:33 +0000 (UTC) Received: from tpad.localdomain (ovpn-112-2.gru2.redhat.com [10.97.112.2]) by smtp.corp.redhat.com (Postfix) with ESMTPS id A110C1121314; Thu, 23 Mar 2023 10:59:33 +0000 (UTC) Received: by tpad.localdomain (Postfix, from userid 1000) id 3D3C04038C716; Thu, 23 Mar 2023 07:52:22 -0300 (-03) Date: Thu, 23 Mar 2023 07:52:22 -0300 From: Marcelo Tosatti To: Michal Hocko Cc: Christoph Lameter , Aaron Tomlin , Frederic Weisbecker , Andrew Morton , linux-kernel@vger.kernel.org, linux-mm@kvack.org, Russell King , Huacai Chen , Heiko Carstens , x86@kernel.org, Vlastimil Babka Subject: Re: [PATCH v7 00/13] fold per-CPU vmstats remotely Message-ID: References: <20230320180332.102837832@redhat.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: X-Scanned-By: MIMEDefang 3.1 on 10.11.54.3 X-Spam-Status: No, score=-0.2 required=5.0 tests=DKIMWL_WL_HIGH,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_NONE, RCVD_IN_MSPIKE_H2,SPF_HELO_NONE,SPF_NONE autolearn=unavailable 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 Thu, Mar 23, 2023 at 08:51:14AM +0100, Michal Hocko wrote: > On Wed 22-03-23 11:20:55, Marcelo Tosatti wrote: > > On Wed, Mar 22, 2023 at 02:35:20PM +0100, Michal Hocko wrote: > [...] > > > > "Performance details for the kworker interruption: > > > > > > > > oslat 1094.456862: sys_mlock(start: 7f7ed0000b60, len: 1000) > > > > oslat 1094.456971: workqueue_queue_work: ... function=vmstat_update ... > > > > oslat 1094.456974: sched_switch: prev_comm=oslat ... ==> next_comm=kworker/5:1 ... > > > > kworker 1094.456978: sched_switch: prev_comm=kworker/5:1 ==> next_comm=oslat ... > > > > > > > > The example above shows an additional 7us for the > > > > > > > > oslat -> kworker -> oslat > > > > > > > > switches. In the case of a virtualized CPU, and the vmstat_update > > > > interruption in the host (of a qemu-kvm vcpu), the latency penalty > > > > observed in the guest is higher than 50us, violating the acceptable > > > > latency threshold for certain applications." > > > > > > Yes, I have seen that but it doesn't really give a wider context to > > > understand why those numbers matter. > > > > OK. > > > > "In the case of RAN, a MAC scheduler with TTI=1ms, this causes >100us > > interruption observed in a guest (which is above the safety > > threshold for this application)." > > > > Is that OK? > > This might be a sufficient information for somebody familiar with the > matter (not me). So no, not enough. We need to hear a more complete > story. Michal, Please refer to https://www.diva-portal.org/smash/get/diva2:541460/FULLTEXT01.pdf 2.3 Channel Dependent Scheduling The purpose of scheduling is to decide which terminal will transmit data on which set of resource blocks with what transport format to use. The objective is to assign resources to the terminal such that the quality of service (QoS) requirement is fulfilled. Scheduling decision is taken every 1 ms by base station (termed as eNodeB) as the same length of Transmission Time Interval (TTI) in LTE system. In general: https://en.wikipedia.org/wiki/Real-time_computing Real-time computing (RTC) is the computer science term for hardware and software systems subject to a "real-time constraint", for example from event to system response.[1] Real-time programs must guarantee response within specified time constraints, often referred to as "deadlines".[2] Real-time responses are often understood to be in the order of milliseconds, and sometimes microseconds. A system not specified as operating in real time cannot usually guarantee a response within any timeframe, although typical or expected response times may be given. Real-time processing fails if not completed within a specified deadline relative to an event; deadlines must always be met, regardless of system load. For example, for the MAC scheduler processing must occur every 1ms, and a certain amount of computation takes place (and must finish before the next 1ms timeframe). A > 50us latency spike as observed by cyclictest is considered a "failure".