Received: by 2002:a05:6358:3188:b0:123:57c1:9b43 with SMTP id q8csp4833114rwd; Tue, 23 May 2023 13:17:28 -0700 (PDT) X-Google-Smtp-Source: ACHHUZ5QNv0HpmZAikpwqT3yqUulxmMB+w+kFqltbfpiLBS85VCQ0utCXRxqd08U+zJxXuUt93yf X-Received: by 2002:a05:6a20:841c:b0:10b:ecde:2911 with SMTP id c28-20020a056a20841c00b0010becde2911mr7283188pzd.27.1684873048516; Tue, 23 May 2023 13:17:28 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1684873048; cv=none; d=google.com; s=arc-20160816; b=G4luLi6s00bt7c8Z7Db2yczeWPXRpgDcWCGVS0d2I+lXsPb8FNlT8poKf/OHqu/04d 3jbp7bXXNcuKvlSzczzwZNwzEpcBnb+0LVxyJQgAxEYAvFQlPI6poeo4r85fK2AVWwZ3 xtgpOo9lqAOEpEHDTDtLmrSGknFYWUW6LhLAsAgmp80BotiVWZWZRexow0jQAdBYzls9 faHuJcwnY6b0lZTyAsWI3AiVuZCjP6sWjU7ZN4M79lguMHz5Zbv+MDa2uULskON9H0+N CjQK3wmbFbT0baQVU/UwFQYN3Dkg8tRf1C2rGEqHcfpU7CLy7vdDQSVOv9iUKejaEOW0 1NtA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :message-id:date:subject:cc:to:from:dkim-signature; bh=IUxmQ5P+MH9SvOjqUd5l2+YQ2XDFMIly2tHjSWnRkr0=; b=pozB41mKShCtEv4dTjUidGZCHY0L6WY/9xjzE7sZnCytwYIGqvMhSrRhYzE8561yf6 943v5SYnmXn+dlOCZJgBnxlikj9YCp9PZPkCm+jpEtK0xhu1uQtDzVoHF1OqEUEqibqO MlWr84cKaqy9OC/JgUOyFH9YC15Fdb2CeXkwn9yRsHakyxt/cDZG3ahVJsoY5IGGLtZb rJblYDHHnMHYXwmR08Z81QyJIEk8gnweMeoS8Sm85lfh35Jf6m61PwVHe6Bio0KDHdlR uBIOxTDCr71fqGdc8EBH4UTTRHYc6zjRGEXK/ocGlbLwlh9UjFSICQ44wzb1rkAzzxsc HYyg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@redhat.com header.s=mimecast20190719 header.b=JkAGHIDy; 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 y4-20020a637d04000000b005344b36c64asi7037504pgc.786.2023.05.23.13.17.13; Tue, 23 May 2023 13:17:28 -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=JkAGHIDy; 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 S230296AbjEWTzf (ORCPT + 99 others); Tue, 23 May 2023 15:55:35 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:53474 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229614AbjEWTzd (ORCPT ); Tue, 23 May 2023 15:55:33 -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 22042E5 for ; Tue, 23 May 2023 12:54:52 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com; s=mimecast20190719; t=1684871691; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version: content-transfer-encoding:content-transfer-encoding; bh=IUxmQ5P+MH9SvOjqUd5l2+YQ2XDFMIly2tHjSWnRkr0=; b=JkAGHIDyuP8mRGOIu37kVJXBN6ruA6E4p+Nk1lJ9MiLNCpfruNb1ryMZnabSJxtANmnUsr p2FZVAhIChI8gbjYp9p+CzZoK9qTj8RIGtmknoetJHk+brq/vYAqBHBI/uKVaTxrTtjnh0 788mBWHFohUHw5C3wbL325udH5yxfy0= 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-541-gNeZnkYYM_a-OP0OnxG1Tw-1; Tue, 23 May 2023 15:54:47 -0400 X-MC-Unique: gNeZnkYYM_a-OP0OnxG1Tw-1 Received: from smtp.corp.redhat.com (int-mx09.intmail.prod.int.rdu2.redhat.com [10.11.54.9]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by mimecast-mx02.redhat.com (Postfix) with ESMTPS id 06664185A78B; Tue, 23 May 2023 19:54:47 +0000 (UTC) Received: from work.redhat.com (unknown [10.39.193.140]) by smtp.corp.redhat.com (Postfix) with ESMTP id 794E4492B00; Tue, 23 May 2023 19:54:45 +0000 (UTC) From: Tim Wiederhake To: "Borislav Petkov" , "Dave Hansen" , "H. Peter Anvin" , "Ingo Molnar" , "Paolo Bonzini" , "Thomas Gleixner" , kvm@vger.kernel.org, linux-kernel@vger.kernel.org, x86@kernel.org Cc: Tim Wiederhake Subject: [PATCH 1/2] x86/msr: Read MSRs individually Date: Tue, 23 May 2023 21:49:48 +0200 Message-Id: <20230523194949.96149-1-twiederh@redhat.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Scanned-By: MIMEDefang 3.1 on 10.11.54.9 X-Spam-Status: No, score=-2.1 required=5.0 tests=BAYES_00,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,T_SCC_BODY_TEXT_LINE 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 Reading from /dev/cpu/*/msr with buffer size > 8 would read the data of the same msr repeatedly instead of the data for consecutive msrs, as one might expect. Solve by restricting MSR reads to one per call. Signed-off-by: Tim Wiederhake --- arch/x86/kernel/msr.c | 21 +++++++-------------- 1 file changed, 7 insertions(+), 14 deletions(-) diff --git a/arch/x86/kernel/msr.c b/arch/x86/kernel/msr.c index 7bb17d37db01..058f2b67d0c7 100644 --- a/arch/x86/kernel/msr.c +++ b/arch/x86/kernel/msr.c @@ -58,24 +58,17 @@ static ssize_t msr_read(struct file *file, char __user *buf, u32 reg = *ppos; int cpu = iminor(file_inode(file)); int err = 0; - ssize_t bytes = 0; - if (count % 8) + if (count < 8) return -EINVAL; /* Invalid chunk size */ - for (; count; count -= 8) { - err = rdmsr_safe_on_cpu(cpu, reg, &data[0], &data[1]); - if (err) - break; - if (copy_to_user(tmp, &data, 8)) { - err = -EFAULT; - break; - } - tmp += 2; - bytes += 8; - } + err = rdmsr_safe_on_cpu(cpu, reg, &data[0], &data[1]); + if (err) + return err; + if (copy_to_user(tmp, &data, 8)) + return -EFAULT; - return bytes ? bytes : err; + return 8; } static int filter_write(u32 reg) -- 2.39.2