net: ieee802154: Fill the list of MLME return codes
authorMiquel Raynal <miquel.raynal@bootlin.com>
Thu, 7 Apr 2022 10:08:55 +0000 (12:08 +0200)
committerStefan Schmidt <stefan@datenfreihafen.org>
Mon, 25 Apr 2022 18:51:12 +0000 (20:51 +0200)
There are more codes than already listed, let's be a bit more
exhaustive. This will allow to drop device drivers local definitions of
these codes.

Signed-off-by: Miquel Raynal <miquel.raynal@bootlin.com>
Acked-by: Alexander Aring <aahringo@redhat.com>
Link: https://lore.kernel.org/r/20220407100903.1695973-3-miquel.raynal@bootlin.com
Signed-off-by: Stefan Schmidt <stefan@datenfreihafen.org>
include/linux/ieee802154.h

index 01d945c..f1f9412 100644 (file)
@@ -134,7 +134,35 @@ enum {
         * a successful transmission.
         */
        IEEE802154_SUCCESS = 0x0,
-
+       /* The requested operation failed. */
+       IEEE802154_MAC_ERROR = 0x1,
+       /* The requested operation has been cancelled. */
+       IEEE802154_CANCELLED = 0x2,
+       /*
+        * Device is ready to poll the coordinator for data in a non beacon
+        * enabled PAN.
+        */
+       IEEE802154_READY_FOR_POLL = 0x3,
+       /* Wrong frame counter. */
+       IEEE802154_COUNTER_ERROR = 0xdb,
+       /*
+        * The frame does not conforms to the incoming key usage policy checking
+        * procedure.
+        */
+       IEEE802154_IMPROPER_KEY_TYPE = 0xdc,
+       /*
+        * The frame does not conforms to the incoming security level usage
+        * policy checking procedure.
+        */
+       IEEE802154_IMPROPER_SECURITY_LEVEL = 0xdd,
+       /* Secured frame received with an empty Frame Version field. */
+       IEEE802154_UNSUPPORTED_LEGACY = 0xde,
+       /*
+        * A secured frame is received or must be sent but security is not
+        * enabled in the device. Or, the Auxiliary Security Header has security
+        * level of zero in it.
+        */
+       IEEE802154_UNSUPPORTED_SECURITY = 0xdf,
        /* The beacon was lost following a synchronization request. */
        IEEE802154_BEACON_LOST = 0xe0,
        /*
@@ -204,11 +232,48 @@ enum {
         * that is not supported.
         */
        IEEE802154_UNSUPPORTED_ATTRIBUTE = 0xf4,
+       /* Missing source or destination address or address mode. */
+       IEEE802154_INVALID_ADDRESS = 0xf5,
+       /*
+        * MLME asked to turn the receiver on, but the on time duration is too
+        * big compared to the macBeaconOrder.
+        */
+       IEEE802154_ON_TIME_TOO_LONG = 0xf6,
+       /*
+        * MLME asaked to turn the receiver on, but the request was delayed for
+        * too long before getting processed.
+        */
+       IEEE802154_PAST_TIME = 0xf7,
+       /*
+        * The StartTime parameter is nonzero, and the MLME is not currently
+        * tracking the beacon of the coordinator through which it is
+        * associated.
+        */
+       IEEE802154_TRACKING_OFF = 0xf8,
+       /*
+        * The index inside the hierarchical values in PIBAttribute is out of
+        * range.
+        */
+       IEEE802154_INVALID_INDEX = 0xf9,
+       /*
+        * The number of PAN descriptors discovered during a scan has been
+        * reached.
+        */
+       IEEE802154_LIMIT_REACHED = 0xfa,
+       /*
+        * The PIBAttribute parameter specifies an attribute that is a read-only
+        * attribute.
+        */
+       IEEE802154_READ_ONLY = 0xfb,
        /*
         * A request to perform a scan operation failed because the MLME was
         * in the process of performing a previously initiated scan operation.
         */
        IEEE802154_SCAN_IN_PROGRESS = 0xfc,
+       /* The outgoing superframe overlaps the incoming superframe. */
+       IEEE802154_SUPERFRAME_OVERLAP = 0xfd,
+       /* Any other error situation. */
+       IEEE802154_SYSTEM_ERROR = 0xff,
 };
 
 /* frame control handling */