Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp6865281imu; Wed, 14 Nov 2018 08:07:06 -0800 (PST) X-Google-Smtp-Source: AJdET5dS3pg8f/x1w2sXYdRMnQ/xHQhA2eRkfSteq8bvZMM4xfJ+bc5EmuxlVaxAFVp/R/jgm5xR X-Received: by 2002:a17:902:e089:: with SMTP id cb9-v6mr2442952plb.196.1542211626517; Wed, 14 Nov 2018 08:07:06 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1542211626; cv=none; d=google.com; s=arc-20160816; b=o13i65iny9NrRKCn88uvO595N4dvjXcoHcdii7gDUspxcV8Wx9zkyj+DXpbzotro0S JOqMROavb56ve93Riy6d7cMjumQykGroULTPUTc1LFFGYeYpSXWeaRLEdVmLDDeCNBfK FbLUTdxoSIy4I6U2A8JM7acbyJSWdLRJFOj64HKaU49JLrJPr5UbMqbeHypAZvYYcxyl bidkrD1Ez/lS0unglK2ithpCFWx6L96BH1+h1qIlzadkiK6H4L2KF00maAwNG+AElGR0 R5FJcntxRMuv5ek82iTHG8aRBVNuE9v0z64aJolPCywVAC4FziInnrF1NZFq1uta34/9 w5Pg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=7NlOcQS1CVYAxETpCLLRykD6JVs/z/XSS1hZoJW810k=; b=KEUVzvvoJWE+WaSWY98tRNOGUPIS57rnarTKk7dZMCce9TB39cvqJsCSUcnxbo5m73 YZkmvnuc4uYqgcrtcgyp5ZvO3sSsITnq3FFqwnigXQdp/27egxqf39PONKIvB7jaF7Vn SmWFz/9RvswaLEVUUWSQq9PKfgZcCviA+cQ0UiClTV5GBQ0teN5eyVqy7rbEQwNdfokQ 0Tz6QyUTfoJhTTvcRYMpEnjz6IcCAC6n0R5B6lgq0FvSuby6CK9PAlmqLjNV8iPX5tpC TiKRQX8O4qXNXWGG+eMqMaBwk6bcAiG1fDI+89CdjyLlm7ERS7yUvuRh/qtbK/UbDn67 mN+w== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@g.ncu.edu.tw header.s=google header.b=JMgJeJqd; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id a3-v6si24056202plp.323.2018.11.14.08.06.46; Wed, 14 Nov 2018 08:07:06 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@g.ncu.edu.tw header.s=google header.b=JMgJeJqd; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2387749AbeKOCHU (ORCPT + 99 others); Wed, 14 Nov 2018 21:07:20 -0500 Received: from mail-pl1-f195.google.com ([209.85.214.195]:37828 "EHLO mail-pl1-f195.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2387676AbeKOCHT (ORCPT ); Wed, 14 Nov 2018 21:07:19 -0500 Received: by mail-pl1-f195.google.com with SMTP id b5so1575497plr.4 for ; Wed, 14 Nov 2018 08:03:30 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=g.ncu.edu.tw; s=google; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=7NlOcQS1CVYAxETpCLLRykD6JVs/z/XSS1hZoJW810k=; b=JMgJeJqdUpopiQmpcleJDdwDA+1w6Ag6VS9X03nyaaK66vSQhfZhrk7yFYL93dggk5 WwBHkPJFEI5x4+Xs2DkPMVdHGPO8HyLY+My9Y5arDRw/VGIfuhodPBEmntutyTbLzCf+ Dp8tkbRJIjIwfTXGgLGehXs2hOy65zOYIFDB0= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references:mime-version:content-transfer-encoding; bh=7NlOcQS1CVYAxETpCLLRykD6JVs/z/XSS1hZoJW810k=; b=P69WHANsWtWCYrrA3aYU92PG1S+OpfDF6TwLj0ug960UMfOpuJGAU/WAzC1umBGkg3 NquIWXk7FCgFpOVLxi8wRh0Z9R27grYVyOEvobxmPCpUi+fX2luXYx17dy/13c22Mvhi 9etSUyZxccG2mbH866SOzPqTzT2OF8sE4gcoOol82FjXtPa43W/r7oJN+5975rtq64Ju vr9vg5w05/S/3bPDxye7FtBOM/1BYkpJ5H1Piht7djQlQ78VtNcN7wEQM3+tBXL5yWLt CBm8NmECgCVtK+dWUW9mfS0rvJetPkjXFWxSfwWrQ8rWe1YDxjZX7V2FHmmJdj7F0aho Mpwg== X-Gm-Message-State: AGRZ1gIkdu8CjRjOoVe8Cd69k4p/qp6WD/5ozTOlR395hWykEi2K7ic2 S0AlfK6sK9qICjsU433nRDFPLg== X-Received: by 2002:a17:902:f08f:: with SMTP id go15mr2513873plb.332.1542211410150; Wed, 14 Nov 2018 08:03:30 -0800 (PST) Received: from starnight.local ([150.116.248.145]) by smtp.gmail.com with ESMTPSA id s2-v6sm53449854pfk.133.2018.11.14.08.03.27 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Wed, 14 Nov 2018 08:03:29 -0800 (PST) From: Jian-Hong Pan To: =?UTF-8?q?Andreas=20F=C3=A4rber?= , "David S . Miller" Cc: netdev@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org, Marcel Holtmann , Dollar Chen , Ken Yu , linux-wpan@vger.kernel.org, Stefan Schmidt , Jian-Hong Pan Subject: [PATCH V3 4/7] net: maclorawan: Add maclorawan module declaration Date: Thu, 15 Nov 2018 00:01:25 +0800 Message-Id: <20181114160126.4445-5-starnight@g.ncu.edu.tw> X-Mailer: git-send-email 2.19.1 In-Reply-To: <20181105.101610.1437737564548154497.davem@davemloft.net> References: <20181105.101610.1437737564548154497.davem@davemloft.net> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Add the maclorawan header file for common APIs in the module. Signed-off-by: Jian-Hong Pan --- V2: - Split the LoRaWAN class module patch in V1 into LoRaWAN socket and LoRaWAN Soft MAC modules - Use SPDX license identifiers net/maclorawan/maclorawan.h | 199 ++++++++++++++++++++++++++++++++++++ 1 file changed, 199 insertions(+) create mode 100644 net/maclorawan/maclorawan.h diff --git a/net/maclorawan/maclorawan.h b/net/maclorawan/maclorawan.h new file mode 100644 index 000000000000..66b87f051d51 --- /dev/null +++ b/net/maclorawan/maclorawan.h @@ -0,0 +1,199 @@ +/* SPDX-License-Identifier: GPL-2.0-or-later OR BSD-3-Clause */ +/*- + * LoRaWAN soft MAC + * + * Copyright (c) 2018 Jian-Hong, Pan + * + */ + +#ifndef __MAC_LORAWAN_H__ +#define __MAC_LORAWAN_H__ + +#include +#include +#include +#include +#include +#include +#include +#include +#include + +#define LORAWAN_MODULE_NAME "maclorawan" + +/* List the message types of LoRaWAN */ +enum { + LRW_JOIN_REQUEST, + LRW_JOIN_ACCEPT, + LRW_UNCONFIRMED_DATA_UP, + LRW_UNCONFIRMED_DATA_DOWN, + LRW_CONFIRMED_DATA_UP, + LRW_CONFIRMED_DATA_DOWN, + LRW_RFU, + LRW_PROPRIETARY, +}; + +/* List the communication directions */ +enum { + LRW_UPLINK, + LRW_DOWNLINK, +}; + +/* States of LoRaWAN slot timing */ +enum { + LRW_INIT_SS, + LRW_XMITTING_SS, + LRW_XMITTED, + LRW_RX1_SS, + LRW_RX2_SS, + LRW_RXTIMEOUT_SS, + LRW_RXRECEIVED_SS, + LRW_RETRANSMIT_SS, +}; + +#define LRW_MHDR_LEN 1 +#define LRW_FHDR_MAX_LEN 22 +#define LRW_FOPS_MAX_LEN 15 +#define LRW_FPORT_LEN 1 +#define LRW_MIC_LEN 4 + +/** + * lrw_fhdr - Hold the message's basic information of the frame + * + * @mtype: this message's type + * @fctrl: the frame control byte + * @fcnt: this message's frame counter value + * @fopts: this frame's options field + * @fopts_len: the length of the fopts + */ +struct lrw_fhdr { + u8 mtype; + u8 fctrl; + u16 fcnt; + u8 fopts[LRW_FPORT_LEN]; + u8 fopts_len; +}; + +/** + * lrw_session - LoRaWAN session for Class A end device + * + * @lrw_st: points to the belonging lrw_st + * @entry: the entry of the ss_list in lrw_struct + * @devaddr: the LoRaWAN device address of this LoRaWAN hardware + * @fcnt_up: uplink frame counter + * @fcnt_down: downlink frame counter + * @fport: the LoRaWAN data message's port field + * @tx_skb: points to the TX skb, the frame + * @rx_skb: points to the RX skb, the frame + * @tx_fhdr: hold the message's basic information of the TX frame + * @rx_fhdr: hold the message's basic information of the RX frame + * @tx_should_ack: flag for determining the TX which should be acked or not + * @retry: retry times for xmitting failed + * @state: this session's current state + * @state_lock: lock of the session's state + * @timer: timing for this session and the state transition + * @timeout_work: work if waiting acknowledge time out + * @rx_delay1: RX1 delay time in seconds + * @rx_delay2: RX2 delay time in seconds + * @rx1_window: RX1 window opening time in mini-seconds + * @rx2_window: RX2 window opening time in mini-seconds + * @ack_timeout: time out time for waiting acknowledge in seconds + */ +struct lrw_session { + struct lrw_struct *lrw_st; + struct list_head entry; + + u32 devaddr; + u16 fcnt_up; + u16 fcnt_down; + u8 fport; + struct sk_buff *tx_skb; + struct sk_buff *rx_skb; + struct lrw_fhdr tx_fhdr; + struct lrw_fhdr rx_fhdr; + + bool tx_should_ack; + u8 retry; + u8 state; + spinlock_t state_lock; + + struct timer_list timer; + struct work_struct timeout_work; + unsigned long rx_delay1; + unsigned long rx_delay2; + unsigned long rx1_window; + unsigned long rx2_window; + unsigned long ack_timeout; +}; + +/** + * lrw_struct - The full LoRaWAN hardware to the LoRa device. + * + * @dev: this LoRa device registed in system + * @hw: the LoRa device of this LoRaWAN hardware + * @ops: handle of LoRa operations interfaces + * @rx_skb_list: the list of received frames + * @ss_list: LoRaWAN session list of this LoRaWAN hardware + * @_cur_ss: pointer of the current processing session + * @rx_should_ack: represent the current session should be acked or not + * @state: the state of this LoRaWAN hardware + * @app_eui: the LoRaWAN application EUI + * @dev_eui: the LoRaWAN device EUI + * @devaddr: the LoRaWAN device address of this LoRaWAN hardware + * @appky: the Application key + * @nwkskey: the Network session key + * @appskey: the Application session key + * @nwks_shash_tfm: the hash handler for LoRaWAN network session + * @nwks_skc_tfm: the crypto handler for LoRaWAN network session + * @apps_skc_tfm: the crypto handler for LoRaWAN application session + * @fcnt_up: the counter of this LoRaWAN hardware's up frame + * @fcnt_down: the counter of this LoRaWAN hardware's down frame + * @xmit_task: the xmit task for the current LoRaWAN session + * @rx_work: the RX work in workqueue for the current LoRaWAN session + * @ndev: points to the emulating network device + * @_net: the current network namespace of this LoRaWAN hardware + */ +struct lrw_struct { + struct device dev; + struct lrw_hw hw; + struct lrw_operations *ops; + + struct sk_buff_head rx_skb_list; + struct list_head ss_list; + struct mutex ss_list_lock; + struct lrw_session *_cur_ss; + bool rx_should_ack; + u8 state; + + u64 app_eui; + u64 dev_eui; + u32 devaddr; + u8 appkey[LRW_KEY_LEN]; + u8 nwkskey[LRW_KEY_LEN]; + u8 appskey[LRW_KEY_LEN]; + struct crypto_shash *nwks_shash_tfm; + struct crypto_skcipher *nwks_skc_tfm; + struct crypto_skcipher *apps_skc_tfm; + + u16 fcnt_up; + u16 fcnt_down; + + struct tasklet_struct xmit_task; + struct work_struct rx_work; + + struct net_device *ndev; + possible_net_t _net; +}; + +#define NETDEV_2_LRW(ndev) ((struct lrw_struct *)netdev_priv(ndev)) + +struct lrw_session * lrw_alloc_ss(struct lrw_struct *); +void lrw_free_ss(struct lrw_session *); +void lrw_del_ss(struct lrw_session *); +int lrw_start_hw(struct lrw_struct *); +void lrw_stop_hw(struct lrw_struct *); +void lrw_prepare_tx_frame(struct lrw_session *); +void lrw_xmit(unsigned long); +void lrw_rx_work(struct work_struct *); + +#endif -- 2.19.1