Initial import of Microsemi Driver

Change-Id: I431d5f2c18e0b66a84c36273c3d9f0b84f223841

Added in BUCK files for building driver

Change-Id: I70681327f5b89f67e904c45d5974ab393652d51f

Corrected some syntax errors

Change-Id: I11150cc499c212005f80619e3900e747f1c23d96

Updated pom file to clean build

Change-Id: I6613ddc9e6802aa882e716cf04df210249870835

Added in utility functions for EA1000 Init

Change-Id: I51ffe0cf0daf9ffcea0e2479ee9982fcd1755440

Added YMS code to Microsemi Driver

Change-Id: I6f2a14e454c6909bf9e9f6025321c74c98c13c72

Updated driver to work with YMS and YCH

Change-Id: If7dbe3cd5bd1b6f902d09d6b2dc3895605d70f70

Implemented IetfSystemManager as a service and call on YMS as a service

Change-Id: If1c5e8482b1f53f578a3b0b770accd50024111cf

Moved YMS calls over in to Yang Service implementation

Change-Id: I044aad06f1ef7452bc48e88987787a683666cd72

improved unit test for IetfSystemManager

Change-Id: I48fbf831e7e5ca0e1ef3de8288e56da1b5ebb7a4

Major changes to IetfSystemManager to work in live system

Change-Id: I6e3aa118ba422151f314b9a666860d90905c9929

Added in retry mechanism for DeviceDescription to wait for YCH

Change-Id: If8e0f2c2f315ffd6db15627a11382a00217dd262

Added in implementation of MseaSaFiltering and unit tests

Change-Id: I34bf888e0e732bd4664d1fb8ef5abb679b1506fe

Updated driver with unit tests for MseaSaFiltering

Change-Id: I7ea2407a546622ff55d1ab21610c45697546d632

Modified removeFlowRules of Ea1000FlowRuleProgrammable

Change-Id: Ibb4a555f61887a8e6e42af588bb42f7b70f58efb

Added in manager for MseaUniEvc service with unit tests

Change-Id: Idc5853f46051548973f52a0659f7f88982ff960c

Implemented getFlowEntries() for EVCs from EA1000

Change-Id: Ie85dadfa7760f0b30a9bdf6ccd09cca9f097fff9

Added in translation of FlowRules in to EVC on EA1000

Change-Id: Icfb65171c3300c96b3ca4e18cbd327f0ed2190be

Added in handling of FlowRule deletion including complex ceVlanMaps

Change-Id: I7fd0bb0ef04d1b40e4b7d6a6db7f7ee662329780

Updated Service entries for new onos-yang-tools

Change-Id: I44e655202f3a45073e1e16f83737caed6e01afa8

Revert "Updated Service entries for new onos-yang-tools"

This reverts commit 642b550ef1de12ed59bad2eaa3a2da414d2e5e59.

Improved timeout mechanism for YANG model loading

Change-Id: If744ecd206372e822edf2b736c83226321a12256

Minor edits of EVC creation

Change-Id: Ib0a4763deaf6dce37625ba77f5095b39cd98272d

Added in CustomEvc and supporting classes

Change-Id: Iad60eb1bcd48d2aec55b894b2d419b51852c3b2f

Created CeVlanUtils to resolve loading problem

Change-Id: I0d63931ad2c5ad2725861ebc7dccc4d5fe7b9298

Modified startup check

Change-Id: I6e6bcfa7e615044cb08fe7ee2f8a6c8b89aabb21

Modified handlin of flow rules

Change-Id: I965a79c23298866122aeb94c6d9d584aafee3bd5

Fixed problem with ceVlanMap

Change-Id: If1458c35d0b95b5b25b6636f098292f9e91c06c6

Minor Pom edits

Change-Id: I5cefb18674aa04b1f50bd7e2306260c1c3ad3814

Commented out extension references in YANG files to avoid onos-yang-tools problems

Change-Id: I32fdb34c4f476f495fe28e75d0f410aaf14e2ec1

Corrected error in removing 0 in CeVlanMapUtils

Change-Id: I8cd1fd02788b81c2613364d5639ef6e090057f80

Changes in YMS to accomodate EA1000 driver

