Received: by 2002:a05:6358:3188:b0:123:57c1:9b43 with SMTP id q8csp2367931rwd; Wed, 17 May 2023 09:03:42 -0700 (PDT) X-Google-Smtp-Source: ACHHUZ4Sx+OslcB9co/8EC8V3BowSN51RkiDfZsKhXhZ3AxuaauHvXEJbysIyNQyzdt7EmnN0Akr X-Received: by 2002:a17:902:f547:b0:1ac:3e56:41b1 with SMTP id h7-20020a170902f54700b001ac3e5641b1mr50990186plf.30.1684339421986; Wed, 17 May 2023 09:03:41 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1684339421; cv=none; d=google.com; s=arc-20160816; b=l+XRIqBpdgyE1TxFmVxmJ6FHdRu7UEUsZNutEAFavkGUN4fgCFqTHHnRg1r1lIFC6n wmNwvjJmYYXQ1hNnNJu63JDyh58wKhofS9Fj4ACqF2TtMip7sv9hKPzZvN11gONz2gjz nZOihDB28qQBaISoOMVlPvrXNj8CABVMuR2avwcwyjKkQwWXmMm1l246emGHHrvx/qeY quICzTqMILhL2rDzbiqRAnCaHfXhx2Iq1VWrtmZd72Cc/QdhLPCdtkSfxRmGdPH/m4hb 84z27EVoe3OHOtVRvwFXa8VSr5JzGApT+QaennpWg4quzfVpR8Id4alr0f8NIbpj4YIx MJ5A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:feedback-id:content-transfer-encoding :mime-version:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=NAdU0ZFkKL/GxTNJIYcpoMVLuevkFQ3Dl3nGDNVQ2BE=; b=Obd8QzJ5BZd0Ik8SkJCIA5ERPzVFEenj70Zny7a7HIT+M2ST8B9YYUdLckJyoFT/0B ng6yiF20+sD14JeH2fq6JGQFN8VtJFn74EKmzonQo3X+HZ7rlQb+rAAw+nROXW2OPZEV Xn+i6ldupyvsEqbtokakszI7PmmRU76Ngm+ScL/rdfzEEvPPc54EVcWzy89H2DKHQYyA tqA3Eohf8V3cCOJixPh/k3VmBdkaLIhAbN1RBjm8PYZIO6zKKtQ9RzFq8YBUXiPUzqET 2optonOoH972510nd8D6BiWO6ITFAPEuWBXAGANBSo8bkLsdQzbNlgpO3ePGRlpm5PFc MgIQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@siemens.com header.s=fm1 header.b=CtvJC2T0; 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=REJECT sp=REJECT dis=NONE) header.from=siemens.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id r1-20020a1709028bc100b001ab1fb8cc83si20481706plo.161.2023.05.17.09.03.26; Wed, 17 May 2023 09:03:41 -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=@siemens.com header.s=fm1 header.b=CtvJC2T0; 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=REJECT sp=REJECT dis=NONE) header.from=siemens.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S232039AbjEQP7B (ORCPT + 99 others); Wed, 17 May 2023 11:59:01 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:56856 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231175AbjEQP6i (ORCPT ); Wed, 17 May 2023 11:58:38 -0400 Received: from mta-65-227.siemens.flowmailer.net (mta-65-227.siemens.flowmailer.net [185.136.65.227]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 91AD71725 for ; Wed, 17 May 2023 08:58:30 -0700 (PDT) Received: by mta-65-227.siemens.flowmailer.net with ESMTPSA id 202305171558285090153d3041a1fa1b for ; Wed, 17 May 2023 17:58:28 +0200 DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; s=fm1; d=siemens.com; i=daniel.starke@siemens.com; h=Date:From:Subject:To:Message-ID:MIME-Version:Content-Type:Content-Transfer-Encoding:Cc:References:In-Reply-To; bh=NAdU0ZFkKL/GxTNJIYcpoMVLuevkFQ3Dl3nGDNVQ2BE=; b=CtvJC2T0MgZgMjGIQvNbo1nopjh3gRiRhHZp5Vy3jg3TSKm3bMkMaemumLw0IUD8EZgYHU 3gm8oN5jUrTdYn5CPB42c9LKYWOFFE90dusFscLuP+4t6AAfGroGPYz4CpDoRo0lieWU3enU mLkMGmCYvZagE8c03kxMuCjlnzMoE=; From: "D. Starke" To: linux-serial@vger.kernel.org, gregkh@linuxfoundation.org, jirislaby@kernel.org, ilpo.jarvinen@linux.intel.com, felix-haase@siemens.com Cc: linux-kernel@vger.kernel.org, Daniel Starke Subject: [PATCH v5 04/10] tty: n_gsm: add open_error counter to gsm_mux Date: Wed, 17 May 2023 17:56:58 +0200 Message-Id: <20230517155704.5701-4-daniel.starke@siemens.com> In-Reply-To: <20230517155704.5701-1-daniel.starke@siemens.com> References: <20230517155704.5701-1-daniel.starke@siemens.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Flowmailer-Platform: Siemens Feedback-ID: 519:519-314044:519-21489:flowmailer X-Spam-Status: No, score=-2.1 required=5.0 tests=BAYES_00,DKIMWL_WL_MED, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_MSPIKE_H2, SPF_HELO_PASS,SPF_PASS,T_SCC_BODY_TEXT_LINE,URIBL_BLOCKED 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 From: Daniel Starke Extend the n_gsm link statistics by a failed link open counter in preparation for an upcoming patch which will expose these. This counter is increased whenever an attempt to open the control channel failed. This is true in the following cases: - new DLCI allocation failed - connection request (SAMB) with invalid CR flag has been received - connection response (UA) timed out - parameter negotiation timed out or failed Signed-off-by: Daniel Starke --- drivers/tty/n_gsm.c | 25 ++++++++++++++++++++----- 1 file changed, 20 insertions(+), 5 deletions(-) v4 -> v5: No changes. Please note that I cannot response to emails until August 7th. Felix Haase will take over from our side for questions regarding this patch series or the n_gsm. Link: https://lore.kernel.org/all/20230426080315.7595-4-daniel.starke@siemens.com/ diff --git a/drivers/tty/n_gsm.c b/drivers/tty/n_gsm.c index ebb71957f783..186f463f0f11 100644 --- a/drivers/tty/n_gsm.c +++ b/drivers/tty/n_gsm.c @@ -339,6 +339,7 @@ struct gsm_mux { unsigned long bad_fcs; unsigned long malformed; unsigned long io_error; + unsigned long open_error; unsigned long bad_size; unsigned long unsupported; }; @@ -1730,25 +1731,32 @@ static void gsm_control_negotiation(struct gsm_mux *gsm, unsigned int cr, struct gsm_dlci *dlci; struct gsm_dlci_param_bits *params; - if (dlen < sizeof(struct gsm_dlci_param_bits)) + if (dlen < sizeof(struct gsm_dlci_param_bits)) { + gsm->open_error++; return; + } /* Invalid DLCI? */ params = (struct gsm_dlci_param_bits *)data; addr = FIELD_GET(PN_D_FIELD_DLCI, params->d_bits); - if (addr == 0 || addr >= NUM_DLCI || !gsm->dlci[addr]) + if (addr == 0 || addr >= NUM_DLCI || !gsm->dlci[addr]) { + gsm->open_error++; return; + } dlci = gsm->dlci[addr]; /* Too late for parameter negotiation? */ - if ((!cr && dlci->state == DLCI_OPENING) || dlci->state == DLCI_OPEN) + if ((!cr && dlci->state == DLCI_OPENING) || dlci->state == DLCI_OPEN) { + gsm->open_error++; return; + } /* Process the received parameters */ if (gsm_process_negotiation(gsm, addr, cr, params) != 0) { /* Negotiation failed. Close the link. */ if (debug & DBG_ERRORS) pr_info("%s PN failed\n", __func__); + gsm->open_error++; gsm_dlci_close(dlci); return; } @@ -1768,6 +1776,7 @@ static void gsm_control_negotiation(struct gsm_mux *gsm, unsigned int cr, } else { if (debug & DBG_ERRORS) pr_info("%s PN in invalid state\n", __func__); + gsm->open_error++; } } @@ -2221,6 +2230,7 @@ static void gsm_dlci_t1(struct timer_list *t) dlci->retries--; mod_timer(&dlci->t1, jiffies + gsm->t1 * HZ / 100); } else { + gsm->open_error++; gsm_dlci_begin_close(dlci); /* prevent half open link */ } break; @@ -2236,6 +2246,7 @@ static void gsm_dlci_t1(struct timer_list *t) dlci->mode = DLCI_MODE_ADM; gsm_dlci_open(dlci); } else { + gsm->open_error++; gsm_dlci_begin_close(dlci); /* prevent half open link */ } @@ -2757,12 +2768,16 @@ static void gsm_queue(struct gsm_mux *gsm) switch (gsm->control) { case SABM|PF: - if (cr == 1) + if (cr == 1) { + gsm->open_error++; goto invalid; + } if (dlci == NULL) dlci = gsm_dlci_alloc(gsm, address); - if (dlci == NULL) + if (dlci == NULL) { + gsm->open_error++; return; + } if (dlci->dead) gsm_response(gsm, address, DM|PF); else { -- 2.34.1