Re: [pim] Robert Wilton's Discuss on draft-ietf-pim-igmp-mld-snooping-yang-17: (with DISCUSS and COMMENT)

Hongji Zhao <hongji.zhao@ericsson.com> Tue, 14 July 2020 03:26 UTC

Return-Path: <hongji.zhao@ericsson.com>
X-Original-To: pim@ietfa.amsl.com
Delivered-To: pim@ietfa.amsl.com
Received: from localhost (localhost [127.0.0.1]) by ietfa.amsl.com (Postfix) with ESMTP id 955323A07F7; Mon, 13 Jul 2020 20:26:26 -0700 (PDT)
X-Virus-Scanned: amavisd-new at amsl.com
X-Spam-Flag: NO
X-Spam-Score: -2.101
X-Spam-Level:
X-Spam-Status: No, score=-2.101 tagged_above=-999 required=5 tests=[BAYES_00=-1.9, DKIMWL_WL_HIGH=-0.001, DKIM_SIGNED=0.1, DKIM_VALID=-0.1, DKIM_VALID_AU=-0.1, DKIM_VALID_EF=-0.1, RCVD_IN_DNSWL_BLOCKED=0.001, RCVD_IN_MSPIKE_H2=-0.001, SPF_PASS=-0.001, URIBL_BLOCKED=0.001] autolearn=ham autolearn_force=no
Authentication-Results: ietfa.amsl.com (amavisd-new); dkim=pass (1024-bit key) header.d=ericsson.com
Received: from mail.ietf.org ([4.31.198.44]) by localhost (ietfa.amsl.com [127.0.0.1]) (amavisd-new, port 10024) with ESMTP id OyuM8GBj2nDT; Mon, 13 Jul 2020 20:26:21 -0700 (PDT)
Received: from EUR03-AM5-obe.outbound.protection.outlook.com (mail-eopbgr30042.outbound.protection.outlook.com [40.107.3.42]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by ietfa.amsl.com (Postfix) with ESMTPS id 804433A0900; Mon, 13 Jul 2020 20:25:52 -0700 (PDT)
ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=GdzjmkA+TRM0crHHGGix4RMZI5mY7v1eRJtJ8e7rxFkw5HZL2tvtpR3usiyqERuUjqjtzLXAkKNw+tJ6iXsczkqD+c4RDgBla6q9t9crp6Ybf9une63txVPrldl3dhxBdo2KWylskDa7crWj7AYnsx4IyNSKm726C0AB3x2F9kdCwCMUmGPLpQHyj+Y4Ul8qm+4UuwgyGwUyA9q4rJEAAoMNKfNSGQQTEfEUnVicsRCXhg+cS8K1q7MCHp0uBuPpMeYLXlYdjbDJN0GQMMrfpAqkNDbsgW6rhe/NFUVmJRruENSxU5nZ2NqeUmAfavp6KDMsqWezb9IlDys0bsUshA==
ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector9901; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=HCDNq7olJeq3obWc/ahXKzDCcbWLVRrd/kCuuPyy5Gw=; b=Ph9m53lOk1lkLrTGbgmqlZhXNh30RVb6JoAIAcFw64yLVl0fUnTUrD8LwwelB0Qjz+j0JKJoKwIxUOgWuvqfL6UaVJk8yZ592GlekC3aFYT+NNQUft0RX0IoeFvpf3vvvIJ60C5bLlapyevndsLZNKtjNVv0e4mS5GMe24EelrB8QLVgKOxJClXTVqDtd7DLc9TXChKfVVwee9fywNu/yiZnV2vA6Uo8bhJYE0mTzt56eW7vJu95m3+jcCoLwBEq/N0Cz9w/P3cmDz6TsV6zsumxvT3nky62X3guvAB+a96t2HeFagnJ21sUzKNv9ZvOfdhCxLY1tGlKEA2bBomYqg==
ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=ericsson.com; dmarc=pass action=none header.from=ericsson.com; dkim=pass header.d=ericsson.com; arc=none
DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=ericsson.com; s=selector1; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=HCDNq7olJeq3obWc/ahXKzDCcbWLVRrd/kCuuPyy5Gw=; b=YFUng7YDbKcKWbPq544dWs6zfyf47eohwAIpfOQ2jPHqwH6j0vdcKVzMGpDqJ79WqmQa3mCM4Uh9AhgC/m/MgiSXyn8QlqxS7WGPysyYBdUAGEZwbyD0Uqou+eatdgQyTzML2APRu1mjwS5eR1O/qba3zhfZfipzVR+w81RoFTY=
Received: from HE1PR0701MB2492.eurprd07.prod.outlook.com (2603:10a6:3:71::22) by HE1PR07MB3131.eurprd07.prod.outlook.com (2603:10a6:7:31::17) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.3195.10; Tue, 14 Jul 2020 03:25:42 +0000
Received: from HE1PR0701MB2492.eurprd07.prod.outlook.com ([fe80::ec82:bf39:2810:fbb0]) by HE1PR0701MB2492.eurprd07.prod.outlook.com ([fe80::ec82:bf39:2810:fbb0%7]) with mapi id 15.20.3195.009; Tue, 14 Jul 2020 03:25:42 +0000
From: Hongji Zhao <hongji.zhao@ericsson.com>
To: Robert Wilton <rwilton@cisco.com>, The IESG <iesg@ietf.org>
CC: "draft-ietf-pim-igmp-mld-snooping-yang@ietf.org" <draft-ietf-pim-igmp-mld-snooping-yang@ietf.org>, "pim-chairs@ietf.org" <pim-chairs@ietf.org>, "pim@ietf.org" <pim@ietf.org>, Stig Venaas <stig@venaas.com>, "aretana.ietf@gmail.com" <aretana.ietf@gmail.com>
Thread-Topic: Robert Wilton's Discuss on draft-ietf-pim-igmp-mld-snooping-yang-17: (with DISCUSS and COMMENT)
Thread-Index: AQHWVdcXmlpukUvGqE2bmmz/z85+SqkGcErg
Date: Tue, 14 Jul 2020 03:25:42 +0000
Message-ID: <HE1PR0701MB249249C361CB7EAE14C9E8BF96610@HE1PR0701MB2492.eurprd07.prod.outlook.com>
References: <159428852777.7283.9711125025293117565@ietfa.amsl.com>
In-Reply-To: <159428852777.7283.9711125025293117565@ietfa.amsl.com>
Accept-Language: en-US
Content-Language: en-US
X-MS-Has-Attach:
X-MS-TNEF-Correlator:
authentication-results: cisco.com; dkim=none (message not signed) header.d=none;cisco.com; dmarc=none action=none header.from=ericsson.com;
x-originating-ip: [119.28.22.196]
x-ms-publictraffictype: Email
x-ms-office365-filtering-correlation-id: 61bbd1d2-fca2-4079-16b4-08d827a596ea
x-ms-traffictypediagnostic: HE1PR07MB3131:
x-microsoft-antispam-prvs: <HE1PR07MB31313D58D333CBE37D492FDB96610@HE1PR07MB3131.eurprd07.prod.outlook.com>
x-ms-oob-tlc-oobclassifiers: OLM:10000;
x-ms-exchange-senderadcheck: 1
x-microsoft-antispam: BCL:0;
x-microsoft-antispam-message-info: KAD+ORLgjWmEZNk+XB9hANBLv273FhfqrGoDr/nxUMaj0yq8lYbIRxIpH0tlO8jvnbPn9/xYT4OeSSJ3m81m3NFLBFwWbU4oID19SredhqgjO7qvx+PVj9OYIjDUq+0roLE2hL7yEdSTMf6Hene5dxUU2L9wzeIK88uGeSPeZ42RBtCvFbIFq56K2a81UOmlRprWC7+BgsFZfrThCqGZB1YDisHXAtvhIflcU3kGdrgaPfGspPfKj2E7eqwm4A0KCw6B6oyH3YEaBySWGytrnKsMO2+PkEptH74+i+zcddgAOSeeAgxgnfsCjy7RD2WNMiyVWgk4ogxKKFbzj09K1qYlsAsOVTEJM77fTZkpC3uk4/hCXCpn2EbtLyz4l14JjYYUDU2bMx2AK3GdQ47VxmDyi/RkETkvmSlsrBtE8Wka8Sl9q7NJlycT13RzFZ4yzA6Y8Y5qRDi8ZhHuqjtNUw==
x-forefront-antispam-report: CIP:255.255.255.255; CTRY:; LANG:en; SCL:1; SRV:; IPV:NLI; SFV:NSPM; H:HE1PR0701MB2492.eurprd07.prod.outlook.com; PTR:; CAT:NONE; SFTY:; SFS:(4636009)(346002)(39860400002)(136003)(396003)(376002)(366004)(86362001)(53546011)(6506007)(8676002)(83380400001)(9686003)(44832011)(5660300002)(52536014)(2906002)(7696005)(55016002)(8936002)(478600001)(66476007)(316002)(66556008)(64756008)(66446008)(4326008)(966005)(26005)(66946007)(66574015)(33656002)(54906003)(186003)(71200400001)(76116006)(110136005)(21314003); DIR:OUT; SFP:1101;
x-ms-exchange-antispam-messagedata: 7RLHG8NewvSv7H3UUp/FFbwKiZHo+dugkChOY2VqIwzHIleBwZVOKwkmB6yaZgsDAl/p2vrKXjd3XHfIL3DWYLM8pyCckT49dDUP0kNEwFmQMWF6LBfn6Qj2NfZEAobAqHln8UiYgQvxkLtbp9PTQvQlLlahG5sPOx0wm3YWJrMgjuHPMBTXV3vIKx9VSr6UOpaCK5Tel9Icskezsd0iF17GJbFFrm3T6EFQaqNBItFOGRIb+9M8TNVHtCQZ/vQjlrBso5t6IvqWfK7990qEvALNSyxxvnEhJ2S14TAphS64m8WKPlEpLSLmymA4sBX2qFgZ8p8ZDqZwNuieTBrPlzc3NxgjR7mljdpk7GeVB+tqJr7hg1xcGYXSaM9DS+/8zHtStUOBI7tyGPLLAwcqhtO2430I5cXxg9Upc7jM9falgyfjSqwredwy+gAnulXP9N+ogoG3jZXetL3/qRxupgf64NdCF86W+RVMgBzvbE4=
x-ms-exchange-transport-forked: True
Content-Type: text/plain; charset="utf-8"
Content-Transfer-Encoding: base64
MIME-Version: 1.0
X-OriginatorOrg: ericsson.com
X-MS-Exchange-CrossTenant-AuthAs: Internal
X-MS-Exchange-CrossTenant-AuthSource: HE1PR0701MB2492.eurprd07.prod.outlook.com
X-MS-Exchange-CrossTenant-Network-Message-Id: 61bbd1d2-fca2-4079-16b4-08d827a596ea
X-MS-Exchange-CrossTenant-originalarrivaltime: 14 Jul 2020 03:25:42.6426 (UTC)
X-MS-Exchange-CrossTenant-fromentityheader: Hosted
X-MS-Exchange-CrossTenant-id: 92e84ceb-fbfd-47ab-be52-080c6b87953f
X-MS-Exchange-CrossTenant-mailboxtype: HOSTED
X-MS-Exchange-CrossTenant-userprincipalname: LbnwUv99eWWK2BsxnE7BKw1+QLKqHP1ouw9DcgHyQot4Pm57+qKZU1+fqiFXYQyfvfhHfFh8+w3ekhqvJVFFWattL5NR9+GnF18AAgzBvgw=
X-MS-Exchange-Transport-CrossTenantHeadersStamped: HE1PR07MB3131
Archived-At: <https://mailarchive.ietf.org/arch/msg/pim/43PQQwvmChKdv2pugUKiUzz2ekE>
Subject: Re: [pim] Robert Wilton's Discuss on draft-ietf-pim-igmp-mld-snooping-yang-17: (with DISCUSS and COMMENT)
X-BeenThere: pim@ietf.org
X-Mailman-Version: 2.1.29
Precedence: list
List-Id: Protocol Independent Multicast <pim.ietf.org>
List-Unsubscribe: <https://www.ietf.org/mailman/options/pim>, <mailto:pim-request@ietf.org?subject=unsubscribe>
List-Archive: <https://mailarchive.ietf.org/arch/browse/pim/>
List-Post: <mailto:pim@ietf.org>
List-Help: <mailto:pim-request@ietf.org?subject=help>
List-Subscribe: <https://www.ietf.org/mailman/listinfo/pim>, <mailto:pim-request@ietf.org?subject=subscribe>
X-List-Received-Date: Tue, 14 Jul 2020 03:26:27 -0000

Hi Robert,

Thanks a lot for your comments.

In this YANG model, four of six groupings are common for both igmp snooping and mld snooping. 
If it is splitted into two separate YANG models, there will be a lot of duplicated contents.  Is it ok?   Thank you very much.



BR/Hongji

-----Original Message-----
From: Robert Wilton via Datatracker <noreply@ietf.org> 
Sent: Thursday, July 9, 2020 5:55 PM
To: The IESG <iesg@ietf.org>
Cc: draft-ietf-pim-igmp-mld-snooping-yang@ietf.org; pim-chairs@ietf.org; pim@ietf.org; Stig Venaas <stig@venaas.com>; aretana.ietf@gmail.com; stig@venaas.com
Subject: Robert Wilton's Discuss on draft-ietf-pim-igmp-mld-snooping-yang-17: (with DISCUSS and COMMENT)

Robert Wilton has entered the following ballot position for
draft-ietf-pim-igmp-mld-snooping-yang-17: Discuss

When responding, please keep the subject line intact and reply to all email addresses included in the To and CC lines. (Feel free to cut this introductory paragraph, however.)


Please refer to https://www.ietf.org/iesg/statement/discuss-criteria.html
for more information about IESG DISCUSS and COMMENT positions.


The document, along with other ballot positions, can be found here:
https://datatracker.ietf.org/doc/draft-ietf-pim-igmp-mld-snooping-yang/



----------------------------------------------------------------------
DISCUSS:
----------------------------------------------------------------------

Hi,

I appreciate that this YANG model has already passed a YANG doctor review, but this discuss is to understand the reasoning as to why both IGMP snooping and MLD snooping are in the same YANG module, yet have top level features to separate their functionality.

    4. IGMP and MLD Snooping YANG Module

      feature igmp-snooping {
        description
          "Support IGMP snooping.";
        reference
          "RFC 4541";
      }

      feature mld-snooping {
        description
          "Support MLD snooping.";
        reference
          "RFC 4541";
      }

It seems strange to me to have the entire YANG Model split under two separate feature statements. I believe that it would have been better to split this into two separate YANG models, both following the same structure.  Possibly, a common YANG module could have been used to share groupings and definitions, but even then duplicating the contents of the model so that the description statements could be correct/accurate would be more helpful.


----------------------------------------------------------------------
COMMENT:
----------------------------------------------------------------------

Thank you for your work on this document and YANG model.  I also have a few minor comments/suggestions that may improve the document and YANG module:

    2. Design of Data Model

    An IGMP/MLD snooping switch [RFC4541] analyzes IGMP/MLD packets and sets
    up forwarding tables for multicast traffic. If a switch does not run
    IGMP/MLD snooping, multicast traffic will be flooded in the broadcast
    domain. If a switch runs IGMP/MLD snooping, multicast traffic will be
    forwarded based on the forwarding tables to avoid wasting bandwidth. The
    IGMP/MLD snooping switch does not need to run any of the IGMP/MLD
    protocols. Because the IGMP/MLD snooping is independent of the IGMP/MLD
    protocols, the data model defined in this document does not augment, or
    even require, the IGMP/MLD data model defined in [RFC8652].
    The model covers considerations for Internet Group Management Protocol
    (IGMP) and Multicast Listener Discovery (MLD) Snooping Switches
    [RFC4541].

It wasn't clear to me what the final sentence was trying to say.  Perhaps it should be merged with the penultimate sentence in the paragraph?

    The YANG module includes IGMP and MLD Snooping instance definition,
    using instance in the scenario of BRIDGE [dot1Qcp] and L2VPN [draft-
    ietf-bess-l2vpn-yang]. The module also includes actions for clearing
    IGMP and MLD Snooping group tables.

I find the use of the terminology of "scenario of " to be somewhat strange.  I would probably have referred to these a "L2 forwarding pradigms" or "L2 forwarding instances".  If this terminology is changed then it would need to be fixed elsewhere in this document and the YANG model.

    On the other hand, operational state parameters are not so widely
    designated as features, as there are many cases where the defaulting
    of an operational state parameter would not cause any harm to the
    system, and it is much more likely that an implementation without
    native support for a piece of operational state would be able to derive
    a suitable value for a state variable that is not natively supported.

With NMDA, the server also has the option of not returning a value for a given item of operational data (RFC 8342, section 5,3, paragraph 4).  Although this doesn't conform to the data model, the semantics are well defined - i.e. the client cannot infer anything about the value that has not been returned.

    2.3. Position of Address Family in Hierarchy

    IGMP Snooping only supports IPv4, while MLD Snooping only supports IPv6.
    The data model defined in this document can be used for both IPv4 and
    IPv6 address families.

    This document defines IGMP Snooping and MLD Snooping as separate schema
    branches in the structure. The benefits are:

    *  The model can support IGMP Snooping (IPv4), MLD Snooping (IPv6), or
    both optionally and independently. Such flexibility cannot be achieved
    cleanly with a combined branch.

    *  The separate branches for IGMP Snooping and MLD Snooping can
    accommodate their differences better and cleaner. The two branches can
    better support different features and node types.

I would suggest rewording this first sentence to something like:

"Having separate branches for IGMP Snooping and MLD Snooping allows minor differences in their  behavior to be modelled more simply and cleanly".

    3. Module Structure

    A configuration data node is marked as mandatory only when its value
    must be provided by the user. Where nodes are not essential to protocol
    operation, they are marked as optional.  Some other nodes are essential
    but have a default specified, so that they are also optional and need
    not be configured explicitly.

This paragraph seems to just describe standard YANG modelling and can be removed.

    3.1. IGMP Snooping Instances

    The value of scenario in igmp-snooping-instance is bridge or l2vpn. When it
    is bridge, igmp-snooping-instance will be used in the BRIDGE

As per previous comments, this first sentence does not read well for me.

    The values of bridge-mrouter-interface, l2vpn-mrouter-interface-ac,
    l2vpn-mrouter-interface-pw are filled by the snooping device dynamically.
    They are different from static-bridge-mrouter-interface,
    static-l2vpn-mrouter-interface-ac, and static-l2vpn-mrouter-interface-pw
    which are configured

Ideally, these static nodes would not have been necessary, instead relying on the NMDA split between configuration and state, but that would probably require the default model to always allow them to be statically configured.  In NMDA, features can be implemented per-datastore but it is not clear how well that would work here.

      units one-tenth-second;

Perhaps "units deciseconds" would be better?

  grouping igmp-snooping-statistics {
    description
      "The statistics attributes for IGMP snooping.";

      leaf num-query {
        type yang:counter64;
        description
          "The number of Membership Query messages.";
        reference
          "RFC 2236";
      }

For these counters, rather than "num-XXX", I think that they would be better as "XXX-count", or if these relate to the number of packets "XXX-pkts" (as per RFC 8343).

           container statistics {
             description
               "The interface statistics for IGMP snooping";

             container received {
               description
                 "Statistics of received IGMP snooping packets.";

               uses igmp-snooping-statistics;
             }
             container sent {
               description
                 "Statistics of sent IGMP snooping packets.";

               uses igmp-snooping-statistics;
             }
           }

Should the descriptions for received and sent be for "snooped IGMP packets"? 
The equivalent MLD structure probably also needs a similar fix.