Change-Id: I6ae2b9bd2be49eae8d4ad2f929dfe3214c514550
diff --git a/drivers/microsemi/ea1000yang/src/main/yang/msea-sa-filtering.yang b/drivers/microsemi/ea1000yang/src/main/yang/msea-sa-filtering.yang
new file mode 100644
index 0000000..72534a9
--- /dev/null
+++ b/drivers/microsemi/ea1000yang/src/main/yang/msea-sa-filtering.yang
@@ -0,0 +1,149 @@
+module msea-sa-filtering {
+
+    /*** NAMESPACE / PREFIX DEFINITION ***/
+
+    namespace "http://www.microsemi.com/microsemi-edge-assure/msea-sa-filtering";
+    prefix "msea-saf";
+
+    import ietf-inet-types {
+        prefix inet;
+        revision-date 2013-07-15;
+    }
+
+    import msea-types {
+        prefix msea;
+        revision-date 2016-02-29;
+    }
+
+    /*** META INFORMATION ***/
+
+    organization
+    "Microsemi Inc., FTD Division";
+
+    contact
+    "Web URL: http://www.microsemi.com/
+    E-mail: info@microsemi.com
+    Postal: Microsemi Corporation Corporate Headquarters
+    One Enterprise Aliso Viejo,
+    CA 92656
+    U.S.A.
+    Phone: +1 949 380 6100
+    Fax: +1 949 215-4996";
+
+    description
+    "This YANG module add Source Address Filtering for IPv4 packets to
+    the Optics(eth0) port (only) of the Edge Assure device.
+
+    Copyright 2016 Microsemi Inc.
+    All rights reserved.";
+
+    revision "2016-04-12" {
+        description
+        "Initial version - Sean Condon, Microsemi";
+    }
+
+
+    container source-ipaddress-filtering {
+        presence "Supports IPv4 Source Address Filtering";
+
+        container interface-eth0 {
+
+            leaf filter-admin-state {
+                type enumeration {
+                    enum inactive {
+                        description "Source address filtering is inactive";
+                    }
+                    enum whitelist {
+                        description "Only IPv4 packets from the source
+                        address ranges are allowed in to the device on the
+                        Optics(eth0) port. All non IPv4 packets are not
+                        filtered by this whitelist";
+                    }
+                    enum blacklist {
+                        description "All IPv4 packets from the source 
+                        address ranges are blocked from entering the device 
+                        on the Optics(eth0) port. All other packets are not
+                        filtered by this blacklist";
+                    }
+                }
+                default inactive;
+                description "This attribute sets the address range to be used as
+                either a whitelist or a blacklist of IPv4 packets.
+                When activating the filter the user should be careful not to
+                block or exclude the management IP address of the manager";
+            }
+
+            list source-address-range {
+                key range-id;
+                max-elements 10;
+                unique ipv4-address-prefix;
+                unique name;
+
+                leaf range-id {
+                    type uint8 {
+                        range "1..10";
+                    }
+                }
+
+                leaf name {
+                    type string{
+                        length "1..45";
+                    }
+                    description "An optional name for the filter range";
+                }
+
+                leaf ipv4-address-prefix {
+                    type string {
+                      pattern
+                         '(([0-9]|[1-9][0-9]|1[0-9][0-9]|2[0-4][0-9]|25[0-5])\.){3}'
+                       +  '([0-9]|[1-9][0-9]|1[0-9][0-9]|2[0-4][0-9]|25[0-5])'
+                       + '/(([1-9])|(1[0-9])|(2[0-7]))';
+                    }
+
+                    mandatory true;
+//                    msea:not-changeable;
+
+                    description
+                     "The ipv4-address-prefix type represents an IPv4 address prefix
+                      in CIDR notation format. e.g. a.b.c.d/n
+
+                      It consists of an address part and a mask length part.
+                      The address part is only used up to the number of bits
+                      specified in the length (1-27, given after the slash).
+
+                      For example the value 10.10.159.211/20 will mean an
+                      effective range from 10.10.144.0 - 10.10.159.255 and
+                      a count of 2^12 = 4096. The last 12 bits (32-20=12)
+                      of the address is ignored because it is not within the
+                      mask length.";
+                }
+
+
+                container effective-address-range {
+                    config false;
+
+                    leaf start-of-range {
+                        type inet:ipv4-address-no-zone;
+                        description "The calculated start of the address range";
+                    }
+
+                    leaf end-of-range {
+                        type inet:ipv4-address-no-zone;
+                        description "The calculated end of the address range";
+                    }
+
+                    leaf count {
+                        type uint32;
+                        description "The number of IPv4 addresses that match the filter";
+                    }
+
+                    description "The effective start and end addresses calculated
+                    from the ipv4-address-prefix";
+                }
+
+                description "A set of address ranges to be either blacklisted or
+                whitelisted on ingress to the eth0(Optics) port of the device";
+            }
+        }
+    }
+}
\ No newline at end of file