Received: by 2002:a05:6358:3188:b0:123:57c1:9b43 with SMTP id q8csp2376066rwd; Wed, 17 May 2023 09:08:03 -0700 (PDT) X-Google-Smtp-Source: ACHHUZ4f5t9Auk2BMPrnik0GA0hK5N3K1COjGRXFJEC+FzFxnajqj+/qYhOKBQCL4sv6T1cX6pZv X-Received: by 2002:a17:90b:a4b:b0:253:2f58:fe62 with SMTP id gw11-20020a17090b0a4b00b002532f58fe62mr189271pjb.19.1684339682770; Wed, 17 May 2023 09:08:02 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1684339682; cv=none; d=google.com; s=arc-20160816; b=Le7GvJr15atKBrK5qZRkh7du1oRqxQtYnzfnUNjwUSf05V5Kdv9RPRovfH1uDoX+LN yCBPPSP0g/XmzmDgtAW0vPutlu62QAf12y+UagfZStf8CdF80n17ZvwW9oZGvjn7SoOc 8sNAHRNNfH38f/+ONfc/I27nxnb5qCfdS9LWrXj69AkiMpNypeexMuqbAIsQQO7/kto1 azFJ+GmBrgLN/IqkrEPhZIHk2JOuDQryvqtmCIs2Xjf90+fa+CQ9W541IXHEGA4PG+rv TJLKYicYe3+7q3C5721iNgCH91AnPa5UQp/k2d2F0+yQ6xrvNyILa8zc0hWt/lYfwJrZ MKRQ== 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=ZT7+g7B3Lbu99drej4ZddyowwBxP0nuUx4VS88186Es=; b=NqqzoijRTyEuSHOV/AfSIElddHDUwFisaTbp98ilqnE2pozVm+NQlOjirzS0+DyO29 V3RA5fQlNQm5MmRTLpZyxBQ0VQFpGNeNHxF/qtnRaUjft4hh1KpphnsFykpn7617ftSm 0sK+orVqkprTARTt0FR3RUm/CeCUNkgj4/DuAILtTPKUk5JB2F+axNBKhyzg3WeZREdd SuaNM0MW32xWZ/1F8YnfU6368EnQXNhonX2GSh2iLCvn7iHPv+yBlqHFRSSGQwWguDkB p0sMR7dmRQ3Y/9pKAMWXMVwDh9mA85Zjx7+rkX95/qHTxozuI/Efuhtyn5bIhQVMoWXS KGCQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@siemens.com header.s=fm1 header.b=OTmSarLU; 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 c20-20020a6566d4000000b0050bcfe667e7si21750108pgw.474.2023.05.17.09.07.47; Wed, 17 May 2023 09:08:02 -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=OTmSarLU; 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 S232046AbjEQP7E (ORCPT + 99 others); Wed, 17 May 2023 11:59:04 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:57372 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231898AbjEQP6y (ORCPT ); Wed, 17 May 2023 11:58:54 -0400 Received: from mta-64-225.siemens.flowmailer.net (mta-64-225.siemens.flowmailer.net [185.136.64.225]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 037AB3A80 for ; Wed, 17 May 2023 08:58:31 -0700 (PDT) Received: by mta-64-225.siemens.flowmailer.net with ESMTPSA id 20230517155829be8a39f72acba4b99e for ; Wed, 17 May 2023 17:58:29 +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=ZT7+g7B3Lbu99drej4ZddyowwBxP0nuUx4VS88186Es=; b=OTmSarLUw0pA6xy7u7l5FKpEmDX8pQVAYcMCiPvj+Ym0KglLFhEbIYSI5nHazJw1MZDMwZ 0rRkoy2A9ftyynVqELLWBaJVUfAg+ithhLgwK91W35/0K1Q3c6vcyTUp1CSWL5MQ09Pmgykr MdNtXdpV6aK7mbTefE9a9Yk+KauzU=; 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 06/10] tty: n_gsm: increase gsm_mux unsupported counted where appropriate Date: Wed, 17 May 2023 17:57:00 +0200 Message-Id: <20230517155704.5701-6-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 The structure gsm_mux contains the 'unsupported' field. However, there is currently no place in the code which increases this counter. Increase the 'unsupported' statistics counter in the following case: - an unsupported frame type has been requested by the peer via parameter negotiation - a control frame with an unsupported but known command has been received Note that we have no means to detect an inconsistent/unsupported adaptation sufficient accuracy as this changes the structure of the UI/UIH frames. E.g. a one byte header is added in case of convergence layer type 2 instead of 1 and contains the modem signal octet with the state of the signal lines. There is no checksum or other value which indicates of this field is correct or should be present. Therefore, we can only assume protocol correctness here. See also 'gsm_dlci_data()' where this is handled. Signed-off-by: Daniel Starke --- drivers/tty/n_gsm.c | 3 +++ 1 file changed, 3 insertions(+) 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-6-daniel.starke@siemens.com/ diff --git a/drivers/tty/n_gsm.c b/drivers/tty/n_gsm.c index 5b6a03668c78..42a8507aae4a 100644 --- a/drivers/tty/n_gsm.c +++ b/drivers/tty/n_gsm.c @@ -1590,6 +1590,7 @@ static int gsm_process_negotiation(struct gsm_mux *gsm, unsigned int addr, if (debug & DBG_ERRORS) pr_info("%s unsupported I frame request in PN\n", __func__); + gsm->unsupported++; return -EINVAL; default: if (debug & DBG_ERRORS) @@ -1897,6 +1898,8 @@ static void gsm_control_message(struct gsm_mux *gsm, unsigned int command, /* Optional unsupported commands */ case CMD_RPN: /* Remote port negotiation */ case CMD_SNC: /* Service negotiation command */ + gsm->unsupported++; + fallthrough; default: /* Reply to bad commands with an NSC */ buf[0] = command; -- 2.34.1