The present subject matter relates generally to communication networks, and more particularly, to natively integrating blockchain technologies in the context of managing data sessions for User Equipment (UE) in telecommunication networks (e.g., 4G, 5G, etc.)
An ever-increasing consumer demand, improved technological advancements (e.g., hardware/software infrastructure), and industry collaboration has driven significant growth in modern telecommunication networks and continues to drive its evolution. Indeed, each iteration or “next generation” of network capabilities, e.g., represented by standards promulgated by a Third Generation Partnership Project (3GPP), interconnects more devices, improves network bandwidth, increases data-rates, and so on. For example, a transition from 3rd Generation (3G) networks to 4th Generation (4G) networks introduced new network services and connected mobile devices to third party data networks such as the Internet. More recently, a transition is underway from existing 4G networks to new 5G networks, which includes a new service-oriented architecture for provisioning network services/resources in a dynamic, scalable, and customizable fashion (e.g., micro-services, network functions virtualization (NFV), etc.). For example, this service-oriented architecture supports network slices, which employ an isolated set of programmable resources that can implement individual network functions and/or application services through software programs within a respective network slice, without interfering with other functions and services on coexisting network slices. In turn, the service-oriented architecture, including its network slice support, creates opportunities to employ new mechanisms that natively support such dynamic and flexible workload provisioning and improve overall UE mobility.
The embodiments herein may be better understood by referring to the following description in conjunction with the accompanying drawings in which like reference numerals indicate identical or functionally similar elements. Understanding that these drawings depict only exemplary embodiments of the disclosure and are not therefore to be considered to be limiting of its scope, the principles herein are described and explained with additional specificity and detail through the use of the accompanying drawings in which:
that invokes an Access and Mobility Management Function (AMF) entity;
This disclosure describes techniques for managing data sessions (e.g., establishing, hand-over, modify, etc.) for User Equipment (UE) in a telecommunication network (e.g., 4G/5G networks, etc.) using a natively integrated blockchain platform. For example, according to one or more embodiments of this disclosure, a network function (NF) entity in a communication network receives session request data associated with a User Equipment (UE), which includes blockchain authentication data. The NF entity selects a Blockchain Authentication Function (BAF) entity based on the session request data, and exchanges at least a portion of the blockchain authentication data with the BAF entity over a blockchain network interface. The NF entity further receives authentication confirmation data from the BAF entity over the blockchain network interface, and establishes a data session associated with the UE based on the authentication confirmation data.
Various embodiments of the disclosure are discussed in detail below. While specific implementations are described in detail, it should be understood that this is done for illustration purposes only. A person skilled in the relevant art will recognize that other components and configurations may be used without departing from the spirit and scope of the disclosure.
As provided herein, this disclosure relates to communication networks (e.g., telecommunication networks), which include a number of network devices/modules/entities or “Network Function(s)” (NF(s)), which can be implemented as a network element on a dedicated hardware, as a software instance running on a dedicated hardware, and/or as a virtualized function instantiated on an appropriate platform (e.g. on a cloud infrastructure), as is appreciated by those skilled in the art. For sake of clarity, the NFs described herein are based on NFs specified by existing Technical Specifications such as the 3GPP TS 23.501, TS 23.502, TS 24.501, TS 29.509, TS 29.518, TS 33.301, TS 33.501, each of which is incorporated herein by reference to its entirety. Moreover, while some operations and functionality may be described and/or attributed to a particular NF, it is appreciated that such operations are not intended to be limited to the particular NF, but may be performed by other NFs as appropriate, particularly in view of the ongoing development and evolving nature of telecommunication networks.
A communication network is a geographically distributed collection of nodes interconnected by communication links and segments for transporting data between end nodes, such as mobile devices, computers, personal computing devices (and so on), and other devices, such as network entities, sensors, etc. Many types of networks are available, ranging from local area networks (LANs) to wide area networks (WANs). LANs typically connect these nodes over dedicated private communications links located in the same general physical location, such as a building or campus. WANs, on the other hand, typically connect geographically dispersed nodes over long-distance communications links, such as common carrier telephone lines, optical lightpaths, synchronous optical networks (SONET), synchronous digital hierarchy (SDH) links, etc. Some communication networks can include telecommunication networks, which transport data between end nodes, such as user equipment (UE), which can include mobile devices.
Those skilled in the art will understand that any number of nodes, devices, communication links, and the like may be used, and that the view shown herein is for simplicity. In particular, the representations of telecommunication networks 100, including respective interconnected network entities, are illustrated and described herein for purposes of discussion, not limitation, and it is appreciated that the illustrated networks can support inter-network operability/compatibility, and can include (or exclude) any number of network entities, communication links, and the like.
Access network 150 represents the infrastructure or radio towers, such as a Radio Access Network (RAN), for receiving and transmitting data packets between end user nodes (UE) as well as the various network entities (e.g., core network entities). Access network 150 includes NodeBs (NBs) for 3G network 110, eNodeBs (eNBs) for 4G network 120, and gNodeBs (gNBs) for 5G network 130. The infrastructure for each network may support different functionality and it is appreciated that infrastructure illustrated within one network can include appropriate hardware/software to support functionality of other telecommunication networks.
Respective network entities that form core network 160 (within the telecommunication networks 100) operatively connect respective RAN infrastructure (NBs, eNBs, gNBs) to third party networks such as a voice network 105 (e.g., a Public Switched Telephone Network (PSTN) network) and/or a data network (DN) 108 to create end-to-end connections. Prior to 3G (e.g., 2G, 2.5G, etc.) the third party network primarily included a voice network/PSTN 105 (e.g., a circuit switched network). From 3G onward, the third party network transitioned to include a public network (e.g., the Internet), represented by data network 108 (e.g., a packet switched network). Core network 160 and its respective network entities collectively operate to manage connections, bandwidth, and mobility for respective UE.
Notably, core network 160 evolved along three functional planes, including service management, session management, and mobility management. Service management for 2G and 3G networks includes operations to create an Integrated Services Digital Network (ISDN) over wireless links (e.g., Uu links). Session management for 3G and 4G networks generally include operations establish, maintain, and release network resources (e.g., data connections). In particular, in 3G network 110, session management includes a standalone General Packet Radio Service (GPRS) network, while 4G network 120 introduced a fully integrated data only network optimized for mobile broadband (where basic telephone operations are supported as one profile). Mobility management generally includes operations that support movement of UE in a mobile network, such as system registration, location tracking and handover (e.g., often optimized reduce heavy signaling loads). For example, in the context of 4G network 120, a Serving Gateway (SGW) and a Packet Data Gateway (PGW) support session management operations while mobility management operations (which maintains data sessions for mobile UE) are centralized within a Mobility Management Entity (MME).
5G network 130, as discussed in greater detail herein, introduces a new service base architecture (SBA) 132, which generally redistributes functionality of 4G network entities into smaller service-based functions/network entities. In addition, packet routing and forwarding functions (which are performed by SGW and PGW in 4G network 120) are realized as services rendered through a new network function/entity called the User Plane Function (UPF) entity. In this fashion, 5G network 130 provides a modular set of services that support dynamic and scalable deployment of resources to satisfy diverse user demands.
The illustrative device/entity 200 comprises one or more network interfaces 210, at least one processor 220, and a memory 240 interconnected by a system bus 250. Network interface(s) 210 contain the mechanical, electrical, and signaling circuitry for communicating data over links (e.g., wires or wireless links) within the telecommunication networks 100 (e.g., ref.
Memory 240 comprises a plurality of storage locations that are addressable by processor 220 for storing software programs and data structures associated with the embodiments described herein. Processor 220 may comprise necessary elements or logic adapted to execute the software programs and manipulate data structures 245. An operating system 242, portions of which are typically resident in memory 240 and executed by processor 220, functionally organizes the device by, inter alia, invoking operations in support of services and/or software processes executing on the device/module. These services and/or software processes may comprise an illustrative “blockchain registration” process/service 244 as well as a “blockchain session management” process/services 246, as described herein. Note that while processes/services 244 and 246 are shown in centralized memory 240, some embodiments provide for these processes/services to be operated in a distributed communication network.
Illustratively, the techniques described herein may be performed by hardware, software, and/or firmware, such as in accordance with the illustrative blockchain authentication process 244 and/or the illustrative blockchain session management process 246, which may contain computer executable instructions executed by processor 220 to perform functions relating to UE authentication and/or UE session establishment, as described herein.
It will be apparent to those skilled in the art that other processor and memory types, including various computer-readable media, may be used to store and execute program instructions pertaining to the techniques described herein. Also, while the description illustrates various processes, it is expressly contemplated that various processes may be embodied as modules configured to operate in accordance with the techniques herein (e.g., according to the functionality of a similar process). Further, while the processes have been shown separately, those skilled in the art will appreciate that processes may be routines or modules within other processes. For example, processor 220 can include one or more programmable processors, e.g., microprocessors or microcontrollers, or fixed-logic processors. In the case of a programmable processor, any associated memory, e.g., memory 240, may be any type of tangible processor readable memory, e.g., random access, read-only, etc., that is encoded with or stores instructions that can implement program modules, e.g., a module having blockchain registration process 244 and/or blockchain session management process 246 encoded thereon. Processor 220 can also include a fixed-logic processing device, such as an application specific integrated circuit (ASIC) or a digital signal processor that is configured with firmware comprised of instructions or logic that can cause the processor to perform the functions described herein. Thus, program modules may be encoded in one or more tangible computer readable storage media for execution, such as with fixed logic or programmable logic, e.g., software/computer instructions executed by a processor, and any processor may be a programmable processor, programmable digital logic, e.g., field programmable gate array, or an ASIC that comprises fixed digital logic, or a combination thereof. In general, any process logic may be embodied in a processor or computer readable medium that is encoded with instructions for execution by the processor that, when executed by the processor, are operable to cause the processor to perform the functions described herein.
As noted above, a transition is currently underway from existing 4G networks to 5G networks, which introduces a new service-oriented architecture (e.g., SBA 132—
In order to provision network resources, whether over existing 3G/4G networks or via the new SBA for 5G networks, the UE typically registers or authenticates with the network and further establishes a data session (which describes charging, billing, QoS, etc.) Sessions are typically managed as part of a connectivity service (e.g., PDU Connectivity Service), which defines rules for exchanging data packets (e.g., Protocol Data Units (PDUs)) between the UE and a data network. In the context of 5G networks, each session is typically associated with a respective network slice (e.g., one session belongs to one slice). This disclosure provides complimentary and/or alternative mechanisms such as blockchain registration processes as well as blockchain session management processes to enhance dynamic and flexible workload provisioning, session establishment, and improve overall UE mobility with a natively integrated blockchain platform.
With respect to blockchain, blockchain technologies generally facilitate transparent, verifiable, and secure digital asset transactions with proof of rights and ownership. For example, blockchain technologies generally employ distributed ledger technology (DLT) with built-in cryptography to enable open and trusted exchanges over the internet without requiring central servers and/or independent trusted authorities. However, despite its advantages, existing protocols/network architectures in the telecommunications context fail to support native blockchain technologies due, in part, to underlying security requirements for initial registration processes. For example, while some blockchain technologies can be employed within existing telecommunication networks, mobile network operators and/or mobile network entities are often unaware of any blockchain transaction because such blockchain transaction only occurs after a mobile session is established (e.g., using overlay messages).
Accordingly, embodiments of this disclosure provide a native blockchain platform that employs blockchain operations that can serve as additional, alternative, or supplemental registration processes and/or session management processes within a mobile network. Moreover, the disclosed blockchain processes can operate in conjunction with various mobile Network Functions (NFs) or other network entities (including UE) over new blockchain network interfaces, satisfy security requirements for network service providers, and provide access to new types of devices/users. The native blockchain platform and the blockchain processes of this disclosure support device registration and/or session management in the context of local networks (e.g., the UE is connected to its local/home network) as well as roaming networks (e.g., the UE is outside of its local/home network and attempts to connect to a roaming/visiting network).
Referring again to the figures,
The blockchain interfaces represent communication links that facilitate an exchange of messages or data packets between BAF(s) and SBA 132 (e.g., one or more NFs that form SBA 132). In particular, BCx can facilitate exchanging messages related to policy request, authorization, network usage, lawful intercept, accounting, and the like. BCy can facilitate exchanging messages related to secondary authentication, authorization, resource sharing, lawful intercept, network slicing, etc. BCz can facilitate exchanging messages related to standalone Authentication public key pre-set, authorization, Distributed Ledger Technology query/set, etc.
Blockchain network 304 generally facilitates sharing network resources or access to network functions (NFs), such as Access and Mobility Management Function (AMF), Session Management Function (SMF), Network Repository Function (NRF), and so on, with User Equipment (e.g., UE 308), and creates specific trust boundaries across multiple service providers using distributed blockchain ledgers, as discussed in greater detail herein.
With specific reference to
Network entities of SBA 132 include AMF 320, SMF 325, Network Slice Selection Function (NSSF) 330, Network Exposure Function (NEF) 335v|335h, Network Repository Function (NRF) 340v|340h, Policy Control Function (PCF) 345v|345h, and Application Function (AF) 350. These network entities can be implemented either as a network element on a dedicated hardware, as a software instance running on a dedicated hardware, or as a virtualized function instantiated on an appropriate platform, e.g., a cloud infrastructure, as is appreciated by those skilled in the art.
In general, UE 308 connects to RAN/Access Network (AN) 310 as well as AMF 320 over respective network interfaces. Here, the RAN can include a base station while the AN can include a base station supporting non-3GPP access, e.g., Wi-Fi access. AMF 320 provides UE-based authentication, authorization, mobility management, etc. Notably, AMF 320 represents a common entity logically associated with all network slices instances that serve UE 308. As part of a registration procedure for UE 308, AMF 320 typically selects network slice instances for UE 308 by, for example, invoking or interacting with NSSF 330 to retrieve appropriate network slice instances based on UE subscription data.
SMF 325 is responsible for session management, IP address allocation to UE(s), and traffic management/selection of a User Plane Function (UPF) (e.g., UPF 315) for proper routing/data transfer. If UE 308 has multiple sessions, different SMFs may be allocated to each session for individual management and/or different functionality per session. In operation, AMF 320 can discover SMF 325 based on session request data from UE 308, as discussed in greater detail below.
AF 350 generally provides information on packet flows to PCF 345v, which is responsible for policy control in order to support Quality of Service (QoS). PCF 345v determines policies about mobility and session management for proper AMF/SMF operations based on the information from AF 350.
AUSF 355 stores authentication data for UE 308, and UDM 360 stores subscription data for UE 308. Data network 108 provides Internet access or operator services.
As illustrated, the native blockchain platform includes enterprise blockchain network 304, which interconnects blockchain service providers (SPs), represented as Blockchain Authentication Function (BAF) entities 305a-305n (also referred to as BAF 305 herein), with various mobile network entities over respective blockchain network interfaces BCx, BCy, and BCz.
BCx exchanges messages such as policy requests, authorizations, network usage, lawful intercept, accounting, and etc., BCy exchanges messages such as secondary authentication, authorization, resource sharing, lawful intercept, network slicing, and etc., and BCz exchanges messages such as standalone authentication public key present, authorization, blockchain entity queries/set, and etc.
The native blockchain platform operably supports additional and/or alternative blockchain authentication procedures for registering UE as well as session management procedures for PDN/PDU sessions. Notably, the blockchain authentication procedure/operations may be represented by blockchain authentication process/services 244 and the blockchain session management procedure/operations may be represented by blockchain session management process/services 246 (ref.
The blockchain authentication procedure generally includes operations to register and attach UE to the network in order to encrypt and protect traffic between the UE and core network entities (e.g., SBA 132), while the blockchain session management procedure generally includes operations to establish sessions (e.g., PDU sessions/PDN sessions) in order to allocate session resources to relevant network slices, permit data transmission between UE 308 and data network 108, ensure appropriate Quality of Service (QoS) connectivity, satisfy Service Level Agreements (SLA(s)), etc.
As discussed in greater detail below, the blockchain session management processes may include authentication/authorization operations, however it is appreciated such operations relate to session management and may be separate from the blockchain authentication procedure for registering and attaching the UE to the network.
For registration and/or session management, the blockchain authentication/authorization operations generally include authentication messages exchanged between one or more core NFs and a Blockchain Authentication Function (BAF) entity, which is exposed to the core NFs over new blockchain network interfaces. The authentication messages provide the BAF with UE credentials and the BAF, in turn, compares the UE credentials against UE credentials stored on a blockchain or distributed ledger. As is appreciated by those skilled in the art, the BAF returns authentication confirmation messages if the UE credentials match the UE credentials stored on the blockchain or distributed ledger.
Collectively referring to
RAN/Access Network (AN) 310 receives the RRC messages from UE 308 and selects an appropriate AMF 320 (which supports the blockchain procedures) and/or redirects the RRC messages to a new AMF as appropriate. Here, RAN/AN 310 can determine the RRC message from UE 308 include an indication for the disclosed blockchain procedures (e.g., in an access category) and selects AMF 320 and/or redirects to a new AMF based on the AMF blockchain capabilities.
With respect to the blockchain authentication procedure (e.g., for attaching UE 308 to the network), AMF 320 exchanges authentication messages with one or more Blockchain Authentication Function (BAF) entities (e.g., BAF(s) 305a-n) over blockchain network interfaces BCx and/or BCy. In particular, AMF 320 may send authentication messages to invoke/request that AUSF 355 perform authentication, which causes AUSF 355 to authenticate UE 308 with BAF 305 over blockchain network interface BCx. In other embodiments, AMF 320 can directly authenticate UE 308 with BAF 305 over blockchain network interface BCy, using for example, REST Application Program Interface (API) messages.
AMF 320 can also receive an indication to perform the blockchain authentication procedure from RRC messages sent RAN/AN network interfaces (which are further transmitted to AMF 320), and/or from Non-Access Stratum (NAS) messages sent directly from UE 308 (e.g., over network interface N1) to AMF 320. In this fashion, the NAS messages can indicate UE 308 supports/request the blockchain authentication procedure, e.g., in payload data such as registration type in the NAS message, and/or in follow-on request data.
Notably, AMF 320 and/or AUSF 355 can also perform conventional authentication processes in addition to the above discussed blockchain authentication operations, depending on service provider or mobile network operator security/integrity policies, as is appreciated by those skilled in the art—e.g., generating/creating encryption keys (e.g., anchor keys), sending authentication requests to AUSF 355, selecting UDM 360, retrieving vectors, e.g., credentials and/or encryption keys, from UDM 360, and so on. In this fashion, the blockchain authentication procedure can complement (or augment) existing authentication processes (e.g., 5G Extensible Authentication Protocol (EAP)—Authentication and Key Agreement (AKA) procedures defined by 3GPP TS 33.301, etc.) to serve as an enhanced or secondary form of security. In other embodiments, however, the blockchain authentication procedure can replace existing authentication processes (e.g., if existing authentication processes fail, etc.)
Still referring to
While session management is illustrated and described herein in the context of 5G networks (e.g., PDU sessions), it is appreciated such session management and related operations can readily apply to 4G networks (e.g., PDN sessions, etc.) For example, as is appreciated by those skilled in the art, 4G networks create sessions using default data bearers (e.g., 4G networks), while the 5G networks establish a PDU session as-needed or on demand, independent of UE attachment procedures. Further, UE(s) can establish multiple PDU sessions to the same data network (or to different data networks) over a single or multiple access networks (e.g., 3GPP networks, non-3GPP networks, etc.) where each PDU session is associated with network slice—e.g., one S-NSSAI and one Data Network Name (DNN). Notably, the PDU sessions can include various session types (e.g., IPv4, IPv6, Ethernet, unstructured, etc.).
In operation, UE 308 initiates session establishment by sending a PDU session request data to AMF 320 (e.g., as part of a PDU Session Establishment Request message). Notably, when UE 308 attaches to the core network (e.g., SBA 132), UE 308 exchanges mobility management messages and session management messages with AMF 320 (e.g., over an NG1 NAS network interface). Session management messages can be transmitted with the mobility management message supported by the NAS routing capability within AMF 320. Although AMF 320 is involved in sending session management messages, processing mobility messages and session management messages typically occurs in AMF 320 and SMF 325, respectively.
AMF 320 receives the PDU session request and discovers/selects an appropriate SMF (e.g., SMF 325) based on parameters included in the initial PDU session request from UE 308, such as session management service identification data, Single Network Slice Selection Assistance Information (S-NSSAI) data, Data Network Name (DNN) data, UE subscriptions, local operator policies, blockchain authentication data/capabilities, etc.). Although AMF 320 may not understand the full context of the session management messages, but it determines/selects an appropriate SMF for a new PDU session based on the above-mentioned parameters.
Here, AMF 320 selects SMF 325 and establishes a PDU session, which allocates PDU resources for a relevant network slice and permits data transmission/data packet exchanges between UE 308 and data network 108. In addition, AMF 320 also ensures that NAS signaling associated with this PDU session is handled by the same SMF (SMF 325) by assigning a PDU session identifier to the PDU session. UE 308, in turn, uses this PDU session identifier to route messages to the correct SMF.
As mentioned, PDU sessions are typically managed as part of a connectivity service (e.g., PDU Connectivity Service), which defines rules for exchanging data packets (e.g., Protocol Data Units (PDUs)) between the UE (e.g., UE 308) and a data network (e.g., data network 108) based on session-specific Quality of Service (QoS) parameters. Subscription information for each S-NSSAI can include multiple DNNs and one default DNN. When UE 308 does not specify a DNN in a NAS Message containing PDU Session Establishment Request for a given S-NSSAI, the serving AMF determines the DNN for the requested PDU Session by selecting the default DNN for this S-NSSAI if a default DNN is present in the UE's Subscription Information; otherwise the serving AMF selects a locally configured DNN for this S-NSSAI. If the DNN provided by the UE is not supported by the network and AMF can not select an SMF by querying NRF, the AMF may reject the NAS Message containing PDU Session Establishment Request from the UE with a cause indicating that the DNN is not supported.
Each PDU Session typically supports a single PDU Session type, e.g., supports the exchange of a single type of PDU requested by UE 308 at the establishment of the PDU Session. PDU Sessions are generally established upon UE request, modified upon UE 308/SBA 132 request, and released upon UE 308/SBA 132 request using NAS session management signaling exchanged over the N1 network interface between UE 308 and SMF 325. Upon request from an Application Server, SBA 132 is able to trigger a specific application in UE 308. When receiving the trigger message, UE 308 passes it to the identified application (in UE 308). The identified application in UE 308 may establish a PDU Session to a specific DNN, in accordance with 3GPP TS 32.501, clause 4.4.5.
SMF 325 is responsible of checking whether UE requests are compliant with the user subscription. For this purpose, SMF 325 retrieves and requests to receive update notifications on SMF level subscription data from UDM 360. This subscription data can indicate (e.g., per DNN and per S-NSSAI) allowed PDU Session Types and the default PDU Session Type, allowed SSC modes and the default SSC mode, QoS Information, subscribed Session-AMBR, Default 5QI and Default ARP, static IP address/prefix, subscribed User Plane Security Policy, Charging Characteristics to be associated with the PDU Session, and so on.
In addition, UE 308 may request to move a PDU Session between 3GPP and Non 3GPP accesses. The decision to move PDU Sessions between 3GPP access and Non 3GPP access is made on a per PDU Session basis, e.g., UE 308 may, at a given time, have some PDU Sessions using 3GPP access while other PDU Sessions are using Non 3GPP access. UE 308 typically provides a PDU session ID in a PDU Session Establishment Request message. The PDU session ID is unique per UE and represents a unique identifier assigned to a PDU Session. The PDU session ID can be stored in UDM 360 to support handover between 3GPP and non-3GPP access—e.g., when different PLMNs are used for the two accesses.
While many of the above discussed operations may be performed as part of conventional session management processes, this disclosure further provides blockchain session management processes where one or more network entities/NFs of SBA 132 exchange messages with a Blockchain Authentication Function (BAF) (e.g., one of BAF(s) 305a-n over new blockchain interfaces (e.g., BCx, BCy, BCz) in order to establish a session for UE 308. The disclosed blockchain session management processes may complement existing session management processes similar to secondary authentication processes that use an Authentication Authorization, and Accounting (AAA) server in a data network. However, here, the blockchain enterprise platform (e.g., enterprise blockchain network 304 and BAF(s) 305a-n) is natively integrated with and directly exposed to SBA 132. It is also appreciated that the blockchain session management processes, in other embodiments, may replace existing session management processes.
In operation, SMF 325 receives session request data associated with UE 308. This session request data may be included as part of a PDU Session Establishment Request message, which may comprise the above-mentioned parameters such as the blockchain authentication data. In some embodiments, AMF 320 initially selects SMF 325 based on the session request data and further forwards the session request data to SMF 325 (once selected). SMF 325 selects a Blockchain Authentication Function (BAF 305) based on the session request data, and further exchanges at least a portion of the blockchain authentication data (e.g., blockchain authentication credentials associated with UE 308) with BAF 305 over a blockchain network interface (e.g., BCx and/or BCy, where SMF 325 may route messages through AMF 320, etc.)
In some embodiments, SMF 325 may further select an NEF (e.g., NEF 335—shown in a dashed box in
SMF 325 receives authentication confirmation data from BAF 305 over the blockchain network interface and establishes a session associated with the UE based on the authentication data.
In some embodiments, SBA 132 may apply a restricted access policy to the session while one or more NFs perform a blockchain credit check/charging event process. In particular, SMF 325 can communicate with PCF 345 to obtain payment credits (e.g., blockchain tokens, etc.) in order to ensure the services to be provided to UE 308 align with its creditworthiness. For example, PCF 345 can solicit blockchain payment credits from BAF 305 (e.g., either directly and/or indirectly through NEF 335) over the blockchain network interface. PCF 345 and/or SMF 325 can determine the blockchain payment credits satisfy a payment criteria for one or more network services (e.g., as part of the blockchain charging event), and further remove (or modify) the restricted access policy for the session.
These and other blockchain enhanced session management features are described in greater detail with respect to the schematic signaling diagrams shown in
Blockchain Enhanced PDN Session Establishment with Out-of-Band Blockchain Authorization
With respect to the illustrated call flow, UE 308 initiates, at step 402, an initial PDU (or PDN) session establishment request and sends session request data (e.g., Non-Access Stratum (NAS) messages) to AMF 320 over network interface N1. The NAS messages can include information such as Single Network Slice Selection Assistance Information (S-NSSAI), Data Network Name (DNN), PDU session IDs, request types, old PDU session IDs, an N1 Service Management (SM) container, indications/requests for blockchain authorization (e.g., as a secondary authorization), and so on.
Notably, the indications/requests for the blockchain authorization can represent a preference by UE 308 for the network (SBA 132) to use blockchain authentication data (e.g., blockchain credentials) to authorize/authenticate UE 308 for a PDU session. In one embodiment, the indication of the blockchain authorization may be specified by the S-NSSAI data, which can include a unique identifier of a network slice. For example, the S-NSSAI data can include a Slice/Service type (SST), denoting expected network behaviour, as well as a Slice Differentiator (SD), differentiating amongst multiple network slices of the same Slice/Service type. Here, UE 308 can provide S-NSSAI data having a particular unique identifier corresponding to blockchain capable network slice.
Alternatively, the indication of the blockchain authorization may be included as one of the SST values in the S-NSSAI data in accordance with 3GPP TS 23.501 (clause 5.15, table 5.15.2.2-1). For example, the SST value may be modified to include the blockchain ID as provided below.
In other embodiments, if slicing is orthogonal to the blockchain procedures, the PDU “Request Type” could be set to “guest access with dual authentication”, as is appreciated by those skilled in the art.
AMF 320 receives the session establishment request and further discovers/selects an appropriate SMF—here, SMF 325. In particular, AMF 320 discovers and selects SMF 325 based on parameters included in the initial PDU session request (e.g., step 402). As mentioned, these parameters include S-NSSAI data, DNN data, UE subscriptions, local operator policies, blockchain authentication data/blockchain capabilities, and so on.
Here, AMF 320 selects SMF 325 based, at least in part, on its blockchain session capabilities. If AMF 320 does not have an association with an SMF for the PDU session ID (e.g., when Request Type indicates “initial request”), AMF 320 invokes a PDU session creation request (e.g., Nsmf_PDUSession_CreateSMContext Request), as shown at step 404. However, if AMF 320 already has an association with an SMF for the PDU Session ID (e.g., when Request Type indicates “existing PDU Session”), the AMF invokes the Nsmf_PDUSession_UpdateSMContext Request. Notably, the PDU Session creation request can specify a request type set to “guest access with dual authentication” (e.g., if a slice is not explicitly set for blockchain authorization).
At step 406, SMF 325 and UDM 360 exchange registration/subscription information for UE 308. SMF 325 further sends a corresponding PDU session SM context responses (e.g., an SM context identifier) to AMF 320, again at step 404. In this fashion, SMF 325 registers itself for an initial PDU session with UDM 360, in accordance with UE-requested PDU Session Establishment procedures provided by 3GPP TS 23.502.
Steps 408-414 represent operations of the disclosed blockchain session management, including out-of-band blockchain authorization/authentication operations as part of the PDN session establishment. These blockchain authorization/authentication operations may conform to secondary authentication/authorization operations such as Data Network (DN)-Authentication, Authorization, and Accounting (AAA) server, described by 3GPP TS 23.501, clause 5.6.6. However, here, the blockchain authorization/authentication operations leverage the natively integrated blockchain platform (e.g., BAF 305), which is directly exposed to SBA 132 over a new blockchain network interface.
At step 408, UE 308 sends a NAS SM DN Request Container message to SMF 325 to request the blockchain authentication procedure as a secondary authorization for the PDN session (e.g., in accordance with secondary authorization request of 3GPP TS 23.501, clause 5.6.6). The NAS SM DN Request Container message includes blockchain information for PDU session authorization by an external Data Network (e.g., slice information (identified by S-NSSAI), PDU session ID, a PDN it would like to connect to (identified by DNN), a blockchain server ID (identifying BAF 305), etc.). This blockchain information may be provided as part of payload data, and/or may be included as part of follow-on request data.
Although the NAS SM DN Request Container message is illustrated as a single signal between UE 308 and SMF 325, it is appreciated this signal may be conveyed to SMF 325 by AMF 320. For example, UE 308 can send the signal to AMF 320 over the N1 network interface, and AMF 320 can send or forward the signal (or appropriate portions of the signal) to SMF 325 over the N11network interface. In some embodiments, the NAS SM DN Request Container can include the PDU session establishment request message (e.g., step 402) as part of a N1 SM container, as is appreciated by those skilled in the art.
SMF 325 receives the NAS SM DN Request Container and determines an appropriate BAF entity (or BAF server) based on the blockchain information and local configuration information contained therein. SMF 325 determines BAF 305 as the appropriate blockchain authentication/authorization entity and further exchanges, at step 410, blockchain Application Programming Interface (API) messages with BAF 305 over a blockchain network interface (e.g., BCx network interface). In particular, SMF 325 invokes a Namf_Communication_N1N2MessageTransfer service operation on AMF 320 to transfer the DN Request Container information within N1 SM information sent towards UE 308.
At step 412, SMF 325 exchanges the blockchain API messages with BAF 305, using NEF 335 (which acts as a gateway between SMF 325 and BAF 305). NEF 335 further exchanges, at steps 412/414, corresponding Representational State Transfer (REST) API messages with BAF 305. In this fashion, NEF 335 allows external users (e.g., enterprises/partner operations) to monitor, provision, and enforce application-level policy for users inside the operator network.
Steps 412/414 continues until successful authorization or failure. At step 414, BAF 305 sends NEF 335 authentication confirmation data (e.g., indicating successful session authorization and profile information), which are further sent to SMF 325 at step 410. The authentication confirmation data can include a service name that BAF 305 uses to register available network services for UE 308. In addition, BAF 305 may provide service specific attributes (e.g., application access capabilities, QoS and Data rate profiles and other applications that the user has subscribed to as part of the blockchain contract, etc.) Notably, if authorization fails, the PDU set up request is rejected with appropriate cause code.
After successful authorization, SMF 325 continues with PDU establishment operations and, based on a PDU profile, selects a PCF and performs Session Management Policy Establishment procedure, as shown at step 416. SMF 325 can provide a blockchain flag and associated parameters (if available from UE 308) to indicate to PCF 345 that service capabilities can be obtained from BAF 305 (e.g., and/or via NEF 335). For example, PCF 345 can use the blockchain authentication data (received from SMF 325 at step 416) to identify NEF 335 and/or BAF 305.
PCF 345 requests, at step 418, service parameters from NEF 335, which further obtains the service parameters from BAF 305. Notably, step 418 may be optional, because PCF 345 can use the UDR as per 4.16.4 procedure defined in 3GPP TS 23.502. However, in some instances, the UDR may not have a service profile for all use cases (e.g., where the UE is a guest on the service provider's network). As shown here, PCF 345 retrieves the service profile from NEF 335 (which NEF 335 retrieves from BAF 305). PCF 345 further determines the network services, QoS, and charging plan to be applied to the PDU session associated with UE 308.
SMF 325 further selects a UPF (e.g., UPF 315) to serve the PDU session, and at steps 420-424, SMF 325 performs a blockchain charging event in conjunction with PCF 345, NEF 335, and/or BAF 305, based on the profile information received at step 414.
In particular, SMF 325 requests PCF 345 and NEF 335 to perform the blockchain charging event, which represents a credit request transaction.
The blockchain charging event includes operations for BAF 305 to return blockchain payment credits (e.g., blockchain tokens) to PCF 345 and/or SMF 325 in order to pay for one or more network services for UE 308. For example, the BAF 305 can return blockchain tokens from a blockchain eWallet associated with UE 308.
In some instances, SMF 325 and PCF 345 can return tokens to BAF 305 should all the tokens requested in this step not be consumed. In comparison to other pre-paid services that use quotas from an Online Charging Server (OCS) (not an actual monetary fund), the blockchain charging event represents a prepaid transaction that can include actual funds, which the service provider can return if the contract is not completed in an authorized time period.
The blockchain charging event may include messages exchanged over the N30 network interface, shown at step 422, between PCF 345 and NEF 335. In this fashion, Nnef API messages may be augmented to include appropriate blockchain eWallet messages (requests/returns/etc.)
Step 424 represents trusted communications between NEF 335 with BAF 305 as BAF 305 is a trusted application. However, in some instances, BAF 305 may not be trusted, in which case an Application Function could provide a proxy for these procedures.
In one or more additional embodiments, enhanced blockchain session management operations also accommodate delayed authorization. For example, BAF 305 may require a certain amount of time to conclude a consensus, which may delay its response/fund verifications (e.g., as part of the blockchain charging event). In these instances, SMF 325 can request PCF 345 to notify it when NEF 335 allows the subscription. In addition, SMF 325 concludes the PDU session establishment, but can indicate UPF 315 to place the PDU session in quarantine until further notice (e.g., until BAF 305 concludes the consensus/completes the charging event).
Remaining steps 426-448, may be defined by 3GPP TS 23.502, as is appreciated by those skilled in the art.
Blockchain Enhanced PDN Session Establishment with in-Band Blockchain Authorization
Signaling diagram 401 begins at step 402 where, as discussed above, UE 308 initiates a PDU session establishment request. The session establishment call flow follows the above-discussed operations for steps 404 and 406.
At step 408, UE 308 sends a NAS SM DN Request Container message to SMF 325 to request the blockchain authentication procedure as a secondary authorization for the PDN session. As mentioned, the NAS SM DN Request Container message includes blockchain information for PDU session authorization by an external Data Network (e.g., slice information (identified by S-NSSAI), PDU session ID, a PDN it would like to connect to (identified by DNN), a blockchain server ID (identifying BAF 305), etc.) Notably, step 408 represents an optional signal between UE 308 and SMF 325. However, even though it is optional, step 408 helps build trust between the core network (e.g., SBA 132) and BAF 305 (e.g., a Distributed Ledger Technology (DLT) entity). For example, as discussed in greater detail below, until the blockchain authentication procedure results in successful authorization of the UE, UE 308 may only have a temporary connection and the access control list may be restricted. BAF 305 is typically registered and authenticated with NEF 335, and SMF 325 may invoke NEF 335 to pass on the blockchain authentication credentials. Once authorized, UE 308 is notified of successful authorization, and BAF 305 notifies NEF 335, which (in turn) notifies SMF 325 of the successful authorization.
Steps 410-414 (not shown) apply for the out-of-band blockchain authentication operations (e.g., secondary authentication/authorization operations), illustrated in signaling diagram 400. Here, however, signaling diagram 401 illustrates in-band authentication operations, performed later in the signal flow (e.g., steps 450-460), described below.
In proper context, UE 308 is attached to the network at step 408, but does not have an IP address assigned. After step 408, SMF 325 selects PCF 345 based on a PDU profile. PCF 435 performs the Session Management Policy Establishment procedure, shown by steps 416-418. For example, the Session Management Policy Establishment procedure can include operations where SMF 325 establishes the PDU Session with PCF 345, including SMF 325 receiving default PCC Rules for the PDU Session, PCF 345 subscribing to IP allocation/release events in SMF 325, PCF 345 updating policy information in SMF 325, and so on.
Following steps 416-418, SMF 325 selects a UPF (e.g., UPF 315) to serve the PDU session. In case of PDU Type IPv4 or IPv6, SMF 325 allocates an IP address/prefix for the PDU Session as described in 3GPP TS 23.501, clause 5.8.1. In case of a PDU Type IPv6, SMF 325 can allocate an interface identifier to UE 308 for the UE to build its link-local address. For Unstructured PDU Type the SMF may allocate an IPv6 prefix for the PDU Session and N6 point-to-point tunneling (based on UDP/IPv6) as described in 3GPP TS 23.501, clause 5.6.10.3.
Step 420 is modified since the above-discussed out-of-band blockchain authentication operations do not occur (e.g., steps 410-414) here. Instead, at step 420, PCF 345 determines UE 308 requests the blockchain authentication/authorization procedure. For example, SMF 325 can provide a blockchain indication to PCF 345, which blockchain indication can include a blockchain flag, blockchain authentication data, payment data, blockchain entity identifiers, and so on. Here, the blockchain indication includes a blockchain flag, which causes PCF 345 to apply a restricted or guest access policy for the PDU session, pending successful in-band blockchain authorization/authentication operations, discussed below. Put differently, PCF 345 installs a restricted access rule for the PDU session, which may be similar to the rules applied for pre-paid users (e.g., users can access a Domain Name Server (DNS) to resolve the servers and HTTPS port/destination pair to a set of servers, etc.) In some embodiments, the server IP addresses could be returned in step 422 and step 424 as part of a blockchain charging event (not shown here).
If there is a commercial agreement in place, the restricted access policy allows UE 308 access to DN 108 to obtain authentication/authorization and blockchain payment data/tokens from BAF 305. Again, similar to the pre-paid restricted policies, which allows UE 308 to connect to DN 108 through a web portal and enter credit card information, the in-band blockchain authentication/authorization operations represented by steps 450-462 leverage the native blockchain platform to automatically debit blockchain payments/tokens from BAF 305. In this fashion, the subscriber associated with UE 308 only needs to ensure their wallet has funds.
Following step 420, SMF 325 provisions rules on UPF 315, at steps 426-428, to allow DNS requests and REST messages to BAF 305 (e.g., a DLT server address provided by PCF 345).
Steps 430-448 represent signals or messages accordance with UE-requested PDU Session Establishment procedures provided by 3GPP TS 23.502.
Steps 450-460 represent in-band blockchain authentication/authorization signals or messages. While steps 450-460 are illustrated after the PDU session is established at step 448 with a restricted access policy, it is appreciated these signals or messages may begin at step 438 (Up Link (UL) traffic).
At step 450, UE 308 sends blockchain authentication data to UPF 315 using IP datagram encapsulation. UPF 315 acts as a gateway to BAF 305 and sends, at step 452, corresponding blockchain data to BAF 305. In some embodiments, UPF 315 may send messages to other NFs (e.g., SMF 325) and/or over DN 108 for forwarding to BAF 305. However, for sake of simplicity, signaling diagram 401 shows UPF 315 sending the corresponding blockchain data directly to BAF 305. The blockchain authentication data can include, for example, blockchain authentication credentials, blockchain entity identifiers (e.g., corresponding to BAF 305), and other information required by BAF 305 to authenticate/authorize UE 308 as well as to solicit blockchain payment data (e.g., blockchain tokens).
In this fashion, DN 108 may treat the PDU session as a prepaid session and allow approved protocols. In some embodiments, the PDU session may be associated with a timer that can safeguard the session and terminate the session if the PDU authentication/authorization does not conclude within a predetermined timeframe. In these embodiments, UDM 360 can set the timeframe at step 406 and/or the timeframe may be locally configured as part of an APN profile.
Steps 450-452 represent bi-directional messages between UE 308, UPF 315 and BAF 305. Other NFs (e.g., NEF 335, DN 108, etc.) may be invoked or employed as is appreciated by those skilled in the art. The bi-directional messages include blockchain authentication data required by BAF 305 to authenticate/authorize UE 308 as well as to solicit blockchain payment data (e.g., blockchain tokens). If authorization fails at steps 450-452, UE 308 can choose to disconnect from the network. The network (e.g., SBA 132) would be notified at steps 456-458, and may further block UE 308, disconnect the PDU session, or try authentication again.
BAF 305 authenticates (e.g., verifies blockchain credentials for UE 308) the blockchain credentials associated with UE 308 and, if successful, it notifies NEF 335 (step 454), which in turn notifies PCF 345 (step 456) regarding successful authentication. In addition, BAF 305 can return blockchain payment data (e.g., blockchain tokens) to NEF 335 and/or PCF 345. PCF 345 updates the policy/traffic rules for SMF 325, at step 458, which further updates the traffic rules with UPF 315. The updated policy/traffic rules permit UE 308 access to contracted network services (e.g., as specified and/or as paid for by BAF 305).
The call flows or messages shown in
Procedure 500 can represent operations of a blockchain session management process (e.g., blockchain session management process/services 246) that may be performed by one or more NF entities (e.g., device/entity 200) in a core network such as SBA 132. For example, the NF entities can include, for example, an AMF entity (AMF 320), an SMF entity (SMF 325), a PCF entity (PCF 345), and/or a NEF entity (NEF 335).
Procedure 500 begins at step 505 and continues on to step 510 where, as discussed above, the SMF entity receives session request data associated with User Equipment (UE, such as UE 308). Notably, the session request data may be sent to the SMF entity from an AMF entity. In addition, the session request data can include blockchain authentication data associated with the UE (e.g., blockchain authentication credentials, blockchain entity identifiers which identify a Blockchain Authentication Function (BAF such as BAF 305), other information to solicit blockchain payment data from the BAF, etc.)
Next, at step 515, the SMF entity selects the BAF based on the session request data. As mentioned, the session request data can include identification information indicating an appropriate blockchain service provider to authenticate/authorize (and issue payment tokens) for the UE. After selecting the appropriate BAF, procedure continues to step 520 where at least a portion of the blockchain authentication data is exchanged between the SMF entity and the BAF entity over a blockchain network interface. For example, the blockchain network interface can include the above discussed BCx, BCy, and/or BCz interfaces, which expose the blockchain platform (e.g., enterprise blockchain network, including blockchain service providers or BAFs) to the core network. In addition, in some embodiments, the SMF can invoke an NEF entity (e.g., NEF 335) to act as a gateway between the BAF and the core network. In these embodiments, SMF sends blockchain authentication data to the NEF entity, which in turn sends the blockchain authentication data to the BAF entity over the blockchain network interface. Likewise, the BAF entity can communicate with SMF by sending responsive blockchain authentication data (e.g., authentication confirmation data for successful (or failed) transactions, blockchain payment data/credits, etc.) to the NEF entity over the blockchain network interface, which causes the NEF entity to send the responsive blockchain authentication data to the SMF entity.
The SMF entity receives, at step 525, authentication confirmation data from the BAF entity and establishes, at step 530 a session with the UE based on the same. In some embodiments, a PCF entity can apply a restricted access policy to the session while one or more NFs perform a blockchain credit check/charging event process. For example, at step 540, the SMF entity and/or the PCF entity can solicit blockchain payment credits such as blockchain tokens from the BAF entity over the network interface as part of the blockchain credit check/charging event process. In response, the PCF entity determines the blockchain payment credits satisfies a contract for one or more network resources/services and updates, at step 545, the restricted access policy to permit the UE access to such resources/services. Procedure subsequently ends at step 550, but may return again to step 510 where the SMF receives session request data associated with the UE.
It should be noted that certain steps within procedure 500 may be optional, and further, the steps shown in
The techniques described herein, therefore, provide a natively integrated blockchain platform for wireless networks. This native blockchain platform supports new use cases that create opportunities to share network resources across multiple provider networks, increase workload mobility security, improve billing/mediation and reconciliation and create mechanisms for roaming authentication/registration using blockchain technology. In addition, the native blockchain platform provides new opportunities for the app economy and creates a new market place for Mobile virtual network operators (MVNO) participation. As discussed above the native blockchain platform facilitates new methods for authenticating UE when attaching the UE to the network as well as managing sessions for the UE. Moreover, the native blockchain platform can be leveraged to natively facilitate payments for network services as part of blockchain charging events.
While there have been shown and described illustrative embodiments of the native blockchain platform and corresponding operations in a specific network context (e.g., a mobile core network for a 5G network), it is to be understood that various other adaptations and modifications may be made within the spirit and scope of the embodiments herein. For example, the embodiments and operations disclosed herein have been described with respect to certain devices, NFs, interfaces, and systems, however it is appreciated that such embodiments are provided for purposes of example, not limitation and that the blockchain authentication techniques disclosed herein can be incorporated as part of existing wireless networks.
The foregoing description has been directed to specific embodiments. It will be apparent, however, that other variations and modifications may be made to the described embodiments, with the attainment of some or all of their advantages. For instance, it is expressly contemplated that the components, elements, and/or operations described herein can be implemented as software being stored on a tangible (non-transitory) computer-readable medium, devices, and memories (e.g., disks/CDs/RAM/EEPROM/etc.) having program instructions executing on a computer, hardware, firmware, or a combination thereof. Further, methods describing the various functions and techniques described herein can be implemented using computer-executable instructions that are stored or otherwise available from computer readable media. Such instructions can comprise, for example, instructions and data which cause or otherwise configure a general purpose computer, special purpose computer, or special purpose processing device to perform a certain function or group of functions. Portions of computer resources used can be accessible over a network. The computer executable instructions may be, for example, binaries, intermediate format instructions such as assembly language, firmware, or source code. Examples of computer-readable media that may be used to store instructions, information used, and/or information created during methods according to described examples include magnetic or optical disks, flash memory, USB devices provided with non-volatile memory, networked storage devices, and so on. In addition, devices implementing methods according to these disclosures can comprise hardware, firmware and/or software, and can take any of a variety of form factors. Typical examples of such form factors include laptops, smart phones, small form factor personal computers, personal digital assistants, and so on. Functionality described herein also can be embodied in peripherals or add-in cards. Such functionality can also be implemented on a circuit board among different chips or different processes executing in a single device, by way of further example. Instructions, media for conveying such instructions, computing resources for executing them, and other structures for supporting such computing resources are means for providing the functions described in these disclosures. Accordingly this description is to be taken only by way of example and not to otherwise limit the scope of the embodiments herein. Therefore, it is the object of the appended claims to cover all such variations and modifications as come within the true spirit and scope of the embodiments herein.
This application is a continuation of U.S. application Ser. No. 16/134,887, filed on Sep. 18, 2018, which in turn, claims priority of U.S. Provisional Patent Application Ser. No. 62/682,770, filed on Jun. 8, 2018, the contents of which are incorporated herein by reference to their entirety.
Number | Name | Date | Kind |
---|---|---|---|
4236068 | Walton | Nov 1980 | A |
5642303 | Small et al. | Jun 1997 | A |
5751223 | Turner | May 1998 | A |
6812824 | Goldinger et al. | Nov 2004 | B1 |
D552603 | Tierney | Oct 2007 | S |
7573862 | Chambers et al. | Aug 2009 | B2 |
D637569 | Desai et al. | May 2011 | S |
7975262 | Cozmei | Jul 2011 | B2 |
8010079 | Mia et al. | Aug 2011 | B2 |
8102814 | Rahman et al. | Jan 2012 | B2 |
8260320 | Herz | Sep 2012 | B2 |
8284748 | Borghei | Oct 2012 | B2 |
8300594 | Bernier et al. | Oct 2012 | B1 |
8325626 | Tóth et al. | Dec 2012 | B2 |
8396485 | Grainger et al. | Mar 2013 | B2 |
8446899 | Lei et al. | May 2013 | B2 |
8457145 | Zimmerman et al. | Jun 2013 | B2 |
8458184 | Dorogusker et al. | Jun 2013 | B2 |
D691636 | Bunton | Oct 2013 | S |
8549638 | Aziz | Oct 2013 | B2 |
8553634 | Chun et al. | Oct 2013 | B2 |
8644301 | Tamhankar et al. | Feb 2014 | B2 |
8650279 | Mehta et al. | Feb 2014 | B2 |
8669902 | Pandey et al. | Mar 2014 | B2 |
8676182 | Bell et al. | Mar 2014 | B2 |
8682279 | Rudolf et al. | Mar 2014 | B2 |
8693367 | Chowdhury et al. | Apr 2014 | B2 |
8718644 | Thomas et al. | May 2014 | B2 |
8761174 | Jing et al. | Jun 2014 | B2 |
8768389 | Nenner et al. | Jul 2014 | B2 |
8849283 | Rudolf et al. | Sep 2014 | B2 |
8909698 | Parmar et al. | Dec 2014 | B2 |
8958318 | Hastwell et al. | Feb 2015 | B1 |
9060352 | Chan et al. | Jun 2015 | B2 |
9130859 | Knappe | Sep 2015 | B1 |
9173084 | Foskett | Oct 2015 | B1 |
9173158 | Varma | Oct 2015 | B2 |
D744464 | Snyder et al. | Dec 2015 | S |
9270709 | Shatzkamer et al. | Feb 2016 | B2 |
9271216 | Friman et al. | Feb 2016 | B2 |
9281955 | Moreno et al. | Mar 2016 | B2 |
D757424 | Phillips et al. | May 2016 | S |
D759639 | Moon et al. | Jun 2016 | S |
9369387 | Filsfils et al. | Jun 2016 | B2 |
9389992 | Gataullin et al. | Jul 2016 | B2 |
9426305 | De Foy et al. | Aug 2016 | B2 |
D767548 | Snyder et al. | Sep 2016 | S |
9467918 | Kwan | Oct 2016 | B1 |
D776634 | Lee et al. | Jan 2017 | S |
9544337 | Eswara et al. | Jan 2017 | B2 |
9569771 | Lesavich et al. | Feb 2017 | B2 |
9609504 | Karlqvist et al. | Mar 2017 | B2 |
9615268 | Navarro et al. | Apr 2017 | B2 |
9634952 | Gopinathan et al. | Apr 2017 | B2 |
9642167 | Snyder et al. | May 2017 | B1 |
9654344 | Chan et al. | May 2017 | B2 |
9712444 | Bolshinsky et al. | Jul 2017 | B1 |
9713114 | Yu | Jul 2017 | B2 |
9736056 | Vasseur et al. | Aug 2017 | B2 |
9762683 | Karampurwala et al. | Sep 2017 | B2 |
9772927 | Gounares et al. | Sep 2017 | B2 |
9820105 | Snyder et al. | Nov 2017 | B2 |
D804450 | Speil et al. | Dec 2017 | S |
9858559 | Raleigh et al. | Jan 2018 | B2 |
9860151 | Ganichev et al. | Jan 2018 | B2 |
9933224 | Dumitriu Dan Mihai et al. | Feb 2018 | B2 |
9923780 | Rao et al. | Mar 2018 | B2 |
9961560 | Farkas et al. | May 2018 | B2 |
9967906 | Verkaik et al. | May 2018 | B2 |
9980220 | Snyder et al. | May 2018 | B2 |
9985837 | Rao et al. | May 2018 | B2 |
9998368 | Chen et al. | Jun 2018 | B2 |
10108954 | Dunlevy | Oct 2018 | B2 |
10123202 | Polehn | Nov 2018 | B1 |
10164779 | Uhr | Dec 2018 | B2 |
20030087645 | Kim et al. | May 2003 | A1 |
20030116634 | Tanaka | Jun 2003 | A1 |
20040029576 | Flykt | Feb 2004 | A1 |
20040203572 | Aerrabotu et al. | Oct 2004 | A1 |
20050090225 | Muehleisen et al. | Apr 2005 | A1 |
20050169193 | Black et al. | Aug 2005 | A1 |
20050186904 | Kowalski et al. | Aug 2005 | A1 |
20060022815 | Fischer et al. | Feb 2006 | A1 |
20060030290 | Rudolf et al. | Feb 2006 | A1 |
20060092964 | Park et al. | May 2006 | A1 |
20060126882 | Deng et al. | Jun 2006 | A1 |
20060187866 | Werb et al. | Aug 2006 | A1 |
20070037605 | Logan | Feb 2007 | A1 |
20070239854 | Janakiraman et al. | Oct 2007 | A1 |
20080037715 | Prozeniuk et al. | Feb 2008 | A1 |
20080084888 | Yadav et al. | Apr 2008 | A1 |
20080101381 | Sun et al. | May 2008 | A1 |
20080163207 | Reumann et al. | Jul 2008 | A1 |
20080233969 | Mergen | Sep 2008 | A1 |
20090129389 | Halna DeFretay et al. | May 2009 | A1 |
20090203370 | Giles et al. | Aug 2009 | A1 |
20090282048 | Ransom et al. | Nov 2009 | A1 |
20090298511 | Paulson | Dec 2009 | A1 |
20090307485 | Weniger et al. | Dec 2009 | A1 |
20100039280 | Holm et al. | Feb 2010 | A1 |
20100097969 | De Kimpe et al. | Apr 2010 | A1 |
20110087799 | Padhye et al. | Apr 2011 | A1 |
20110142053 | Van Der Merwe et al. | Jun 2011 | A1 |
20110182295 | Singh et al. | Jul 2011 | A1 |
20110194553 | Sahin et al. | Aug 2011 | A1 |
20110228779 | Goergen | Sep 2011 | A1 |
20120023552 | Brown et al. | Jan 2012 | A1 |
20120054367 | Ramakrishnan et al. | Mar 2012 | A1 |
20120088476 | Greenfield | Apr 2012 | A1 |
20120115512 | Grainger et al. | May 2012 | A1 |
20120157126 | Rekimoto | Jun 2012 | A1 |
20120167207 | Beckley et al. | Jun 2012 | A1 |
20120182147 | Forster | Jul 2012 | A1 |
20120311127 | Kandula et al. | Dec 2012 | A1 |
20120324035 | Cantu et al. | Dec 2012 | A1 |
20130029685 | Moshfeghi | Jan 2013 | A1 |
20130039391 | Skarp | Feb 2013 | A1 |
20130057435 | Kim | Mar 2013 | A1 |
20130077612 | Khorami | Mar 2013 | A1 |
20130088983 | Pragada et al. | Apr 2013 | A1 |
20130107853 | Pettus et al. | May 2013 | A1 |
20130108263 | Srinivas et al. | May 2013 | A1 |
20130115916 | Herz | May 2013 | A1 |
20130145008 | Kannan et al. | Jun 2013 | A1 |
20130155906 | Nachum et al. | Jun 2013 | A1 |
20130191567 | Rofougaran et al. | Jul 2013 | A1 |
20130203445 | Grainger et al. | Aug 2013 | A1 |
20130217332 | Altman et al. | Aug 2013 | A1 |
20130232433 | Krajec et al. | Sep 2013 | A1 |
20130273938 | Ng et al. | Oct 2013 | A1 |
20130317944 | Huang et al. | Nov 2013 | A1 |
20130322438 | Gospodarek et al. | Dec 2013 | A1 |
20130343198 | Chhabra et al. | Dec 2013 | A1 |
20130347103 | Veteikis et al. | Dec 2013 | A1 |
20140007089 | Bosch et al. | Jan 2014 | A1 |
20140016926 | Soto et al. | Jan 2014 | A1 |
20140025770 | Warfield et al. | Jan 2014 | A1 |
20140031031 | Gauvreau et al. | Jan 2014 | A1 |
20140052508 | Pandey et al. | Feb 2014 | A1 |
20140059655 | Beckley et al. | Feb 2014 | A1 |
20140087693 | Walby et al. | Mar 2014 | A1 |
20140105213 | A K et al. | Apr 2014 | A1 |
20140118113 | Kaushik et al. | May 2014 | A1 |
20140148196 | Bassan-Eskenazi et al. | May 2014 | A1 |
20140179352 | V.M. et al. | Jun 2014 | A1 |
20140191868 | Ortiz et al. | Jul 2014 | A1 |
20140198808 | Zhou | Jul 2014 | A1 |
20140222997 | Mermoud et al. | Aug 2014 | A1 |
20140233460 | Pettus et al. | Aug 2014 | A1 |
20140269321 | Kamble et al. | Sep 2014 | A1 |
20140302869 | Rosenbaum et al. | Oct 2014 | A1 |
20140337824 | St. John et al. | Nov 2014 | A1 |
20140341568 | Zhang et al. | Nov 2014 | A1 |
20150016286 | Ganichev et al. | Jan 2015 | A1 |
20150016469 | Ganichev et al. | Jan 2015 | A1 |
20150023176 | Korja et al. | Jan 2015 | A1 |
20150030024 | Venkataswami et al. | Jan 2015 | A1 |
20150043581 | Devireddy et al. | Feb 2015 | A1 |
20150063166 | Sif et al. | Mar 2015 | A1 |
20150065161 | Ganesh et al. | Mar 2015 | A1 |
20150087330 | Prechner et al. | Mar 2015 | A1 |
20150103818 | Kuhn et al. | Apr 2015 | A1 |
20150163192 | Jain et al. | Jun 2015 | A1 |
20150172391 | Kasslin et al. | Jun 2015 | A1 |
20150223337 | Steinmacher-Burow | Aug 2015 | A1 |
20150256972 | Markhovsky et al. | Sep 2015 | A1 |
20150264519 | Mirzaei et al. | Sep 2015 | A1 |
20150280827 | Adiletta et al. | Oct 2015 | A1 |
20150288410 | Adiletta et al. | Oct 2015 | A1 |
20150326704 | Ko et al. | Nov 2015 | A1 |
20150358777 | Gupta | Dec 2015 | A1 |
20150362581 | Friedman et al. | Dec 2015 | A1 |
20160007315 | Lundgreen et al. | Jan 2016 | A1 |
20160044627 | Aggarwal et al. | Feb 2016 | A1 |
20160099847 | Melander et al. | Apr 2016 | A1 |
20160100395 | Xu et al. | Apr 2016 | A1 |
20160105408 | Cooper et al. | Apr 2016 | A1 |
20160127875 | Zampini, II | May 2016 | A1 |
20160146495 | Malve et al. | May 2016 | A1 |
20160330045 | Tang et al. | Nov 2016 | A1 |
20160344641 | Javidi et al. | Nov 2016 | A1 |
20170026974 | Dey et al. | Jan 2017 | A1 |
20170180999 | Alderfer et al. | Jun 2017 | A1 |
20170181136 | Bharadwaj et al. | Jun 2017 | A1 |
20170195205 | Li et al. | Jul 2017 | A1 |
20170202000 | Fu et al. | Jul 2017 | A1 |
20170214551 | Chan et al. | Jul 2017 | A1 |
20170273083 | Chen et al. | Sep 2017 | A1 |
20170317997 | Smith et al. | Nov 2017 | A1 |
20170332421 | Sternberg | Nov 2017 | A1 |
20170339706 | Andreoli-Fang et al. | Nov 2017 | A1 |
20170364700 | Goldfarb | Dec 2017 | A1 |
20180063018 | Bosch et al. | Mar 2018 | A1 |
20180069311 | Pallas et al. | Mar 2018 | A1 |
20180084389 | Snyder et al. | Mar 2018 | A1 |
20180137512 | Georgiadis | May 2018 | A1 |
20180253539 | Minter | Sep 2018 | A1 |
20180294977 | Uhr | Oct 2018 | A1 |
20190005470 | Uhr | Jan 2019 | A1 |
Number | Date | Country |
---|---|---|
WO 2013020126 | Feb 2013 | WO |
WO 2014098556 | Jun 2014 | WO |
WO 2015131920 | Sep 2015 | WO |
WO 2017078657 | May 2017 | WO |
WO 2017187011 | Nov 2017 | WO |
WO 2018009340 | Jan 2018 | WO |
WO 2018028777 | Feb 2018 | WO |
WO 2018053271 | Mar 2018 | WO |
WO 2018066362 | Apr 2018 | WO |
Entry |
---|
Alexandros Kaloxylos,“A survey and an Analysis of network Slicing in 5G networks” , IEEE, 2018. |
Hui Yang “Blockchain-based Trusted Authentication in Cloud Radio over Fiber Network for 5G” (2017 16th International Conference on Optical Communications and Networks (ICOCN)). |
“Cisco ASR 5x00 Mobility Management Entity Administration Guide,” Version 15.0, Cisco Systems, Inc., Last updated Jun. 13, 2014, pp. 1-266. |
“Cisco 10000 Series Router Quality of Service Configuration Guide, Chapter 20: Configuring Quality of Service for MPLS Traffic,” Cisco Systems, Inc., Updated Nov. 17, 2013, pp. 1-34. |
“Enterprise Mobility 7.3 Design Guide, Chapter 11: Cisco Mobility Services Engine,” Cisco Systems, Inc., Updated Apr. 20, 2015, 8 pages. |
“I Love WiFi, the difference between L2 and L3 Roaming Events,” Apr. 1, 2010, 6 pages. |
“Quality of Service Regulation Manual,” ITU 2017, pp. 1-174. |
“Wi-FI Location-Based Services 4.1 Design Guide,” May 20, 2008, 206 pages. |
Afolabi, Ibrahim, et al., “Network Slicing & Softwarization: A Survey on Principles, Enabling Technologies & Solutions,” Mar. 21, 2018, pp. 1-24. |
Ali, Z., et al., “Performance Measurement in Segment Routing Networks with IPv6 Data Plane (SRv6),” Spring Working Group, Feb. 26, 2018, pp. 1-17. |
An, Xueli, et al., “Virtualization of Cellular Network EPC Gateways based on a Scalable SDN Architecture,” IEEE, Feb. 12, 2015, pp. 1-7. |
Antonioli, Roberto, et al., “Dual Connectivity for LTE-NR Cellular Networks,” Research Gate, Sep. 3-6, 2017, pp. 171-175. |
Bekan, Adnan, et al., “D5.1: Machine Learning Algorithms Development and Implementation,” 2016-2018 eWINE Consortium, 23, 2016, pp. 1-72. |
Bogale, Tadilo Endeshaw, et al., “Machine Intelligence Techniques for Next-Generation Context-Aware Wireless Networks,” arxiv.org, Jan. 12, 2018, pp. 1-10. |
Carter, Steve Sr., “E911 VoIP Essentials for Enterprise Deployments,” XO Communications, LLC, 2012, 9 pages. |
Chalise, Batu K., et al., “MIMO Relaying for Multiaccess Communication in Cellular Networks,” Sensor Array and MultiChannel Signal Processing Workshop, 2008, SAM 2008, 5th IEEE, Jul. 21, 2008, pp. 146-150. |
Cheng, W., et al., “Path Segment in MPLS Based Sement Routing Network,” Network Working Group, Oct. 2017, pp. 1-10. |
Christidis, Konstantinos, et al., “Blockchains and Smart Contracts for the Internet of Things,” IEEE Access, Special Section on the of Research in Internet of Things (IoT), vol. 4, May 10, 2016, pp. 1-12. |
Cox, Jacob H. Jr., et al., “Advancing Software-Defined Networks: A Survey,” IEEE, Oct. 12, 2017, pp. 25487-25526. |
Cui, Wenzhi et al., “DiFS: Distributed Flow Scheduling for Data Center Networks,” Nanjing University, China, Jul. 28, 2013, 10 pages. |
Doyle, Matthew G., “An IP Address Management Solution fora Server Solution Provider,” A Dissertation Submitted to the University of Liverpool, Sep. 28, 2005, 116 pages. |
Galvan T., Carlos E., et al., “Wifi bluetooth based combined positioning algorithm,” International Meeting of Electrical Engineering Research ENIINVIE 2012, Procedia Engineering 35 (2012 ), pp. 101-108. |
Geller, Michael, et al. , “5G Security Innovation with Cisco,” Whitepaper Cisco Public, Jun. 8, 2018, pp. 1-29. |
Gesbert, David, “Advances in Multiuser MIMO Systems (Tutorial Part II) Emerging Topics in Multiuser MIMO Networks,” IEEE PIMRC Conference, Sep. 2007, 107 pages. |
Halperin, Daniel, et al., “Augmenting Data Center Networks with Multi-Gigabit Wireless Links,” Aug. 15-19, 2011, SIGCOMM'11, ACM 978-1-4503-0797-0/11/08, pp. 38-49. |
Herb, Daniel, et al., “Roaum: How to Unblock Roaming IoT Using BLockchain,” available at https://uploads-ssl.webflow.com/5987a08baeea4300016b7bd9/5a7a6dcee5bc400010a08f2_Roaum_Roaming_IoT_Whitepaper.pdf, pp. 1-14. |
Hsieh, Cynthia, “Location Awareness in VMware View 4.5 and Above,” VMware, 2011, 8 pages. |
Husain, Syed, et al., “Mobile Edge Computing with Network Resource Slicing for Internet-of-Things,” IEEE 2017, pp. 1-7. |
Jero, Samuel, et al., “Identifier Binding Attacks and Defenses in Software-Defined Networks,” USENIX, The Advanced Computing Systems Association, Aug. 16-18, 2017, 19 pages. |
Ji, Philip N., et al., “Demonstration of High-Speed MIMO OFDM Flexible Bandwidth Data Center Network,” Optical Society of America, 2012, 2 pages. |
Kandula, Srikanth, et al., “Flyways to De-Congest Data Center Networks,” Microsoft Research, Oct. 23, 2009, 6 pages. |
Katayama, Y. et al., “MIMO Link Design Strategy for Wireless Data Center Applications,” IEEE Wireless Communications and Networking Conference: Services, Applications, and Business, 2012, 5 pages. |
Leary, Jonathan, et al., “Wireless LAN Fundamentals: Mobility,” Jan. 9, 2004, Cisco Press, 15 pages. |
Leonhardt, Ulf, “Supporting Location-Awareness in Open Distributed Systems,” May 1998, 186 pages. |
Morozov, Yury, “Blockchain Telecom: Bubbletone Blockchain,” Dec. 29, 2017, pp. 1-33. |
Network Heresy, “NVGRE, VXLAN and What Microsoft is Doing Right,” Oct. 3, 2011, 5 pages. |
Norwegian National Security Authority, “N-03 Security guidance for switches and routers,” Sep. 26, 2012, pp. 1-24. |
Saraiva de Sousa, Nathan F., et al., “Network Service Orchestration: A Survey,” IEEE Communications Surveys & Tutorials, Mar. 23, 2018, pp. 1-30. |
Savvides, Andreas, et al., “Dynamic Fine-Grained Localization in Ad-Hoc Networks of Sensors”, Proceeding MobiCom '01 Proceedings of the 7th annual international conference on Mobile computing and networking, Jul. 2001, pp. 166-179. |
Shwetha, D., et al.,“A Bandwidth Request Mechanism for QoS Enhancement in Mobile WiMAX Networks,” International Journal of Advanced Research in Electrical Electronics and Instrumentation Engineering, vol. 3, Issue 1, Jan. 2014, pp. 1-8. |
Sun, et al., “The future of Wi-Fi,” IEEE Communications Magazine, vol. 52, No. 11, Nov. 21, 2014, 166 pages. |
Ventre, Pier Luigi, et al., “Performance Evaluation and Tuning of Virtual Infrastructure Managers for (Micro) Virtual Network Functions,” ieee.org, Nov. 7-10, 2016, pp. 1-7. |
Wright, Joshua, “Detecting Wireless LAN MAC Address Spoofing,” Jan. 21, 2003, pp. 1-20. |
Zickau, Sebastian, et al., “Enabling Location-based Policies in a Healthcare Cloud Computing Environment,” 2014 IEEE 3rd International Conference on Cloud Networking (Cloudnet), Oct. 2014, pp. 353-358. |
Number | Date | Country | |
---|---|---|---|
62682770 | Jun 2018 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 16134887 | Sep 2018 | US |
Child | 16138524 | US |