KR20170139544A - 데이터 링크 인터페이스 인터넷 프로토콜(ip) 어드레스 생성 - Google Patents

데이터 링크 인터페이스 인터넷 프로토콜(ip) 어드레스 생성 Download PDF

Info

Publication number
KR20170139544A
KR20170139544A KR1020177030379A KR20177030379A KR20170139544A KR 20170139544 A KR20170139544 A KR 20170139544A KR 1020177030379 A KR1020177030379 A KR 1020177030379A KR 20177030379 A KR20177030379 A KR 20177030379A KR 20170139544 A KR20170139544 A KR 20170139544A
Authority
KR
South Korea
Prior art keywords
data link
identifier
address
data
prefix
Prior art date
Application number
KR1020177030379A
Other languages
English (en)
Inventor
브라이언 마이클 뷔스커
아브히? 프라모드 파틸
아브히™r 프라모드 파틸
산토쉬 폴 아브라함
조지 체리안
Original Assignee
퀄컴 인코포레이티드
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by 퀄컴 인코포레이티드 filed Critical 퀄컴 인코포레이티드
Publication of KR20170139544A publication Critical patent/KR20170139544A/ko

Links

Images

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L61/00Network arrangements, protocols or services for addressing or naming
    • H04L61/50Address allocation
    • H04L61/5007Internet protocol [IP] addresses
    • H04L61/2007
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L45/00Routing or path finding of packets in data switching networks
    • H04L45/74Address processing for routing
    • H04L45/741Routing in networks with a plurality of addressing schemes, e.g. with both IPv4 and IPv6
    • H04L61/2038
    • H04L61/2046
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L61/00Network arrangements, protocols or services for addressing or naming
    • H04L61/50Address allocation
    • H04L61/5038Address allocation for local use, e.g. in LAN or USB networks, or in a controller area network [CAN]
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L61/00Network arrangements, protocols or services for addressing or naming
    • H04L61/50Address allocation
    • H04L61/5046Resolving address allocation conflicts; Testing of addresses
    • H04L61/6004
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L69/00Network arrangements, protocols or services independent of the application payload and not provided for in the other groups of this subclass
    • H04L69/22Parsing or analysis of headers
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L2101/00Indexing scheme associated with group H04L61/00
    • H04L2101/60Types of network addresses
    • H04L2101/604Address structures or formats

Landscapes

  • Engineering & Computer Science (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Signal Processing (AREA)
  • Computer Security & Cryptography (AREA)
  • Mobile Radio Communication Systems (AREA)
  • Data Exchanges In Wide-Area Networks (AREA)

Abstract

장치는 메모리 및 메모리에 커플링되는 프로세서를 포함한다. 프로세서는, 데이터 링크 그룹의 데이터 링크 그룹 식별자에 대응하는 제1 식별자를 결정하고 그리고 디바이스에 대응하는 제2 식별자를 결정하도록 구성된다. 프로세서는 추가로, 데이터 링크 라우팅 프리픽스, 제1 식별자, 및 제2 식별자의 결합에 기초하여, 디바이스의 데이터 링크 인터페이스에 대한 인터넷 프로토콜(IP) 어드레스를 생성하도록 구성된다.

Description

데이터 링크 인터페이스 인터넷 프로토콜(IP) 어드레스 생성
[0001] 본 출원은, "DATA LINK INTERFACE INTERNET PROTOCOL (IP) ADDRESS GENERATION"이라는 명칭으로 2016년 4월 21일자로 출원된 미국 특허 출원 제15/134,572호, 및 "NEIGHBOR AWARE NETWORK DATA LINK (NDL) INTERFACE INTERNET PROTOCOL (IP) ADDRESS GENERATION"이라는 명칭으로 2015년 4월 23일자로 출원된 미국 가특허 출원 제62/151,954호, 및 "NEIGHBOR AWARE NETWORK DATA LINK (NDL) INTERFACE INTERNET PROTOCOL (IP) ADDRESS GENERATION"이라는 명칭으로 2015년 8월 24일자로 출원된 미국 가특허 출원 제62/209,279호를 우선권으로 주장하며, 상기 출원들은 그 전체가 인용에 의해 본원에 명백히 포함된다.
[0002] 본 개시내용은 일반적으로 데이터 링크 인터페이스 인터넷 프로토콜(IP; internet protocol) 어드레스 생성에 관한 것이다.
[0003] 무선 디바이스들이 더 저렴해지고 더 보편화됨에 따라, 네트워크들이 증가된 트래픽을 겪을 수 있고, 증가된 트래픽은, 잠재적으로 네트워크들에 부담을 주게 되고, 무선 디바이스들의 성능을 둔화시키고, 그리고 사용자들이 불만을 갖게 할 수 있다. 따라서, 네트워크 셋업 및 네트워크 리소스 할당(예컨대, 네트워크 내에서 트래픽이 라우팅(route)되는 방식)이 무선 네트워크들의 구현 및 설계에서 고려될 수 있다.
[0004] 근접-기반 서비스들은, (예컨대, 이웃 인식 네트워크(NAN; neighbor-aware network) 또는 무선 메시(mesh) 네트워크를 통해) 서로의 특정 거리 내에 있는 디바이스들 간의 직접 통신을 인에이블링(enable)할 수 있다. 데이터 링크 그룹(예컨대, 소셜 Wi-Fi(social wireless fidelity) 네트워크, 이를테면 메시 네트워크)은 NAN과 같은 무선 네트워크 위에 구축될 수 있다. 예시를 위해,, 데이터 링크 그룹(NAN 데이터 링크(NDL; NAN data link)로 또한 지칭됨)의 디바이스들은 무선 네트워크의 일부일 수 있다. 특정 디바이스는 다수의 데이터 링크 그룹들에 포함될 수 있다. 예를 들어, 특정 디바이스의 제1 데이터 링크 인터페이스는 제1 데이터 링크 그룹에 대응할 수 있고, 특정 디바이스의 제2 데이터 링크 인터페이스는 제2 데이터 링크 그룹에 대응할 수 있다. 특정 디바이스는 애플리케이션을 포함할 수 있다. 애플리케이션으로부터의 제1 데이터는 제1 데이터 링크 인터페이스를 통해 제1 데이터 링크 그룹의 하나 또는 그 초과의 디바이스들에 전송될 수 있다. 애플리케이션으로부터의 제2 데이터는 제2 데이터 링크 인터페이스를 통해 제2 데이터 링크 그룹의 하나 또는 그 초과의 디바이스들에 전송될 수 있다.
[0005] 특정 양상에서, 장치는 메모리 및 메모리에 커플링되는 프로세서를 포함한다. 프로세서는, 데이터 링크 그룹의 데이터 링크 그룹 식별자에 대응하는 제1 식별자를 결정하도록 구성된다. 프로세서는, 디바이스에 대응하는 제2 식별자를 결정하도록 구성된다. 프로세서는 추가로, 데이터 링크 라우팅 프리픽스(prefix), 제1 식별자, 및 제2 식별자의 결합에 기초하여, 디바이스의 데이터 링크 인터페이스에 대한 인터넷 프로토콜(IP) 어드레스를 생성하도록 구성된다.
[0006] 다른 양상에서, 방법은, 디바이스에 의해, 데이터 링크 그룹의 데이터 링크 그룹 식별자에 대응하는 제1 식별자를 결정하는 단계를 포함한다. 방법은, 디바이스에 의해, 디바이스에 대응하는 제2 식별자를 결정하는 단계를 포함한다. 방법은, 디바이스에 의해, 데이터 링크 라우팅 프리픽스, 제1 식별자, 및 제2 식별자에 기초하여, 디바이스의 데이터 링크 인터페이스에 대한 인터넷 프로토콜(IP) 어드레스를 생성하는 단계를 더 포함한다.
[0007] 다른 양상에서, 장치는, 데이터 링크 그룹의 데이터 링크 그룹 식별자에 대응하는 제1 식별자를 결정하기 위한 수단을 포함한다. 장치는, 디바이스에 대응하는 제2 식별자를 결정하기 위한 수단을 포함한다. 장치는, 데이터 링크 라우팅 프리픽스, 제1 식별자, 및 제2 식별자의 결합에 기초하여, 디바이스의 데이터 링크 인터페이스에 대한 인터넷 프로토콜(IP) 어드레스를 생성하기 위한 수단을 더 포함한다.
[0008] 다른 양상에서, 컴퓨터-판독가능 저장 디바이스는 명령들을 저장하며, 명령들은, 프로세서에 의해 실행되는 경우 프로세서로 하여금, 데이터 링크 그룹의 데이터 링크 그룹 식별자에 대응하는 제1 식별자를 결정하는 것을 포함하는 동작들을 수행하게 한다. 동작들은, 디바이스에 대응하는 제2 식별자를 결정하는 것을 포함한다. 동작들은, 데이터 링크 라우팅 프리픽스, 제1 식별자, 및 제2 식별자에 기초하여, 디바이스의 데이터 링크 인터페이스에 대한 인터넷 프로토콜(IP) 어드레스를 생성하는 것을 더 포함한다.
[0009] 본 개시내용은 발명의 내용에서 설명된 양상들에 기반하여 제한되도록 의도되지 않는다. 본 개시내용의 다른 양상들, 이점들, 및 특징들은, 다음의 섹션들, 즉, 도면의 간단한 설명, 발명을 실시하기 위한 구체적인 내용, 및 청구범위를 포함하는 전체 출원을 검토한 후 명백해질 것이다.
[0010] 도 1은, 하나 또는 그 초과의 데이터 링크 그룹들을 포함하는 시스템의 예시적인 예의 블록도이다.
[0011] 도 2는, 도 1의 시스템의 디바이스의 예시적인 예의 블록도이다.
[0012] 도 3a는 IPv6(IP version 6) 데이터 패킷의 예시적인 제1 예의 도면이다.
[0013] 도 3b는 IPv6 어드레스의 예시적인 제1 예의 도면이다.
[0014] 도 3c는 IPv6 어드레스의 예시적인 제2 예의 도면이다.
[0015] 도 4는 IPv4(IP version 4) 데이터 패킷의 예시적인 예의 도면이다.
[0016] 도 5는 데이터 링크 인터페이스 IP 어드레스 생성 방법의 예를 예시하기 위한 흐름도이다.
[0017] 도 6은 데이터 링크 인터페이스 IP 어드레스 생성 방법의 다른 예를 예시하기 위한 흐름도이다.
[0018] 도 7은 데이터 링크 인터페이스 IP 어드레스 생성 방법의 또 다른 예를 예시하기 위한 흐름도이다.
[0019] 도 8은, 도 1 내지 도 7의 시스템들 및 방법들에 따라 데이터 링크 인터페이스 IP 어드레스 생성을 수행하도록 동작가능한 디바이스의 블록도이다.
[0020] 본 개시내용의 특정 양상들이 도면들을 참조하여 아래에 설명된다. 설명에서, 공통 특징들은 공통 참조 번호들로 표기된다. 본원에서 사용되는 바와 같이, 다양한 용어는 오직 특정 구현들을 설명하려는 목적을 위해 사용되며, 제한하는 것으로 의도되지 않는다. 예를 들어, 맥락이 명확하게 달리 표시하지 않으면, 단수 형태들은 복수 형태들을 또한 포함하도록 의도된다. 용어들 "포함하다" 및 "포함하는"은 "구비하다" 또는 "구비하는"과 상호교환가능하게 사용될 수 있음이 추가로 이해될 수 있다. 부가적으로, 용어 "여기서"는 "여기에서"와 상호교환가능하게 사용될 수 있음이 이해될 것이다. 본원에 사용되는 바와 같이, 구조, 컴포넌트, 동작 등과 같은 엘리먼트를 수정하는 데 사용되는 서수 용어(예컨대, "제1", "제2", "제3" 등)는 그 자체로 다른 엘리먼트에 대한 그 엘리먼트의 임의의 우선순위 또는 순서를 표시하는 것이 아니라, 오히려, 단순히 (서수 용어의 사용이 없었다면) 동일한 명칭을 갖는 다른 엘리먼트와 그 엘리먼트를 구별한다. 본원에 사용되는 바와 같이, 용어 "서브세트"는 하나 또는 그 초과의 엘리먼트들의 그룹화를 지칭하고, 용어 "복수"는 다수의 엘리먼트들을 지칭한다.
[0021] 도 1을 참조하면, 하나 또는 그 초과의 데이터 링크 그룹들을 포함하는 시스템(100)의 예시적인 예가 도시된다. 시스템(100)은 무선 네트워크(101), 이를테면 데이터 링크 그룹 네트워크 또는 이웃 인식 네트워크(NAN)를 포함한다. 무선 네트워크(101)는 다수의 디바이스들, 이를테면 대표 디바이스들(120), 제2 디바이스(108), 및 제1 디바이스(110)를 포함할 수 있다.
[0022] 무선 네트워크(101)는 하나 또는 그 초과의 데이터 링크 그룹들(예컨대, 하나 또는 그 초과의 메시들 또는 메시 네트워크들)을 포함하거나 그에 대응할 수 있다. 본원에 사용되는 바와 같이, 데이터 링크 그룹은 기반구조가 없는(infrastructure-less) 피어-투-피어(peer-to-peer) 네트워크, 이를테면 애드-혹(ad-hoc) 네트워크를 포함할 수 있다. 데이터 링크 그룹은, 분산화된(decentralized) 무선 네트워크와 같은 네트워크를 형성할 수 있는 다수의 디바이스들을 포함할 수 있다. 부가적으로, 데이터 링크 그룹의 각각의 디바이스는, 데이터 링크 그룹에 의해 사용되는 하나 또는 그 초과의 통신 채널들을 이용하여 대역 내(in band)에서 또는 대역 외(out of band)에서 교환될 수 있는 공통 보안 크리덴셜(security credential)들을 사용할 수 있다. 몇몇 구현들에서, 데이터 링크 그룹의 디바이스들은, 디바이스들 각각이 트래픽과 다른 메시지들을 통지(advertise) 및 수신하기 위해 어웨이크(awake)되어 있는 시간 기간들과 같은 주기적 웨이크-업(wake-up) 시간들을 갖도록 동기화될 수 있다.
[0023] 무선 네트워크(101)는, 디바이스들(108, 110, 120)과 같은 하나 또는 그 초과의 디바이스들을 포함하는 데이터 링크 그룹을 포함하거나 그에 대응할 수 있다. 데이터 링크 그룹은 또한, 데이터 링크, 데이터 링크 네트워크, 그룹 네트워크, NAN 데이터 링크(NDL), NDL 네트워크, 데이터 경로 그룹, 데이터 경로 그룹 네트워크, NAN 데이터 경로, NAN 데이터 경로 그룹, 또는 NAN 데이터 경로 그룹 네트워크로 지칭될 수 있다. 몇몇 구현들에서, 데이터 링크 그룹은, 예시적인 비-제한적인 예들로서, "소셜 Wi-Fi 메시 네트워크" 또는 IEEE(Institute of Electrical and Electronics Engineers) 802.11s 메시 네트워크와 같은 메시 네트워크에 포함된 메시 그룹일 수 있다. 다른 예로서, 데이터 링크 그룹은 기반구조가 없는 p2p(peer-to-peer) 네트워크를 포함할 수 있다. 특정 양상에서, 데이터 링크 그룹은 "멀티-홉(multi-hop)" 데이터 링크 그룹일 수 있고, 메시지들 및 데이터는 데이터 링크 그룹의 제1 디바이스로부터 데이터 링크 그룹의 다른 전자 디바이스들로 송신될 수 있으며, 그 다른 디바이스들은 메시지 및 데이터를 더 많은 디바이스들로 전파할 수 있다. 다른 특정 양상에서, 데이터 링크 그룹은 "단일-홉(single-hop)" 데이터 링크 그룹일 수 있고, 제공자 디바이스에 의해 페이징 메시지가 데이터 링크 그룹의 하나 또는 그 초과의 디바이스들로 송신될 수 있다.
[0024] 디바이스들(108, 110, 120) 각각은, 무선 네트워크(101)에 포함된 하나 또는 그 초과의 다른 무선 통신 디바이스들에 데이터를 송신하거나, 그들로부터 데이터를 수신하거나, 또는 송신 및 수신 둘 모두를 행하도록 구성되는 무선 통신 디바이스일 수 있다. 무선 네트워크(101)는 기반구조 네트워크 또는 기반구조가 없는 네트워크, 이를테면 피어-투-피어 네트워크(예컨대, 애드-혹 네트워크)일 수 있다. 예를 들어, 무선 네트워크(101)(예컨대, NAN)의 디바이스들(108, 110, 120) 각각은, NAN에 대응하는 하나 또는 그 초과의 무선 채널들을 통해, 연관 동작들(예컨대, 보안 연관 동작들), 보안 정보 교환 동작들, 동기화 동작들, 협상(negotiation) 동작들, 및 다른 동작들을 수행하도록 구성될 수 있다. 몇몇 구현들에서, 디바이스들(108, 110, 120)은, 예시적인 비-제한적인 예들로서, IEEE(Institute of Electrical and Electronics Engineers) 802.11 표준(예컨대, IEEE 802.11s 표준), Wi-Fi Alliance 표준, NAN 표준, 또는 이들의 결합과 같은 하나 또는 그 초과의 표준들에 따라 그러한 동작들을 수행할 수 있다. 예를 들어, 시스템(100)의 디바이스들(108, 110, 120)은, 하나 또는 그 초과의 무선 통신 프로토콜들에 따라 무선으로 통신하도록 구성될 수 있다. 예시를 위해,, 시스템(100)의 디바이스들(108, 110, 120)은, 탐색 메시지들, 이를테면 IEEE(Institute of Electrical and Electronics Engineers) 802.11 프로토콜과 관련된 비컨(beacon)들을 전송 및 수신할 수 있다. 이러한 맥락에서, 프로토콜은, 통신하는 데 사용되는 파라미터들, 이를테면 채널(이를 통해 통신들이 발생함)의 식별자, 통신들의 타이밍(예컨대, 탐색 인터벌(interval)들의 타이밍) 등을 지칭할 수 있다. 다른 예에서, 시스템(100)의 디바이스들(108, 110, 120)은 또한, 시스템(100)의 하나 또는 그 초과의 디바이스들(108, 110, 120)에 공통인 특정 애플리케이션(또는 서비스)에 대응하는 데이터와 같은 데이터를 통신할 수 있다. 시스템(100)은, 예시된 개수의 디바이스들보다 더 많은 개수 또는 더 적은 개수의 디바이스들을 포함할 수 있다.
[0025] 무선 네트워크(101)(예컨대, NAN)의 다수의 디바이스들은, 무선 네트워크(101)의 탐색 윈도우(window)들 동안 다수의 디바이스들이 주기적으로 웨이크 업(예컨대, 활성(active) 모드로 스위칭)할 수 있게 하도록 (예컨대, 비컨들을 사용하여) 동기화될 수 있다. 다수의 디바이스들 각각은, 탐색 윈도우들 동안 동일한 NAN 통신 채널을 모니터링할 수 있다. 무선 네트워크(101)는 NAN 식별자에 의해 식별될 수 있다. NAN 식별자는, 각각의 NAN 메시지에, 이를테면 각각의 NAN 탐색 메시지에 포함될 수 있다. 무선 네트워크(101)의 형성을 개시하는 디바이스는 대응하는 NAN 식별자를 선택할 수 있다.
[0026] 다수의 디바이스들의 서브세트는, 무선 네트워크(101)에 대응하는 NAN 통신 채널을 통해 동기화 비컨들, 탐색 비컨들, 또는 둘 모두를 송신할 수 있다. 탐색 메시지들 및 동기화 비컨들은, NAN 통신 채널을 통해, 탐색 윈도우들 동안 다수의 디바이스들 중 하나 또는 그 초과에 의해 송신될 수 있다. 탐색 메시지는, (무선 네트워크(101)에 포함되지 않은) 디바이스에 의해, 무선 네트워크(101)를 탐색하고 디바이스가 무선 네트워크(101)에 참여할 수 있게 하기 위해 사용될 수 있다. 동기화 비컨은, TSF(time synchronization function) 보정을 위해 무선 네트워크(101)의 다수의 디바이스들에 의해 사용될 수 있다.
[0027] 몇몇 구현들에서, 무선 네트워크(101)는 트리(tree) 구조와 같은 구조를 가질 수 있다. 예를 들어, 구조(예컨대, 트리 구조)는 다수의 디바이스들 중 (앵커 마스터(anchor master)로 지칭되는) 특정 디바이스에서 앵커링될 수 있다. 앵커 마스터의 타이밍은, 하나 또는 그 초과의 동기화(싱크(synch)) 디바이스들 및 하나 또는 그 초과의 마스터 디바이스들을 통해 무선 네트워크(101)의 다수의 디바이스들 각각에 전파될 수 있다. 하나 또는 그 초과의 싱크 디바이스들 및 하나 또는 그 초과의 마스터 디바이스들은 무선 네트워크 내에서의 시간 동기화를 가능하게 할 수 있다.
[0028] 무선 네트워크(101)에 대응하는 하나 또는 그 초과의 데이터 링크 그룹들(예컨대, 제1 데이터 링크 그룹(132), 제2 데이터 링크 그룹(134), 제3 데이터 링크 그룹(136))이 존재할 수 있다. 특정 예시적인 구현에서, 데이터 링크 그룹은 NAN의 NDL 그룹을 포함하거나 그에 대응할 수 있다. 다른 특정 구현에서, 데이터 링크 그룹은, 예시적인 비-제한적인 예들로서, "소셜 wi-fi 메시" 네트워크 또는 무선 메시 네트워크의 서브세트와 같은 무선 메시 네트워크를 포함하거나 그에 대응할 수 있다. 다른 예시적인 비-제한적인 예들에서, 본 개시내용의 기술들은 기반구조가 없는 p2p(peer-to-peer) 네트워크 또는 다른 형태의 기반구조가 없는 디바이스-투-디바이스 직접 네트워크에서 사용될 수 있다. 데이터 링크 그룹의 디바이스들은 (예컨대, 하나 또는 그 초과의 무선 캐리어들, 하나 또는 그 초과의 Wi-Fi(wireless fidelity) 액세스 포인트들, 인터넷, 또는 이들의 결합을 수반함이 없이도) 무선 통신들을 통해 데이터 교환들을 수행할 수 있다. 예를 들어, 데이터 링크 그룹의 디바이스들은, 통신을 인에이블링하기 위해, 그룹 키(예컨대, 공통 그룹 키)와 같은 보안 크리덴셜을 공유할 수 있다. 예시를 위해,, 데이터 링크 그룹의 각각의 디바이스는, 그룹 메시지들을 인코딩하거나, 디코딩하거나, 또는 둘 모두를 행하는 데 그룹 키를 사용할 수 있다. 몇몇 구현들에서, 데이터 링크 그룹의 디바이스들 중 하나 또는 그 초과에 의해 하나 또는 그 초과의 서비스들이 제공될 수 있다. 하나 또는 그 초과의 서비스들은, 예시적인 비-제한적인 예들로서, 뮤직 서비스, 소셜 미디어 공유 서비스, 파일 공유 서비스, 다른 서비스, 또는 이들의 결합을 포함할 수 있다. 몇몇 구현들에서, 하나 또는 그 초과의 서비스들은 하나 또는 그 초과의 NDL 서비스들을 포함하거나 그에 대응할 수 있다.
[0029] 특정 구현에서, 데이터 링크 그룹들(132-136)은, 별개의 애플리케이션들, 별개의 벤더(vendor)들, 별개의 타입들의 디바이스들, 별개의 운영 시스템들, 또는 이들의 결합에 대응할 수 있다. 특정 디바이스는 하나 또는 그 초과의 데이터 링크 그룹들에 포함될 수 있다. 예를 들어, 제1 디바이스(110)는 제1 데이터 링크 그룹(132)에 포함될 수 있다. 다른 예로서, 제2 디바이스(108)는 제1 데이터 링크 그룹(132) 및 제2 데이터 링크 그룹(134)에 포함될 수 있다. 무선 네트워크(101)의 각각의 데이터 링크 그룹은, 대응하는 그룹 식별자, 이를테면 고유 값(예컨대, 바이트 값, 그룹 어드레스, 또는 이들의 결합)을 가질 수 있다. 예를 들어, 제1 데이터 링크 그룹(132)은 제1 데이터 링크 그룹 식별자(142)를 가질 수 있다. 다른 예로서, 제2 데이터 링크 그룹(134)은 제2 데이터 링크 그룹 식별자(144)를 가질 수 있다. 몇몇 구현들에서, 데이터 링크 그룹 식별자는 NDL 그룹 식별자를 포함하거나 그에 대응할 수 있다.
[0030] 제공자 디바이스는, 서비스에 대응하는 데이터를 데이터 링크 그룹의 하나 또는 그 초과의 디바이스들에 제공할 수 있다. 몇몇 구현들에서, 제공자 디바이스는 원격통신 연결을 통해 데이터를 수신할 수 있다. 예를 들어, 제공자 디바이스는, 기지국과 무선으로 통신하고 그리고 서비스에 대응하는 데이터를 기지국을 통해 수신할 수 있다. 프록시(proxy) 디바이스는, 서비스에 대응하는 데이터를 디바이스로부터 수신할 수 있고, 그 데이터를 다른 디바이스들에 포워딩할 수 있다. 소비자 디바이스는, 서비스에 대응하는 데이터를 디바이스로부터 수신할 수 있다. 특정 구현에서, 제1 데이터 링크 그룹(132)은 무선 네트워크(101)에 포함된 다수의 디바이스들의 제1 서브세트를 포함할 수 있고, 제2 데이터 링크 그룹(134)은 다수의 디바이스들의 제2 서브세트를 포함할 수 있고, 그리고 제3 데이터 링크 그룹(136)은 다수의 디바이스들의 제3 서브세트를 포함할 수 있다. 디바이스들의 각각의 서브세트는, 디바이스들의 서브세트 중 다른 서브세트로부터의 하나 또는 그 초과의 디바이스들을 포함할 수 있다. 예시를 위해,, 제2 디바이스(108)는 특정 데이터 링크 그룹(예컨대, 제2 데이터 링크 그룹(134))에서의 제1 서비스의 제공자 디바이스일 수 있거나, 다른 데이터 링크 그룹(예컨대, 제1 데이터 링크 그룹(132))에서의 제2 서비스의 프록시 디바이스일 수 있거나, 또 다른 데이터 링크 그룹에서의 제1 서비스, 제2 서비스, 또는 제3 서비스 중 하나 또는 그 초과의 서비스의 소비자 디바이스일 수 있거나, 또는 이들의 결합일 수 있다.
[0031] 제1 데이터 링크 그룹(132)의 특정 디바이스는, 탐색 메시지를 전송(예컨대, 송신)함으로써 서비스의 가용성을 통지할 수 있다. 탐색 메시지는 제1 데이터 링크 그룹 식별자(142)를 포함할 수 있다. 탐색 메시지를 수신하는 것에 대한 응답으로, 하나 또는 그 초과의 디바이스들은, 서비스에 대응하는 데이터를 수신하기 위해 제1 데이터 링크 그룹(132)에 참여할 수 있다. 몇몇 구현들에서, 특정 디바이스는, 탐색 메시지, 서비스에 대응하는 데이터, 또는 이들의 결합을 제1 데이터 링크 그룹(132)의 다수의 디바이스들에 멀티캐스팅(multicast)할 수 있다.
[0032] 제1 디바이스(110)는, 데이터 링크 네트워킹 회로(114), 제1 데이터 링크 인터페이스(112), 메모리(116), 또는 이들의 결합을 포함할 수 있다. 데이터 링크 네트워킹 회로(114)는, 제1 디바이스(110)의 동작을 참조하여 본원에 설명된 하나 또는 그 초과의 기능들을 수행하도록 구성될 수 있다. 예를 들어, 제1 디바이스(110)에 의해 수행되는 것으로 본원에 설명되는 하나 또는 그 초과의 동작들은 데이터 링크 네트워킹 회로(114)에 의해 수행될 수 있다. 제1 데이터 링크 인터페이스(112)는, 제1 데이터 링크 그룹(132)의 하나 또는 그 초과의 디바이스들과 통신하도록 구성되는 네트워크 인터페이스일 수 있다. 몇몇 구현들에서, 데이터 링크 네트워킹 회로는 NDL 네트워킹 회로를 포함하거나 그에 대응할 수 있다. 메모리(116)는 네트워킹 데이터(192)를 포함할 수 있다. 네트워킹 데이터(192)는, 본원에 추가로 설명되는, 제1 데이터(150), 제2 데이터(152), IP 어드레스(154), 데이터 링크 서브넷(subnet) 식별자(156), 라우팅 프리픽스(158), MAC 어드레스(160), 또는 이들의 결합을 포함할 수 있다.
[0033] 동작 동안, 제1 디바이스(110)는, 제1 데이터 링크 그룹 식별자(142)에 대응하는 제1 데이터(150)(예컨대, 제1 식별자)를 결정할 수 있다. 예를 들어, 제1 디바이스(110)는, 제1 데이터 링크 그룹 식별자(142)에 대응하는 제1 데이터(150)를 생성 또는 수신할 수 있다. 예시를 위해,, 제1 디바이스(110)는, 제1 데이터 링크 그룹(132)을 통해 제1 서비스를 제공하는 데 제1 디바이스(110)가 이용가능하다는 것을 표시하는 탐색 메시지를 생성할 수 있다. 제1 디바이스(110)는 제1 데이터(150)를 탐색 메시지에 포함시킬 수 있다. 다른 예시로서, 제1 디바이스(110)는, 제1 데이터(150)를 포함하는 탐색 메시지를 제1 데이터 링크 그룹(132)의 디바이스로부터 수신할 수 있다.
[0034] 탐색 메시지는 제1 데이터 링크 그룹 식별자(142)를 표시하는 식별자 데이터를 포함할 수 있다. 제1 데이터 링크 그룹 식별자(142)는 무선 네트워크(101) 내의 제1 데이터 링크 그룹 식별자(132)에 대해 고유할 수 있다. 예를 들어, 제1 디바이스(110)는, 제1 데이터 링크 그룹 식별자(142)가 무선 네트워크(101)에서 사용 중인 데이터 링크 그룹 식별자들과 충돌하지 않도록, 제1 데이터 링크 그룹 식별자(142)를 생성할 수 있다. 예시를 위해,, 제1 디바이스(110)는, 최근에 사용되지 않은 데이터 링크 그룹 식별자들을 표시하는 그룹 식별자 데이터를 유지할 수 있다. 특정 구현에서, 제1 디바이스(110)는, 특정 데이터 링크 그룹 식별자를 표시하는 메시지를 수신하는 것에 대한 응답으로, 특정 데이터 링크 그룹 식별자를 그룹 식별자 데이터에 부가할 수 있다.
[0035] 제1 디바이스(110)는, 그룹 식별자 데이터에 의해 표시되는 데이터 링크 그룹 식별자들과 구별되도록, 제1 데이터 링크 그룹 식별자(142)를 생성할 수 있다. 특정 구현에서, 제1 디바이스(110)는, 제1 데이터 링크 그룹 식별자(142)에 해시 함수(hash function)(180)를 적용한 결과가 그룹 식별자 데이터에 의해 표시되는 데이터 링크 그룹 식별자들에 해시 함수(180)를 적용한 결과들과 구별되도록, 제1 데이터 링크 그룹 식별자(142)를 생성할 수 있다. 해시 함수(180)는 사용자-정의될 수 있다. 예를 들어, 제1 디바이스(110)는 사용자 입력에 기초하여 해시 함수(180)를 결정할 수 있다. 특정 구현에서, 해시 함수(180)는 디폴트 기능(default function)에 대응할 수 있다.
[0036] 제1 데이터(150)는, 예시적인 비-제한적인 예들로서, 제1 데이터 링크 그룹 식별자(142), 또는 제1 데이터 링크 그룹 식별자(142)에 해시 함수(180)를 적용한 결과에 대응할 수 있다. 제1 데이터 링크 그룹 식별자(142)는 48개의 비트들을 포함할 수 있다. 몇몇 구현들에서, 제1 데이터 링크 그룹 식별자(142)에 해시 함수(180)를 적용한 결과는 16개의 비트들을 포함할 수 있다.
[0037] 제1 디바이스(110)는, 제1 디바이스(110)에 대응하는 제2 데이터(152)(예컨대, 제2 식별자)를 결정할 수 있다. 예를 들어, 제1 디바이스(110)는, 제1 디바이스(110)의 MAC(media access control) 식별자(예컨대, MAC 어드레스(160))에 기초하여 제2 데이터(152)를 생성할 수 있다. 몇몇 구현들에서, MAC 어드레스(160)는 48개의 비트들을 포함할 수 있다. 부가적으로 또는 대안적으로, 제2 데이터(152)는 64개의 비트들을 포함할 수 있다. 제1 디바이스(110)는, IEEE EUI-64(64-bit Extended Unique Identifier) 포맷에 따른 MAC 어드레스(160)에 기초하여 제2 데이터(152)를 생성할 수 있다.
[0038] 제1 디바이스(110)는 또한 라우팅 프리픽스(158)를 결정할 수 있다. 특정 구현에서(예컨대, IPv6 어드레스들이 사용되는 경우), 라우팅 프리픽스(158)는, 데이터 링크 네트워크들에 전용되는 데이터 링크 라우팅 프리픽스일 수 있다. 예를 들어, 이러한 특정 구현에서, 데이터 링크 라우팅 프리픽스는 48개의 비트들을 포함할 수 있다. 제1 디바이스(110)는, 라우팅 프리픽스(158), 제1 데이터(150), 및 제2 데이터(152)에 기초하여 IP 어드레스(154)를 생성할 수 있다. 예를 들어, 제1 디바이스(110)는, 라우팅 프리픽스(158), 제1 데이터(150), 및 제2 데이터(152)를 결합(예컨대, 연접(concatenate))시킴으로써 IP 어드레스(154)를 생성할 수 있다. IP 어드레스(154)는, 예컨대, 라우팅 프리픽스(158)가 데이터 링크 라우팅 프리픽스(예컨대, 48개의 비트들)에 대응하고, 제1 데이터(150)가 16개의 비트들을 포함하고, 그리고 제2 데이터(152)가 64개의 비트들을 포함하는 경우, 128-비트 IPv6 어드레스에 대응할 수 있다. 몇몇 구현들에서, 데이터 링크 라우팅 프리픽스는, 하나 또는 그 초과의 NAN들의 NDL들에서의(또는 이들에 의한) 사용에 전용되는 NDL 라우팅 프리픽스를 포함하거나 그에 대응할 수 있다.
[0039] 다른 특정 구현에서(예컨대, IPv4 어드레스들이 사용되는 경우), 라우팅 프리픽스(158)는 비-전역적으로(non-globally) 라우팅가능한 프리픽스(예컨대, 0x10)에 대응할 수 있다. 이러한 특정 구현에서, 라우팅 프리픽스(158)는 8개의 비트들을 포함할 수 있고, 결합된 제1 데이터(150)와 제2 데이터(152)는 24개의 비트들을 포함할 수 있다. 이러한 구현에서, IP 어드레스(154)는 32-비트 IPv4 어드레스를 포함할 수 있다. 결합된 라우팅 프리픽스(158)와 제1 데이터(150)는 데이터 링크 서브넷 식별자(156)에 대응할 수 있다. 특정 양상에서, 제1 디바이스(110)는, 데이터 링크 서브넷 식별자(156) 및 제2 데이터(152)에 기초하여 IP 어드레스(154)를 생성할 수 있다. 예를 들어, 제1 디바이스(110)는, 데이터 링크 서브넷 식별자(156)와 제2 데이터(152)를 결합(예컨대, 연접)시킴으로써 IP 어드레스(154)를 생성할 수 있다. 몇몇 구현들에서, 데이터 링크 서브넷 식별자는 NDL 서브넷 식별자를 포함하거나 그에 대응할 수 있다.
[0040] IP 어드레스(154)는 제1 데이터 링크 인터페이스(112)에 대응할 수 있다. 제1 디바이스(110)는, 제1 데이터 링크 그룹(132)의 하나 또는 그 초과의 디바이스들과 통신하기 위해 제1 데이터 링크 인터페이스(112)를 사용할 수 있다. 예시를 위해,, 제1 디바이스(110)는, 제1 헤더 및 페이로드(payload)를 갖는 제1 데이터 패킷을 생성할 수 있다. 페이로드는, 제1 디바이스(110)로부터 제1 데이터 링크 그룹(132)의 하나 또는 그 초과의 디바이스들로 전송될 데이터를 포함할 수 있다. 제1 헤더는, 제1 데이터 패킷의(또는 이에 대한) 소스 어드레스로서 IP 어드레스(154)를 표시하는 어드레스 데이터를 포함할 수 있다. 제1 디바이스(110)는, 제1 데이터 링크 인터페이스(112)를 통해 제1 데이터 링크 그룹(132)의 하나 또는 그 초과의 디바이스들로 (이를테면 제1 데이터 패킷을 멀티캐스팅함으로써) 제1 데이터 패킷을 전송할 수 있다.
[0041] 제1 디바이스(110)의 수신기는, 제2 헤더를 갖는 제2 데이터 패킷을 수신할 수 있다. 제2 헤더는, 제2 데이터 패킷의(또는 이에 대한) 목적지(destination) 어드레스로서 IP 어드레스(154)를 포함할 수 있다. 제1 디바이스(110)의 수신기는, IP 어드레스(154)가 제1 데이터 링크 인터페이스(112)에 대응한다는 결정에 대한 응답으로, 제2 데이터 패킷을 제1 데이터 링크 인터페이스(112)에 제공하도록 구성될 수 있다. 예를 들어, 제1 디바이스(110)는 라우팅 테이블(188)을 포함할 수 있고, 라우팅 테이블(188)에 기초하여, IP 어드레스(154)가 제1 데이터 링크 인터페이스(112)에 대응한다는 것을 결정할 수 있다. 라우팅 테이블(188)은, IP 어드레스들의 데이터 링크 인터페이스로의 "맵핑"을 포함할 수 있다. 예시를 위해,, 라우팅 테이블(188)은, IP 어드레스(154)가 제1 데이터 링크 인터페이스(112)에 대응한다는 것(또는 맵핑된다는 것)을 표시하는 데이터를 포함할 수 있다. 제1 디바이스(110)는, 데이터 링크 인터페이스의 IP 어드레스가 변경되는 경우 라우팅 테이블(188)을 업데이트할 수 있다. 라우팅 테이블(188)은, 예시적인 비-제한적인 예들로서, 제1 디바이스(110)의 메모리(116) 또는 프로세서의 레지스터에 저장될 수 있다.
[0042] 특정 양상에서, 제1 데이터 패킷의 제1 헤더는 QoS(quality of service) 필드(예컨대, 트래픽 클래스(traffic class) 필드)를 포함할 수 있다. 제1 디바이스(110)는, QoS 필드에 기초하여, 송신을 위해 제1 데이터 패킷을 프로세싱을 할 수 있다. 예를 들어, 제1 디바이스(110)는, 제1 데이터 패킷의 QoS 필드가 다른 패킷의 제2 QoS 필드의 제2 QoS 데이터보다 더 높은 송신 우선순위를 표시하는 QoS 데이터를 포함한다고 결정하는 것에 대한 응답으로, 다른 패킷보다 먼저 제1 데이터 패킷을 송신할 수 있다. QoS 필드에 포함된 QoS 데이터는, 도 2를 참조하여 설명되는 바와 같이, 하나 또는 그 초과의 애플리케이션들에 데이터 링크들을 할당하는 데 사용될 수 있다.
[0043] 특정 양상에서, 제1 디바이스(110)는, 데이터 링크 서브넷 식별자(156)(또는 IP 어드레스(154))가 NAN(예컨대, 무선 네트워크(101)), 제1 데이터 링크 그룹(132), 또는 둘 모두의 디바이스들에 의해 사용되는 서브넷의 식별자(또는 IP 어드레스)와 충돌하는지 여부를 결정할 수 있다. 예를 들어, 제1 디바이스(110)는, 다른 디바이스로부터 충돌 통지를 수신할 수 있다. 충돌 통지는, 데이터 링크 서브넷 식별자(156)(또는 IP 어드레스(154))가 다른 디바이스에 의해 사용되는 서브넷의 식별자(또는 IP 어드레스)와 충돌한다는 것을 표시하는 충돌 데이터를 포함할 수 있다. 충돌 통지는 제1 디바이스(110)로부터의 메시지(예컨대, 제1 데이터 패킷)에 대한 응답으로 이루어질 수 있고, 메시지는, 데이터 링크 서브넷 식별자(156), IP 어드레스(154), 또는 둘 모두를 표시한다. 제1 디바이스(110)는, 충돌 통지를 수신하는 것에 대한 응답으로, 데이터 링크 서브넷 식별자(156), IP 어드레스(154), 또는 둘 모두를 업데이트할 수 있다.
[0044] 디바이스는 다수의 데이터 링크 인터페이스들을 포함할 수 있다. 예를 들어, 제2 디바이스(108)는, 제1 데이터 링크 인터페이스(162) 및 제2 데이터 링크 인터페이스(164)를 포함할 수 있다. 제1 데이터 링크 인터페이스(162)는 제1 데이터 링크 그룹(132)에 대응할 수 있고, 제2 데이터 링크 인터페이스(164)는 제2 데이터 링크 그룹(134)에 대응할 수 있다. 제2 디바이스(108)는 또한, 데이터 링크 네트워킹 회로(166)를 포함할 수 있다. 제2 디바이스의 데이터 링크 네트워킹 회로(166)는, 제1 디바이스의 데이터 링크 네트워킹 회로(114)와 유사하게 동작하도록 구성될 수 있다. 제2 디바이스의 데이터 링크 네트워킹 회로(166)는, 제2 디바이스(108)의 동작을 참조하여 본원에 설명된 하나 또는 그 초과의 기능들을 수행하도록 구성될 수 있다. 제2 디바이스(108)는 메모리(168)를 포함할 수 있다. 메모리(168)는 네트워킹 데이터(190)를 저장할 수 있다.
[0045] 제2 디바이스(108)는, 라우팅 프리픽스(158), 제1 데이터 링크 그룹 식별자(142)에 대응하는 제1 데이터, 및 MAC 어드레스(178)에 대응하는 제2 데이터에 기초하여, 제2 디바이스의 제1 데이터 링크 인터페이스(162)의 제1 IP 어드레스(170)를 생성할 수 있다. 예를 들어, 제2 디바이스(108)는, 라우팅 프리픽스(158)와 제1 데이터를 결합시킴으로써 제1 서브넷 식별자를 생성할 수 있고, 제2 디바이스(108)는, 제1 서브넷 식별자와, MAC 어드레스(178)에 대응하는 제2 데이터를 결합시킴으로써 제1 IP 어드레스(170)를 생성할 수 있다. 제2 디바이스(108)는, 라우팅 프리픽스(158), 제2 데이터 링크 그룹 식별자(144)에 대응하는 제3 데이터(예컨대, 제3 식별자), 및 MAC 어드레스(178)에 대응하는 제2 데이터에 기초하여 제2 IP 어드레스(172)를 생성할 수 있다. 예를 들어, 제2 디바이스(108)는 라우팅 프리픽스(158)와 제3 데이터를 결합시킴으로써 제2 서브넷 식별자를 생성할 수 있고, 제2 디바이스(108)는, 제2 서브넷 식별자와 제2 데이터를 결합시킴으로써 제2 IP 어드레스(172)를 생성할 수 있다.
[0046] 도 1의 시스템(100)은, IP 어드레스들을 사용하여 데이터가 데이터 링크 그룹의 디바이스들 간에 라우팅될 수 있게 할 수 있다. 디바이스의(또는 디바이스에서의) 애플리케이션은, 대응하는 데이터 링크 그룹의 디바이스들에 데이터를 전송하기 위해 어느 데이터 링크 인터페이스가 사용되고 있는지를 인식하지 못할 수 있으며, 디바이스의 운영 시스템이 IP 어드레스에 기초하여 올바른 데이터 링크 인터페이스를 제공할 수 있다. 레거시(legacy) 애플리케이션들은, 대응하는 IP 어드레스들을 사용하여 다수의 데이터 링크 그룹들의 디바이스들과 통신하는 것이 가능할 수 있다.
[0047] 도 2를 참조하면, 제2 디바이스(108)의 예시적인 예가 도시된다. 제2 디바이스(108)는 제1 애플리케이션(208), 제2 애플리케이션(210), 및 제3 애플리케이션(212)을 포함할 수 있다. 제1 애플리케이션(208) 및 제2 애플리케이션(210)은 제1 데이터 링크 그룹(132)에 대응할 수 있다. 예를 들어, 제1 애플리케이션(208) 및 제2 애플리케이션(210)은 제1 IP 어드레스(170)를 사용할 수 있다. 예시를 위해,, 제1 애플리케이션(208), 제2 애플리케이션(210), 또는 둘 모두는, 제2 디바이스(108)의 로컬 소켓(local socket)에 대한 어드레스로서 제1 IP 어드레스(170)를 사용할 수 있다. 몇몇 구현들에서, 제1 애플리케이션(208), 제2 애플리케이션(210), 또는 둘 모두는 로컬 소켓으로서 일반 소켓을 사용할 수 있다. 예를 들어, 제1 애플리케이션(208), 제2 애플리케이션(210), 또는 둘 모두는, 특정 네트워크 인터페이스에 바인딩(bind)되지 않은 소켓을 사용할 수 있다. 제2 디바이스(108)의 운영 시스템(OS)은, 제1 IP 어드레스(170)가 제1 데이터 링크 인터페이스(162)에 맵핑된다는 것을 결정하기 위해 라우팅 테이블을 사용할 수 있다. OS는, 결정에 대한 응답으로, 로컬 소켓(또는 제1 IP 어드레스(170))에 대응하는 데이터를 제1 데이터 링크 인터페이스(162)로 지향(direct)시킬 수 있다.
[0048] 동작 동안, 애플리케이션 계층에서, 제1 애플리케이션 계층(208), 제2 애플리케이션 계층(210), 또는 둘 모두는 제1 데이터를 생성할 수 있다. 네트워크 계층에서, 제1 데이터 링크 인터페이스(162)는, 페이로드로서 제1 데이터를 포함하는 데이터 패킷을 생성할 수 있다. 데이터 패킷의 헤더는 소스 어드레스로서 제1 IP 어드레스(170)를 표시할 수 있다. 데이터 링크 계층에서, 데이터 링크-X 계층(204)은 데이터 패킷을 포함하는 프레임(예컨대, MAC 프레임)을 생성할 수 있다. 물리 계층에서, Wi-Fi(wireless fidelity) 계층(202)은, 무선 매체(예컨대, 에어(air))를 통해 프레임에 대응하는 비트들을 송신하기 위해 안테나를 사용할 수 있다.
[0049] 제3 애플리케이션(212)은 제2 데이터 링크 그룹(134)에 대응할 수 있다. 예를 들어, 제3 애플리케이션(212)은 제2 IP 어드레스(172)를 사용할 수 있다. 예시를 위해,, 제3 애플리케이션(212)은, 제2 디바이스(108)의 로컬 소켓에 대한 어드레스로서 제2 IP 어드레스(172)를 사용할 수 있다. 애플리케이션 계층에서, 제3 애플리케이션(212)은 제2 데이터를 생성할 수 있다. 네트워크 계층에서, 제2 데이터 링크 인터페이스(164)는, 페이로드로서 제2 데이터를 포함하는 제2 데이터 패킷을 생성할 수 있다. 제2 데이터 패킷의 헤더는 소스 어드레스로서 제2 IP 어드레스(172)를 표시할 수 있다. 데이터 링크 계층에서, 데이터 링크-Y 계층(206)은 제2 데이터 패킷을 포함하는 제2 프레임(예컨대, MAC 프레임)을 생성할 수 있다. 물리 계층에서, Wi-Fi(wireless fidelity) 계층(202)은, 무선 매체(예컨대, 에어)를 통해 제2 프레임에 대응하는 비트들을 송신하기 위해 안테나를 사용할 수 있다. 몇몇 구현들에서, 데이터 링크-X 계층(204), 데이터 링크-Y 계층(206) 또는 둘 모두는 NDL 계층을 포함하거나 그에 대응할 수 있다.
[0050] 몇몇 구현들에서, 애플리케이션(예컨대, 제1 애플리케이션(208), 제2 애플리케이션(210), 또는 제3 애플리케이션(212))은 하위 계층(예컨대, 네트워크 계층 또는 데이터 링크 계층)에 커맨드들을 전송하도록 구성될 수 있다. 커맨드는, 새로운 데이터 링크 인터페이스가 생성되어야 한다는 것을 표시할 수 있다. 특정 구현에서, 애플리케이션은, 하위 계층의 드라이버 또는 펌웨어(예컨대, 프로세서 실행 펌웨어)에 커맨드를 전송할 수 있다. 예를 들어, 애플리케이션은, 프로세서 또는 데이터 링크 네트워킹 회로(예컨대, 데이터 링크 네트워킹 회로(114) 또는 데이터 링크 네트워킹 회로(166))로 하여금 하위 계층의 드라이버 또는 펌웨어에 커맨드를 전송(또는 실행)하게 할 수 있다. 커맨드는, 디바이스의 하위 계층에서의 새로운 데이터 링크 인터페이스의 생성을 야기하도록 구성될 수 있다. 예시를 위해,, 제3 애플리케이션(212)은 네트워크 계층에 커맨드(222)를 전송할 수 있다. 커맨드(222)는, 네트워크 계층에서의 제2 데이터 링크 인터페이스(164)의 생성을 야기하도록 구성될 수 있다. 예를 들어, 커맨드(222)의 실행은 제2 데이터 링크 인터페이스(164)를 생성할 수 있다.
[0051] 부가적으로 또는 대안적으로, 애플리케이션은 다른 커맨드들을 전송할 수 있다. 예를 들어, 제2 커맨드는, 데이터 링크가 삭제, 제거, 또는 소거되어야 한다는 것을 표시할 수 있다. 몇몇 구현들에서, 애플리케이션은, 애플리케이션이 비활성이 되는 것, 이를테면, 애플리케이션이 더 이상 제공되지 않거나 디바이스가 더 이상 애플리케이션의 소비자가 아닌 것에 대한 응답으로, 제2 커맨드를 전송할 수 있다. 다른 예로서, 제3 커맨드는, 특정 데이터 링크에 대응하는 기존 데이터 링크 인터페이스가 다른 데이터 링크와 재사용되거나 그에 재할당되어야 함을 표시할 수 있다. 몇몇 구현들에서, 재할당될 기존 데이터 링크 인터페이스는, QoS 레벨, 이를테면 커맨드에 의해 표시되는 QoS 레벨에 기초하여 선택될 수 있다. 대안적으로, 데이터 링크 인터페이스는, 커맨드(예컨대, 데이터 링크 생성 커맨드)에 의해 표시되는 QoS 레벨이 데이터 링크 인터페이스의 QoS보다 낮거나 같다는 결정에 대한 응답으로 재사용(또는 재할당)될 수 있다.
[0052] 따라서, 제2 디바이스(108)는, 애플리케이션들(208-212)이 데이터를 데이터 링크 그룹들에 전송하는 데 일반(예컨대, 표준) 소켓 인터페이스들을 사용할 수 있게 할 수 있다. 예를 들어, 일반(예컨대, 표준) 소켓 인터페이스는 데이터 링크 인터페이스에 대한 IP 어드레스를 애플리케이션에 제공할 수 있어서, 애플리케이션이 대응하는 데이터 링크 그룹의 디바이스들과 통신할 수 있게 한다.
[0053] 도 3a를 참조하면, 데이터 패킷(300)의 예시적인 예가 도시된다. 데이터 패킷(300)은 IPv6 데이터 패킷에 대응할 수 있다. 특정 양상에서, 데이터 패킷(300)은 시스템(100)의 하나 또는 그 초과의 디바이스들에 의해 생성될 수 있다.
[0054] 데이터 패킷(300)은 헤더(302) 및 페이로드(304)를 포함한다. 헤더(302)는, 도 1을 참조하여 설명된 QoS 필드(306)를 포함할 수 있다. 헤더(302)는 데이터 링크 라우팅 프리픽스(308)를 포함할 수 있다. 데이터 링크 라우팅 프리픽스(308)는 도 1의 라우팅 프리픽스(158)에 대응할 수 있다. 예를 들어, 하나 또는 그 초과의 표준들(예컨대, IEEE 표준)은, 데이터 링크 네트워크들에 전용되는 하나 또는 그 초과의 데이터 링크 라우팅 프리픽스들을 특정할 수 있다. 데이터 링크 라우팅 프리픽스(308)는 전용 데이터 링크 라우팅 프리픽스들 중 하나에 대응할 수 있다. 몇몇 구현들에서, 데이터 링크 라우팅 프리픽스(308)는 NDL 라우팅 프리픽스를 포함하거나 그에 대응할 수 있다.
[0055] 헤더(302)는 제1 데이터(310)를 포함할 수 있다. 제1 데이터(310)는 데이터 링크 그룹 식별자(예컨대, 도 1의 제1 데이터 링크 그룹 식별자(142) 또는 제2 데이터 링크 그룹 식별자(144))에 대응할 수 있다. 특정 구현에서, 제1 데이터(310)는 도 1의 제1 데이터(150)에 대응할 수 있다. 예시를 위해,, 데이터 링크 그룹(예컨대, 제1 데이터 링크 그룹(132))의 디바이스는, 도 1을 참조하여 설명된 바와 같이, 무선 네트워크(101)에서 사용 중인 데이터 링크 그룹 식별자들과 충돌하지 않는 데이터 링크 그룹 식별자(예컨대, 제1 데이터 링크 그룹 식별자(142))를 생성할 수 있다. 디바이스는 탐색 메시지를 무선 네트워크(101)의 다른 디바이스들에 전송할 수 있다. 탐색 메시지는 데이터 링크 그룹 식별자(예컨대, 제1 데이터 링크 그룹 식별자(142))를 표시할 수 있다. 제1 데이터(310)는, 데이터 링크 그룹 식별자(예컨대, 제1 데이터 링크 그룹 식별자(142))에 기초하여 생성될 수 있다. 예를 들어, 제1 데이터(310)는, 도 1을 참조하여 설명된 바와 같이, 데이터 링크 그룹 식별자 또는 데이터 링크 그룹 식별자에 함수(예컨대, 도 1의 해시 함수(180))를 적용한 결과에 대응할 수 있다. 몇몇 구현들에서, 데이터 링크 그룹 식별자는 NDL 그룹 식별자를 포함하거나 그에 대응할 수 있다.
[0056] 헤더(302)는 제2 데이터(312)를 포함할 수 있다. 제2 데이터(312)는 디바이스 특정적일 수 있다. 예를 들어, 제2 데이터(312)는 디바이스(예컨대, 제1 디바이스(110) 또는 제2 디바이스(108))의 MAC 식별자(예컨대, MAC 어드레스)에 대응할 수 있다. 특정 양상에서, 제2 데이터(312)는 도 1의 제2 데이터(152)에 대응할 수 있다. 대안적인 구현들에서, 헤더(302)는, 예시된 개수의 필드들보다 더 많은 개수 또는 더 적은 개수의 필드들을 포함할 수 있다.
[0057] 결합된 데이터 링크 라우팅 프리픽스(308)와 제1 데이터(310)는 데이터 링크 서브넷 식별자(320)에 대응할 수 있다. 데이터 링크 서브넷 식별자(320)는 도 1의 데이터 링크 서브넷 식별자(156)에 대응할 수 있다. 몇몇 구현들에서, 데이터 링크 서브넷 식별자(320)는 NDL 서브넷 식별자를 포함하거나 그에 대응할 수 있다. 결합된 데이터 링크 서브넷 식별자(320)와 제2 데이터(312)는 IP 어드레스(322)(예컨대, 소스 IP 어드레스 또는 목적지 IP 어드레스)에 대응할 수 있다. IP 어드레스(322)는 도 1의 IP 어드레스(154), 제1 IP 어드레스(170), 또는 제2 IP 어드레스(172)에 대응할 수 있다. 데이터 링크 라우팅 프리픽스(308)는 제1 개수의 비트들(예컨대, 48개의 비트들)을 포함할 수 있다. 제1 데이터(310)는 제2 개수의 비트들(예컨대, 16개의 비트들)을 포함할 수 있다. 제2 데이터(312)는 제3 개수의 비트들(예컨대, 64개의 비트들)을 포함할 수 있다.
[0058] 디바이스가 다수의 데이터 링크 인터페이스들을 포함하는 경우, 디바이스에 의한(또는 디바이스에서의) 특정 타입들의 IPv6 어드레스 생성 및 할당 동작은, 동일한 서브넷에 있는 다수의 IPv6 어드레스들을 갖는 데이터 링크 인터페이스들을 초래할 수 있다. 예를 들어, 링크-로컬 어드레스(link-local address)들이 사용되는 경우, 디바이스의(또는 디바이스에서의) 데이터 링크 인터페이스들 각각에 할당된 IPv6 어드레스는 동일한 서브넷의 일부일 수 있다. 동작 동안, 디바이스의(또는 디바이스에서의) 애플리케이션은, 다수의 데이터 링크 인터페이스들 중 하나에 포워딩/라우팅하기 위해 디바이스의 운영 시스템에 메시지를 제공할 수 있다. 그러나, 애플리케이션은 데이터 링크 인터페이스를 명시적으로 식별하지 못할 수 있고, 도리어, 임의의 단일 데이터 링크 인터페이스에 바인딩되지 않은 소켓을 사용할 수 있다. 링크-로컬 어드레스들이 사용되는 경우(데이터 링크 인터페이스들이 동일한 서브넷 상에 있는 것을 초래함), 운영 시스템은 데이터 링크 인터페이스들 간을 명확화(disambiguate)하지 못할 수 있다. 예를 들어, 운영 시스템은 하나의 데이터 링크 인터페이스를 다른 데이터 링크 인터페이스와 구별하지 못할 수 있다. 그러한 상황들에서, 운영 시스템은 메시지를 드롭(drop)할 수 있다. 따라서, IPv6 어드레스들의 경우, 디바이스는 서브넷 레벨에서 구별가능하도록 자신의 데이터 링크 인터페이스들에 할당하는 것이 유익할 것이다.
[0059] 도 3b를 참조하면, 서브넷 레벨에서 구별될 수 있는 IPv6 어드레스(330)의 특정 예시적인 예가 도시된다. 예시적인 양상에서, IPv6 어드레스(330)는 디바이스(예컨대, 제1 디바이스(110) 또는 제2 디바이스(108))에 의해 생성되어 디바이스의 데이터 링크 인터페이스(예컨대, 도 1의 데이터 링크 인터페이스들(112, 162, 또는 164))에 할당될 수 있다. 예를 들어, IPv6 어드레스(330)는 도 3a의 IP 어드레스(322) 대신 데이터 패킷에서 사용될 수 있다.
[0060] 특정 양상에서, IPv6 어드레스(330)는, 처음(예컨대, 초기) 7개의 비트들이 로컬 어드레스 프리픽스(332)인 128-비트 어드레스이다. 로컬 어드레스 프리픽스(332)는 비-전역적으로 라우팅가능한 어드레스 프리픽스일 수 있다. 예시적인 예에서, 로컬 어드레스 프리픽스(332)는, "fc00::/7" 블록, 이를테면 "fd00::/8" 또는 "fc00::/8"의 IPv6 ULA(unique local address) 프리픽스이다. 몇몇 양상들에서, IPv6 ULA 프리픽스를 갖는 IPv6 어드레스는 조직(organization)(예컨대, 기업, 법인, 사설 네트워크 등) 내에서 고유하지만 전역적으로 고유하도록 보장되지는 않는다. 따라서, IPv6 ULA 프리픽스를 갖는 IPv6 어드레스는 조직 내에서의 로컬 통신에 적절할 수 있다. 특정 양상에서, 로컬 어드레스 프리픽스(332)는, RFC(Request for Comments) 4193에서 설명되는 IPv6 ULA 프리픽스일 수 있다. 부가적으로, IPv6 ULA 프리픽스를 갖는 IPv6 어드레스는 레지스트레이션 엔티티(registration entity)에 의해 할당될 수 있고, 레지스트레이션 엔티티에 따라 동작하는 조직들에 걸쳐 고유할 수 있다.
[0061] 특정 양상에서, 로컬 어드레스 프리픽스(332)에 연속하여 후속되는 비트는 로컬 표시자 비트(334)이다. 로컬 표시자 비트(334)는, IPv6 어드레스(330)가 로컬로 할당되는지 여부를 표시할 수 있다. 특정 예에서, 로컬 표시자 비트(334)는, 로컬 어드레스 프리픽스(332)가 IPv6 ULA 프리픽스인 경우 제1 값(예컨대, 1)을 가질 수 있으며, 이는 IPv6 어드레스(330)가 로컬로 할당됨을 표시한다.
[0062] 특정 양상에서, 로컬 표시자 비트(334)에 연속하여 후속되는 40개의 비트들은 제1 식별자(336)이다. 예시적인 예에서, 제1 식별자(336)는 조직, 이를테면 기업, 법인, 사설 네트워크 등에 대응할 수 있다(예컨대, 맵핑됨). 제1 식별자(336)는 특정 조직에 대해 "고유"한 "전역" 식별자일 수 있다. 예를 들어, 조직과 그 조직의 "전역" 식별자 간의 맵핑은, 다른 조직들이 상이한 "전역" 식별자들을 선택하여 충돌들이 회피될 수 있도록, 레지스트레이션 데이터베이스 또는 다른 공개 정보 소스에 기록될 수 있다. 제1 식별자(336)가 전역적으로 고유한 경우, 로컬 어드레스 프리픽스(332), 로컬 표시자 비트(334), 및 제1 식별자(336)의 결합이 또한 전역적으로 고유할 수 있음이 인식될 것이다. 예를 들어, 로컬 어드레스 프리픽스(332), 로컬 표시자 비트(334), 및 제1 식별자(336)의 결합은, 레지스트레이션 엔티티, 이를테면 무선 표준 조직(예컨대, Wi-Fi Alliance), IPv6 배치(deployment) 및 터널 브로커(tunnel broker) 등에 의해 기록되는 (특정 조직에 대해) "전역적으로 고유한" 프리픽스에 대응할 수 있다.
[0063] 특정 양상에서, 제1 식별자(336)에 연속하여 후속되는 16개의 비트들은 제2 식별자(338)이다. 제2 식별자(338)는, 웹사이트 또는 조직 내의 서브세트를 식별하는 서브넷 식별자일 수 있다. 몇몇 예들에서, 제2 식별자(338)는 데이터 링크 그룹 식별자에 해시 함수(예컨대, 도 1의 해시 함수(180))를 적용함으로써 생성된다. 데이터 링크 그룹 식별자 및 데이터 링크 그룹 식별자의 해시는 NAN 또는 NAN 클러스터(cluster) 내에서 고유할 수 있다. 따라서, 제2 식별자(338)는 동일한 디바이스의 상이한 데이터 링크 인터페이스들 간에 상이한 서브넷 식별자일 수 있는데, 이는 데이터 링크 인터페이스들이 상이한 데이터 링크 그룹 식별자들에 대응할 수 있기 때문이다.
[0064] 특정 양상에서, 제2 식별자(338)에 연속하여 후속되는 IPv6 어드레스(330)의 64개의 비트들은 인터페이스 식별자(340)이다. 일 예에서, 데이터 링크 인터페이스의 인터페이스 식별자(340)는, 데이터 링크 인터페이스의 MAC 어드레스(예컨대, 48 비트 MAC 어드레스), 데이터 링크 인터페이스를 포함하는 디바이스의 MAC, 디바이스의 하드웨어 네트워킹 컴포넌트에 대한 MAC 어드레스 등에 기초하여 생성된다. 예시를 위해,, 데이터 링크 인터페이스에 대한 48 비트 MAC 어드레스는, MAC 어드레스를 IEEE EUI-64 포맷으로 변환함으로써 64 비트 인터페이스 식별자(340)를 생성하는 데 사용될 수 있다.
[0065] 특정 양상에서, 변환 프로세스는, MAC 어드레스를 절반들인 2개의 24 비트로 분할하고, 2개의 절반들 사이에 16 비트 값을 삽입하는 것을 포함할 수 있다. 일 예에서, 16 비트 값은 0xFFFE이고, 이는 MAC 어드레스들로부터 생성되는 EUI-64들에 대해 예비된 값일 수 있다. 몇몇 예들에서, 16 비트 값을 삽입한 후, EUI-64의 U/L(universal/local) 비트는 EUI-64가 전역적으로 고유하지 않다는 것을 표시하기 위해 플립(flip)될 수 있다. 대안적으로, U/L 비트가 플립되지 않을 수 있고, 이는 EUI-64가 인터페이스 식별자임을 표시한다.
[0066] 도 3c를 참조하면, IPv6 어드레스(360)의 또 다른 예가 도시된다. IPv6 어드레스(360)는, "전역적으로 고유한" 프리픽스(362), 서브넷 식별자(364), 및 인터페이스 식별자(366)를 포함한다. 예시적인 예에서, 서브넷 식별자(364)는 도 3b의 16 비트 제2 식별자(338)이고, 인터페이스 식별자(366)는 도 3b의 64 비트 인터페이스 식별자(340)이다. 예시적인 양상에서, IPv6 어드레스(360)는 도 3a의 IP 어드레스(322) 대신 데이터 패킷에 포함될 수 있다.
[0067] 전역적으로 고유한 프리픽스(362)는, 로컬 어드레스 프리픽스(예컨대, 도 3b의 로컬 어드레스 프리픽스(332)), 로컬 표시자 비트(예컨대, 도 3b의 로컬 표시자 비트(334)), 및 조직 식별자(예컨대, 도 3b의 제1 식별자(336))의 결합(예컨대, 연접)에 대응할 수 있다. 특정 양상에서, 48 비트의 전역적으로 고유한 프리픽스(362)는 레지스트레이션 엔티티, 이를테면 무선 네트워킹 표준, IPv6 배치 및 브로커 등에 의해 기록될 수 있다. 몇몇 양상들에서, 전역적으로 고유한 프리픽스(362)는 일 조직(예컨대, 기업, 법인, 사설 네트워크 등) 내에서 또는 레지스트레이션 엔티티에 따라 동작하는 조직들 내에서 고유할 수 있지만, 전역적으로 고유한 프리픽스(362)가 전역적으로 고유하도록 보장되지는 않을 수 있다.
[0068] 따라서, 도 3b 및 도 3c는, 디바이스에 의해 생성되고 디바이스의 데이터 링크 인터페이스에 할당될 수 있는 대안적인 IPv6 어드레스들을 예시한다. 도 3b 또는 도 3c를 참조하여 설명된 포맷을 갖는 IPv6 어드레스가 사용되는 경우, 애플리케이션은, 운영 시스템에 메시지들을 제공하는 데 바인딩되지 않은(unbound) 소켓을 사용하는 것이 가능할 수 있고, 운영 시스템은, 어느 특정 데이터 링크 인터페이스에 메시지를 포워딩할 것인지를 결정하는 것이 가능할 수 있다. 예를 들어, 운영 시스템은, 메시지 내의 목적지 어드레스의 프리픽스(예컨대, 처음 48개 또는 64개의 비트들)를 로컬 데이터 링크 인터페이스의 프리픽스에 매칭하기 위한 로컬 라우팅 테이블을 참고할 수 있다.
[0069] 도 4를 참조하면, 데이터 패킷(400)의 예시적인 예가 도시된다. 데이터 패킷(400)은 IPv4 데이터 패킷에 대응할 수 있다. 특정 양상에서, 데이터 패킷(300)은 시스템(100)의 하나 또는 그 초과의 디바이스들에 의해 생성될 수 있다.
[0070] 데이터 패킷(400)은 헤더(402) 및 페이로드(404)를 포함한다. 헤더(402)는 라우팅 프리픽스(408)를 포함할 수 있다. 라우팅 프리픽스(408)는 도 1의 라우팅 프리픽스(158)에 대응할 수 있다. 예를 들어, 라우팅 프리픽스(408)는 비-전역적으로 라우팅가능한 프리픽스일 수 있다. 예시를 위해,, 하나 또는 그 초과의 조직들(예컨대, IETF(Internet Engineering Task Force) 또는 IEEE)은, 프리픽스들(예컨대, IPv4 어드레스 프리픽스들)의 범위가 비-전역적으로 라우팅가능하거나 사설 인터넷에 할당됨(이를테면, IETF RFC 1918 프리픽스들)을 특정할 수 있다. 라우팅 프리픽스(408)는 프리픽스들의 범위 내에 포함될 수 있다.
[0071] 헤더(402)는 제1 데이터(410)를 포함할 수 있다. 제1 데이터(410)는 데이터 링크 그룹 식별자(예컨대, 제1 데이터 링크 그룹 식별자(142) 또는 제2 데이터 링크 그룹 식별자(144))에 대응할 수 있다. 예를 들어, 제1 데이터(410)는 도 1의 제1 데이터(150)일 수 있다. 예시를 위해,, 데이터 링크 그룹(예컨대, 제1 데이터 링크 그룹(132))의 디바이스는, 도 1을 참조하여 설명된 바와 같이, 무선 네트워크(101)에서 사용 중인 데이터 링크 그룹 식별자들과 충돌하지 않는 데이터 링크 그룹 식별자(예컨대, 제1 데이터 링크 그룹 식별자(142))를 생성할 수 있다. 디바이스는 탐색 메시지를 무선 네트워크(101)의 다른 디바이스들에 전송할 수 있다. 탐색 메시지는 데이터 링크 그룹 식별자(예컨대, 제1 데이터 링크 그룹 식별자(142))를 표시할 수 있다. 제1 데이터(310)는, 데이터 링크 그룹 식별자(예컨대, 도 1의 제1 데이터 링크 그룹 식별자(142))에 기초하여 생성될 수 있다. 특정 구현에서, 제1 데이터(310)는, 도 1을 참조하여 설명된 바와 같이, 데이터 링크 그룹 식별자 또는 데이터 링크 그룹 식별자에 함수(예컨대, 도 1의 해시 함수(180))를 적용한 결과에 대응할 수 있다. 몇몇 구현들에서, 데이터 링크 그룹 식별자는 NDL 그룹 식별자를 포함하거나 그에 대응할 수 있다.
[0072] 헤더(402)는 제2 데이터(412)를 포함할 수 있다. 제2 데이터(412)는 디바이스 특정적일 수 있다. 예를 들어, 제2 데이터(412)는 디바이스(예컨대, 제1 디바이스(110) 또는 제2 디바이스(108))의 MAC 식별자(예컨대, MAC 어드레스)에 대응할 수 있다. 특정 양상에서, 제2 데이터(412)는 도 1의 제2 데이터(152)에 대응할 수 있다. 대안적인 구현들에서, 헤더(402)는, 예시된 개수의 필드들보다 더 많은 개수 또는 더 적은 개수의 필드들을 포함할 수 있다.
[0073] 결합된 라우팅 프리픽스(408)와 제1 데이터(410)는 데이터 링크 서브넷 식별자(420)에 대응할 수 있다. 데이터 링크 서브넷 식별자(420)는 도 1의 데이터 링크 서브넷 식별자(156)에 대응할 수 있다. 몇몇 구현들에서, 데이터 링크 서브넷 식별자(420)는 NDL 서브넷 식별자를 포함하거나 그에 대응할 수 있다. 결합된 데이터 링크 서브넷 식별자(420)와 제2 데이터(412)는 IP 어드레스(422)(예컨대, 소스 IP 어드레스 또는 목적지 IP 어드레스)에 대응할 수 있다. IP 어드레스(422)는 도 1의 IP 어드레스(154), 제1 IP 어드레스(170), 또는 제2 IP 어드레스(172)에 대응할 수 있다. 라우팅 프리픽스(408)는 제1 개수의 비트들(예컨대, 8개의 비트들)을 포함할 수 있다. 결합된 제1 데이터(410)와 제2 데이터(412)는 제2 개수의 비트들(예컨대, 24개의 비트들)을 포함할 수 있다.
[0074] 라우팅 프리픽스(408)가 비-데이터 링크 디바이스들(예컨대, Wi-Fi 액세스 포인트들)에 의해 사용될 수 있으므로, 데이터 링크 서브넷 식별자(420)는, NAN 또는 데이터 링크 그룹(예컨대, 제1 데이터 링크 그룹(132) 또는 제2 데이터 링크 그룹(134)) 내에서 고유하지 않을 수 있다. 예를 들어, 다른 디바이스는, 데이터 링크 서브넷 식별자(420)에 매칭되는 서브넷 식별자를 사용하는 기반구조 연결을 가질 수 있다. 데이터 링크 서브넷 식별자(420)는 충돌 회피 방식을 사용함으로써 업데이트될 수 있다. 예를 들어, 다른 디바이스는, 예를 들어, 데이터 링크 서브넷 식별자(420)를 표시하는 메시지(이를테면, ARP(address resolution protocol) 메시지)를 수신하는 것에 대한 응답으로, 데이터 링크 서브넷 식별자(420)와의 충돌을 표시하는 충돌 통지를 전송할 수 있다. 데이터 링크 서브넷 식별자(420)를 생성한 디바이스(예컨대, 제1 디바이스(110))는, 충돌 통지를 수신하는 것에 대한 응답으로 데이터 링크 서브넷 식별자(420)를 업데이트할 수 있다. 예를 들어, 충돌 통지는, 다른 디바이스에서 사용 중인 하나 또는 그 초과의 비-전역적으로 라우팅가능한 프리픽스들을 표시할 수 있다. 제1 디바이스(110)는, 사용 중인 것으로 최근에 검출된 비-전역적으로 라우팅가능한 프리픽스들을 표시하는 프리픽스 데이터를 유지할 수 있다. 제1 디바이스(110)는, 사용 중인 것으로 또는 사용 중인 것으로 최근에 검출되었다고 프리픽스 데이터에 의해 표시되지 않는 라우팅 프리픽스에 대응하도록 데이터 링크 서브넷 식별자(420)를 업데이트할 수 있다.
[0075] 특정 구현에서, 제1 디바이스(110)는, 제1 데이터 링크 그룹(132)의 다수의 디바이스들로부터, 디바이스들에 의해(또는 디바이스들에서) 사용 중인 비-전역적으로 라우팅가능한 프리픽스들을 표시하는 메시지들(예컨대, 충돌 통지들)을 수신할 수 있다. 제1 디바이스(110)는, 메시지들에 표시되지 않은 라우팅 프리픽스에 대응하도록 데이터 링크 서브넷 식별자(420)의 값을 업데이트할 수 있다. 대안적인 구현에서, 제1 디바이스(110)는, 제안되는 라우팅 프리픽스들을 포함하는 메시지를 제1 데이터 링크 그룹(132)의 디바이스들에 전송할 수 있고, 제안되는 라우팅 프리픽스들 각각과 충돌이 존재하는지 여부를 표시하는 응답들을 디바이스들로부터 수신할 수 있다. 제1 디바이스(110)는, 응답들에 의해 표시되는, 가장 적은 수의 충돌들을 갖거나 어떠한 충돌들도 존재하지 않는 제안되는 라우팅 프리픽스에 대응하도록, 데이터 링크 서브넷 식별자(420)를 업데이트할 수 있다.
[0076] 도 5를 참조하면, 데이터 링크 인터페이스 IP 어드레스 생성 방법(500)의 예가 도시된다. 방법(500)은, 도 1의 시스템(100)의 하나 또는 그 초과의 디바이스들에 의해 수행될 수 있다.
[0077] 방법(500)은, 502에서, 디바이스에 의해, 데이터 링크 그룹의 데이터 링크 그룹 식별자에 대응하는 제1 식별자를 결정하는 단계를 포함한다. 예를 들어, 제1 디바이스(110)는, 도 1을 참조하여 설명된 바와 같이, 제1 데이터 링크 그룹 식별자(142)에 대응하는 제1 데이터(150)를 결정할 수 있다. 예시를 위해,, 제1 데이터(150)는, 도 1을 참조하여 설명된 바와 같이, 제1 데이터 링크 그룹 식별자(142) 또는 제1 데이터 링크 그룹 식별자(142)에 함수(예컨대, 해시 함수(180))를 적용한 결과(예컨대, 16개의 비트들)에 대응할 수 있다. 다른 예로서, 제1 식별자는, 도 3a의 제1 데이터(310), 도 3b의 제2 식별자(338), 도 3c의 서브넷 식별자(364), 또는 도 4의 제1 데이터(410)를 포함하거나 그들에 대응할 수 있다.
[0078] 방법(500)은 또한, 504에서, 디바이스에 의해, 디바이스에 대응하는 제2 식별자를 결정하는 단계를 포함한다. 예를 들어, 제1 디바이스(110)는, 도 1을 참조하여 설명된 바와 같이, 제1 디바이스(110)에 대응하는 제2 데이터(152)를 결정할 수 있다. 예시를 위해,, 제2 데이터(152)(예컨대, 64개의 비트들)는, 도 1을 참조하여 설명된 바와 같이, MAC 어드레스(160)에 기초하여 생성될 수 있다. 다른 예로서, 제2 식별자는, 도 3a의 제2 데이터(312), 도 3b의 인터페이스 식별자(340), 도 3c의 인터페이스 식별자(366), 또는 도 4의 제2 데이터(412)를 포함하거나 그들에 대응할 수 있다.
[0079] 방법(500)은, 506에서, 디바이스에 의해, 데이터 링크 라우팅 프리픽스, 제1 데이터, 및 제2 데이터를 결합시킴으로써, 디바이스의 데이터 링크 인터페이스에 대한 인터넷 프로토콜(IP) 어드레스를 생성하는 단계를 더 포함한다. 예를 들어, 제1 디바이스(110)는, 도 1을 참조하여 설명된 바와 같이, 라우팅 프리픽스(158), 제1 데이터(150), 및 제2 데이터(152)를 연접시킴으로써 제1 데이터 링크 인터페이스(112)의 IP 어드레스(154)를 생성할 수 있다. 다른 예로서, 데이터 링크 라우팅 프리픽스는, 도 3a의 데이터 링크 라우팅 프리픽스(308), 도 3c의 전역적으로 고유한 프리픽스(362), 또는 라우팅 프리픽스(408)를 포함하거나 그들에 대응할 수 있다. 몇몇 구현들에서, 데이터 링크 라우팅 프리픽스는, NDL 네트워크들에 의한 사용에 전용되는 NDL 라우팅 프리픽스(예컨대, 48-비트 프리픽스)에 대응할 수 있다.
[0080] 몇몇 구현들에서, 방법(500)은, 디바이스의 데이터 링크 인터페이스에 대한 IP 어드레스에 기초하여, 디바이스로부터 데이터 링크 그룹의 하나 또는 그 초과의 디바이스들로 제1 데이터 패킷을 전송하는 단계를 포함할 수 있다. 예를 들어, 제1 데이터 패킷은, 도 1의 제1 데이터 패킷, 도 3a의 데이터 패킷(300), 또는 도 4의 데이터 패킷(400)을 포함하거나 그들에 대응할 수 있다. 방법(500)은 또한, 디바이스의 데이터 링크 인터페이스에 대한 IP 어드레스에 기초하여, 데이터 링크 그룹의 하나 또는 그 초과의 디바이스들 중 제2 디바이스로부터 제2 데이터 패킷을 수신하는 단계를 포함할 수 있다. 예를 들어, 제1 디바이스(110)는, 제1 데이터 링크 그룹(132)의 하나 또는 그 초과의 디바이스들에 제1 데이터 패킷을 전송할 수 있고 그리고 제2 디바이스(108)로부터 제2 데이터 패킷을 수신할 수 있다.
[0081] 몇몇 구현들에서, 방법(500)은, 제1 식별자를 결정하기 위해, 데이터 링크 그룹 식별자에 해시 함수를 적용하는 단계를 포함할 수 있다. 몇몇 구현들에서, 데이터 링크 그룹은 이웃 인식 네트워크(NAN)의 이웃 인식 네트워크 데이터 링크(NDL) 그룹에 대응할 수 있고, 데이터 링크 그룹 식별자는 NAN 내에서 고유할 수 있다.
[0082] 몇몇 구현들에서, 방법(500)은, 디바이스에 의해, 데이터 링크 서브넷 식별자를 생성하기 위해 제1 식별자를 데이터 링크 라우팅 프리픽스와 결합시키는 단계를 포함할 수 있다. 예를 들어, 데이터 링크 서브넷 식별자는, 도 3a의 데이터 링크 서브넷 식별자(320) 또는 도 4의 데이터 링크 서브넷 식별자(420)를 포함하거나 그들에 대응할 수 있다. 특정 구현에서, 방법(500)은, 디바이스에 의해, 어드레스(이를테면, IP 어드레스)를 생성하기 위해 데이터 링크 서브넷 식별자와 제2 식별자를 결합(예컨대, 연접)시키는 단계를 더 포함할 수 있다. IP 어드레스는 IPv6(IP version 6) 어드레스 또는 IPv4(IP version 4) 어드레스에 대응할 수 있다.
[0083] 몇몇 구현들에서, 방법(500)은, 데이터 링크 서브넷 식별자가 데이터 링크 네트워크의 디바이스들에 의해 사용되는 서브넷의 식별자와 충돌하는지 여부를 결정하는 단계를 포함할 수 있다. 방법(500)은 또한, 데이터 링크 서브넷 식별자가 데이터 링크 네트워크의 디바이스들에 의해 사용되는 서브넷의 식별자와 충돌한다고 결정하는 것에 대한 응답으로, 데이터 링크 서브넷 식별자를 업데이트하는 단계를 포함할 수 있다.
[0084] 몇몇 구현들에서, 방법(500)은, 제2 디바이스로부터 충돌 통지를 수신하는 단계를 포함할 수 있으며, 충돌 통지는, 데이터 링크 서브넷 식별자가 다른 디바이스에 의해 사용 중임을 표시하는 충돌 데이터를 포함한다. 방법(500)은 또한, 충돌 통지를 수신하는 것에 대한 응답으로, 데이터 링크 서브넷 식별자가 데이터 링크 네트워크의 디바이스들에 의해 사용되는 서브넷의 식별자와 충돌한다는 것을 결정하는 단계를 포함할 수 있다. 특정 구현에서, 디바이스는, 충돌을 검출 또는 결정하는 것에 대한 응답으로, 충돌 메시지를 생성 및 전송할 수 있다.
[0085] 몇몇 구현들에서, 방법(500)은, 디바이스에 의해, 로컬 어드레스 프리픽스를 결정하는 단계를 포함할 수 있다. 예를 들어, 로컬 어드레스 프리픽스는, 도 3b의 로컬 어드레스 프리픽스(332)를 포함하거나 그에 대응할 수 있다. 방법(500)은 또한, 디바이스에 의해, 조직에 대응하는 제3 식별자를 결정하는 단계를 포함할 수 있으며, 여기서, 데이터 링크 라우팅 프리픽스는 로컬 어드레스 프리픽스, 로컬 표시자 비트, 및 제3 식별자를 포함한다. 예를 들어, 로컬 표시자 비트는 로컬 표시자 비트(334)를 포함하거나 그에 대응할 수 있고, 제3 식별자는 도 3b의 제1 식별자(336)를 포함하거나 그에 대응할 수 있다. 특정 구현에서, 로컬 어드레스 프리픽스는, IPv6(IP version 6) ULA(unique local address) 프리픽스 또는 IETF RFC(Internet Engineering Task Force Request for Comments) 1918에 따른 IPv4(IP version 4) 프리픽스에 대응한다.
[0086] 몇몇 구현들에서, 방법(500)은, 디바이스의 애플리케이션에 의해, 제1 커맨드를 생성하는 단계를 포함할 수 있다. 제1 커맨드는, 제2 데이터 링크 인터페이스를 생성할 것을 디바이스에 지시할 수 있다. 예를 들어, 애플리케이션은, 도 2의 제1 애플리케이션(208), 제2 애플리케이션(210), 또는 제3 애플리케이션(212)을 포함하거나 그들에 대응할 수 있다. 제2 데이터 링크 인터페이스는, 도 1 및 도 2의 제2 데이터 링크 인터페이스(164)를 포함하거나 그에 대응할 수 있다. 방법(500)은 또한, 디바이스에서, 제1 커맨드를 실행하는 것에 대한 응답으로, 제2 데이터 링크 인터페이스를 생성하는 단계를 포함할 수 있다. 제2 데이터 링크 인터페이스는, 제2 IP 어드레스 및 제2 데이터 링크 그룹에 대응할 수 있다. 방법(500)은, 제2 커맨드를 실행하는 것에 대한 응답으로, 제2 데이터 링크 인터페이스에 제3 IP 어드레스를 할당하는 단계를 포함할 수 있다. 제2 데이터 링크 인터페이스는 제3 데이터 링크 그룹에 대응할 수 있다. 방법(500)은, 디바이스에서, 제3 커맨드를 실행하는 것에 대한 응답으로, 제2 데이터 링크 인터페이스를 제거(또는 삭제)하는 단계를 더 포함할 수 있다. 예를 들어, 프로세서는, 도 2를 참조하여 설명된 바와 같이, 네트워크 계층에서, 제2 데이터 링크 인터페이스(164)를 생성하고, 제2 데이터 링크 인터페이스(164)를 할당하고, 그리고 제2 데이터 링크 인터페이스(164)를 삭제할 수 있다.
[0087] 몇몇 구현들에서, 데이터 링크 인터페이스는, 데이터 링크 그룹의 하나 또는 그 초과의 디바이스들에 제1 데이터 패킷을 전송하도록 구성될 수 있다. 제1 데이터 패킷의 헤더는, 제1 데이터 패킷의 소스 어드레스로서 데이터 링크 인터페이스에 대한 IP 어드레스를 표시하는 어드레스 데이터를 포함할 수 있다. 예를 들어, 헤더는, 도 3a의 헤더(302) 또는 도 4의 헤더(402)를 포함하거나 그들에 대응할 수 있다.
[0088] 몇몇 구현들에서, 수신기는 프로세서에 커플링될 수 있고, 수신기는 데이터 링크 그룹의 제2 디바이스로부터 제2 데이터 패킷을 수신하도록 구성될 수 있다. 예를 들어, 수신기는 도 1의 제1 디바이스(110)의 수신기를 포함하거나 그에 대응할 수 있다. 제2 데이터 패킷의 제2 헤더는, 제2 데이터 패킷의 목적지 어드레스로서 데이터 링크 인터페이스에 대한 IP 어드레스를 표시하는 제2 어드레스 데이터를 포함할 수 있다. 수신기는 또한, 제2 데이터 패킷에 포함된 IP 어드레스에 기초하여 데이터 링크 인터페이스에 제2 데이터 패킷을 제공할 수 있다.
[0089] 몇몇 구현들에서, 방법(500)은, 디바이스에서 제2 데이터 인터페이스를 생성하는 단계를 포함할 수 있다. 예를 들어, 제2 데이터 인터페이스는, 도 1 또는 도 2의 제2 데이터 링크 인터페이스(164)를 포함하거나 그에 대응할 수 있다. 방법(500)은 또한, 제2 데이터 링크 그룹의 제2 데이터 링크 그룹 식별자에 대응하는 제3 식별자를 결정하는 단계를 포함할 수 있다. 예를 들어, 제3 식별자는 도 1의 제2 데이터 링크 그룹 식별자(144)를 포함하거나 그에 대응할 수 있다. 방법(500)은, 디바이스의 제2 MAC 식별자에 기초하여 제4 식별자를 결정하는 단계를 포함할 수 있다. 제4 식별자, 제2 MAC 식별자, 또는 둘 모두는, 도 1의 MAC 어드레스(178)를 포함하거나 그에 대응할 수 있다. 방법(500)은, 데이터 링크 라우팅 프리픽스, 제3 식별자, 및 제4 식별자의 결합에 기초하여 제2 데이터 링크 인터페이스에 대한 제2 IP 어드레스를 생성하는 단계를 더 포함할 수 있다. 예를 들어, 제2 IP 어드레스는, 도 1의 제2 IP 어드레스(172)를 포함하거나 그에 대응할 수 있다.
[0090] 몇몇 구현들에서, IP 어드레스는, 처음 7개의 비트들이 로컬 어드레스 프리픽스를 표시하고 로컬 어드레스 프리픽스에 연속하여 후속되는 비트가 로컬 표시자 비트를 포함하는 128-비트 IPv6(IP version 6) 어드레스를 포함하며, 여기서, 로컬 표시자 비트는, IPv6 어드레스가 로컬로 할당됨을 표시하는 제1 값을 갖는다. IP 어드레스는, 로컬 표시자 비트에 연속하여 후속되는 40개의 비트들(제5 식별자를 표시함), 제5 식별자에 연속하여 후속되는 16개의 비트들(제1 식별자를 표시함), 및 제1 식별자에 연속하여 후속되는 64개의 비트들(제2 식별자를 표시함)을 더 포함한다. 예를 들어, 제5 식별자는 도 3b의 제1 식별자(336)를 포함하거나 그에 대응할 수 있다.
[0091] 방법(500)은, 데이터 링크 인터페이스에 대한 IP 어드레스(예컨대, 128-비트 IPv6 어드레스)의 생성을 인에이블링할 수 있다. 생성된 IP 어드레스는, 데이터 링크 네트워크들에 전용되는 데이터 링크 라우팅 프리픽스에 기초할 수 있다. 생성된 IP 어드레스는 제1 데이터 링크 그룹(132) 내에서 고유할 수 있다. 방법(500)은, 데이터 링크 그룹의 디바이스가 고유 IP 어드레스를 생성할 수 있게 하고 그리고 비-고유 IP 어드레스들과의 충돌들을 검출하는 데 사용될 리소스들을 보존할 수 있게 할 수 있다. 부가적으로, 방법(500)은, 디바이스가, 디바이스의 다수의 데이터 링크 인터페이스들의 각각의 데이터 링크 인터페이스에 대한 고유 IP 어드레스들을 생성 및 할당할 수 있게 할 수 있다.
[0092] 도 6을 참조하면, 데이터 링크 인터페이스 IP 어드레스 생성 방법(600)의 다른 예가 도시된다. 방법(600)은, 도 1의 시스템(100)의 하나 또는 그 초과의 디바이스들에 의해 수행될 수 있다.
[0093] 방법(600)은, 602에서, 디바이스에 의해, 데이터 링크 그룹의 데이터 링크 그룹 식별자에 대응하는 제1 식별자를 결정하는 단계를 포함한다. 예를 들어, 제1 디바이스(110)는, 도 1을 참조하여 설명된 바와 같이, 제1 데이터 링크 그룹(132)의 제1 데이터 링크 그룹 식별자(142)에 대응하는 제1 데이터(150)를 결정할 수 있다. 예시를 위해,, 제1 데이터(150)는, 제1 데이터 링크 그룹 식별자(142) 또는 제1 데이터 링크 그룹 식별자(142)에 함수(예컨대, 해시 함수(180))를 적용한 결과에 대응할 수 있다.
[0094] 방법(600)은 또한, 604에서, 디바이스에 의해, 제1 데이터를 라우팅 프리픽스와 결합시킴으로써 데이터 링크 서브넷 식별자를 생성하는 단계를 포함한다. 예를 들어, 제1 디바이스(110)는, 도 1을 참조하여 설명된 바와 같이, 제1 데이터(150)를 라우팅 프리픽스(158)와 결합(예컨대, 연접)시킴으로써 데이터 링크 서브넷 식별자(156)를 생성할 수 있다. 예시를 위해,, 라우팅 프리픽스(158)(예컨대, 8개의 비트들)는 비-전역적으로 라우팅가능한 프리픽스에 대응할 수 있다.
[0095] 방법(600)은, 606에서, 디바이스에 의해, 디바이스에 대응하는 제2 식별자를 결정하는 단계를 더 포함한다. 예를 들어, 제1 디바이스(110)는, 제1 디바이스(110)에 대응하는 제2 데이터(152)를 결정할 수 있다. 예시를 위해,, 제2 데이터(152)는 MAC 어드레스(160)에 기초하여 생성될 수 있다.
[0096] 방법(600)은 또한, 608에서, 디바이스에 의해, 데이터 링크 서브넷 식별자와 제2 데이터를 결합시킴으로써 디바이스의 데이터 링크 인터페이스에 대한 IP 어드레스(예컨대, IPv4 어드레스)를 생성하는 단계를 포함한다. 예를 들어, 제1 디바이스(110)는, 도 1을 참조하여 설명된 바와 같이, 데이터 링크 서브넷 식별자(156)와 제2 데이터(152)를 결합(예컨대, 연접)시킴으로써 제1 데이터 링크 인터페이스(112)의 IP 어드레스(154)를 생성할 수 있다.
[0097] 방법(600)은, 데이터 링크 인터페이스에 대한 IP 어드레스의 생성을 인에이블링할 수 있다. IP 어드레스는, 제1 디바이스(110)의 애플리케이션이 제1 데이터 링크 그룹(132)의 하나 또는 그 초과의 디바이스들과 통신하는 데 사용될 수 있다. 방법(600)은, 데이터 링크 그룹의 디바이스가 고유 IP 어드레스를 생성할 수 있게 하고 그리고 비-고유 IP 어드레스들과의 충돌들을 검출하는 데 사용될 리소스들을 보존할 수 있게 할 수 있다.
[0098] 도 7을 참조하면, 데이터 링크 인터페이스 IP 어드레스 생성 방법(700)의 또 다른 예가 도시된다. 방법(700)은, 도 1의 시스템(100)의 하나 또는 그 초과의 디바이스들에 의해 수행될 수 있다.
[0099] 방법(700)은, 702에서, 디바이스에 의해, 로컬 어드레스 프리픽스를 결정하는 단계를 포함한다. 예를 들어, 제1 디바이스(110)는 로컬 어드레스 프리픽스, 이를테면 도 3b의 로컬 어드레스 프리픽스(332)를 결정할 수 있다. 특정 양상에서, 로컬 어드레스 프리픽스는 IPv6 ULA 프리픽스이다.
[0100] 방법(700)은 또한, 디바이스에 의해, 704에서는 조직에 대응하는 제1 식별자를 그리고 706에서는 데이터 링크 그룹 식별자에 대응하는 제2 식별자를 결정하는 단계를 포함한다. 예를 들어, 제1 디바이스(110)는, 도 3b의 제1 식별자(336) 및 도 3b의 제2 식별자(338)를 결정할 수 있다. 특정 양상에서, 제1 식별자는 40 비트 식별자일 수 있고, 제2 식별자는, 데이터 링크 그룹 식별자에 해시 함수(예컨대, 도 1의 해시 함수(180))를 적용함으로써 결정되는 16 비트 서브넷 식별자일 수 있다.
[0101] 방법(700)은, 708에서, 디바이스에 의해, 적어도 로컬 어드레스 프리픽스, 로컬 표시자 비트, 제1 식별자, 및 제2 식별자를 결합시키는 것에 기초하여 디바이스의 데이터 링크 인터페이스에 대한 IP 어드레스를 생성하는 단계를 더 포함한다. 예를 들어, 제1 디바이스(110)는, 적어도 로컬 어드레스 프리픽스, 로컬 표시자 비트, 제1 식별자, 및 제2 식별자를 결합(예컨대, 연접)시킴으로써, 도 3b의 IPv6 어드레스(330) 또는 도 3c의 IPv6 어드레스(360)를 결정할 수 있다. 방법(700)은, 디바이스의 부가적인 데이터 링크 인터페이스(들)에 대한 IP 어드레스들을 생성하기 위해 반복될 수 있다. 예를 들어, 방법(700)은, 적어도 로컬 어드레스 프리픽스, 로컬 표시자 비트, 제1 식별자, 및 제2 식별자를 결합(예컨대, 연접)시킴으로써 제2 데이터 링크 인터페이스에 대한 제2 IP 어드레스를 생성하기 위해 반복될 수 있다. 제2 IP 어드레스는 제2 데이터 링크 인터페이스의 제2 인터페이스 식별자를 포함할 수 있으며, 이는 몇몇 예들에서는 제1 데이터 링크 인터페이스의 제1 인터페이스 식별자와 상이할 수 있다. 대안적인 예들에서, 디바이스의 다수의 데이터 링크 인터페이스들이 동일한 48 비트 MAC 어드레스를 가질 수 있으며, 그에 따라, 동일한 64 비트 데이터 링크 인터페이스 식별자를 가질 수 있다. 그러나, IPv6 어드레스들의 이들 하위 64개의 비트들이 동일한 경우라 하더라도, 그럼에도 불구하고 전체로서의 IPv6 어드레스들은 상이할 수 있는데, 이는, IPv6 어드레스들의 개별적인 서브넷 식별자들을 결정하기 위한 상이한 데이터 링크 그룹 식별자들의 사용으로 인해 IPv6 어드레스들의 64개의 상위 비트들(예컨대, 프리픽스)이 상이할 수 있기 때문이다.
[0102] 따라서, 방법(700)은, 데이터 링크 인터페이스에 대한 IP 어드레스의 생성을 가능하게 할 수 있다. 예를 들어, IP 어드레스는, 제1 디바이스(110)의 애플리케이션이 제1 데이터 링크 그룹(132)의 하나 또는 그 초과의 디바이스들과 통신하는 데 사용될 수 있다. 방법(700)은, 데이터 링크 그룹의 디바이스가 고유 IP 어드레스를 생성할 수 있게 하고 그리고 비-고유 IP 어드레스들과의 충돌을 검출하는 데 사용될 리소스들을 보존할 수 있게 할 수 있다.
[0103] 특정 양상들에서, 도 5 내지 도 7의 방법들은, FPGA(field-programmable gate array) 디바이스, ASIC(application-specific integrated circuit), 프로세싱 유닛, 이를테면 CPU(central processing unit), DSP(digital signal processor), 제어기, 다른 하드웨어 디바이스, 펌웨어 디바이스, 또는 이들의 임의의 결합에 의해 구현될 수 있다. 일 예로서, 도 5 내지 도 7의 방법들 중 하나 또는 그 초과는 개별적으로 또는 조합되어, 도 8과 관련하여 설명되는, 명령들을 실행하는 프로세서에 의해 수행될 수 있다. 예시를 위해,, 도 5 내지 도 7의 방법들 중 하나의 방법의 일 부분은 도 5 내지 도 7의 방법들 중 하나의 방법의 제2 부분과 결합될 수 있다. 부가적으로, 도 5 내지 도 7을 참조하여 설명된 하나 또는 그 초과의 부분들은 선택적일 수 있거나, 적어도 부분적으로 동시에 수행될 수 있거나, 도시된 것 또는 설명된 것과 상이한 순서로 수행될 수 있거나, 또는 이들의 결합으로 수행될 수 있다.
[0104] 도 8을 참조하면, 무선 통신 디바이스(800)의 예시적인 예가 도시된다. 디바이스(800)는 도 1의 시스템(100)의 디바이스들(예컨대, 제1 디바이스(110), 제2 디바이스(108), 또는 둘 모두) 중 적어도 하나에 대응할 수 있다.
[0105] 디바이스(800)는, 메모리(832)에 커플링되는 프로세서(810)(예컨대, DSP(digital signal processor) 또는 CPU(central processing unit))를 포함한다. 메모리(832)는 도 1의 메모리(168), 메모리(116), 또는 둘 모두에 대응할 수 있다. 예를 들어, 메모리(832)는 네트워킹 데이터(190), 네트워킹 데이터(192), 또는 둘 모두를 포함할 수 있다. 메모리(832)는 명령들(868)을 포함할 수 있다. 프로세서(810)는 데이터 링크 네트워킹 회로(890)에 커플링되거나 그를 포함할 수 있다. 데이터 링크 네트워킹 회로(890)는, 본원에 설명된 방법들, 디바이스들, 및 시스템들의 하나 또는 그 초과의 동작들을 수행하도록 구성될 수 있다. 데이터 링크 네트워킹 회로(890)는, 도 1의 데이터 링크 네트워킹 회로(114), 데이터 링크 네트워킹 회로(166), 또는 둘 모두에 대응할 수 있다. 프로세서(810), 데이터 링크 네트워킹 회로(890), 또는 둘 모두는 데이터 링크 인터페이스(892)에 커플링될 수 있다. 데이터 링크 인터페이스(892)는, 제1 데이터 링크 인터페이스(112), 제1 데이터 링크 인터페이스(162), 제2 데이터 링크 인터페이스(164), 또는 이들의 결합에 대응할 수 있다.
[0106] 특정 양상에서, 데이터 링크 네트워킹 회로(890)는, 도 1을 참조하여 설명된, 제1 데이터 링크 그룹 식별자(142)에 대응하는 제1 데이터(150)를 결정하도록 구성될 수 있다. 데이터 링크 네트워킹 회로(890)는, 도 1을 참조하여 설명된, 디바이스(800)에 대응하는 제2 데이터(152)를 결정하도록 구성될 수 있다. 데이터 링크 네트워킹 회로(890)는, 도 1을 참조하여 설명된, 라우팅 프리픽스(158), 제1 데이터(150), 및 제2 데이터(152)를 결합시킴으로써 데이터 링크 인터페이스(892)의 IP 어드레스(154)를 생성하도록 구성될 수 있다.
[0107] 특정 양상에서, 데이터 링크 네트워킹 회로(890)는, 도 3b를 참조하여 설명된, 로컬 어드레스 프리픽스(332), 로컬 표시자 비트(334), 제1 식별자(336), 제2 식별자(338), 및 인터페이스 식별자(340)를 결정하도록 구성될 수 있다. 데이터 링크 네트워킹 회로(890)는, 도 3b의 IPv6 어드레스(330)를 생성하기 위해, 로컬 어드레스 프리픽스(332), 로컬 표시자 비트(334), 제1 식별자(336), 제2 식별자(338), 및 인터페이스 식별자(340)를 결합시키도록 구성될 수 있다. 대안적으로 또는 부가하여, 데이터 링크 네트워킹 회로(890)는, 도 3c를 참조하여 설명된, 전역적으로 고유한 프리픽스(362), 서브넷 식별자(364), 및 인터페이스 식별자(366)를 결정하도록 구성될 수 있다. 데이터 링크 네트워킹 회로(890)는, 도 3c의 IPv6 어드레스(360)를 생성하기 위해, 전역적으로 고유한 프리픽스(362), 서브넷 식별자(364), 및 인터페이스 식별자(366)를 결합시키도록 구성될 수 있다.
[0108] 특정 구현에서, 데이터 링크 네트워킹 회로(890)는, 이를테면 프로세서(810)를 통해, 온-칩(on-chip)으로 구현될 수 있다. 예를 들어, 메모리(832)는, 프로세서(810)로 하여금 데이터 링크 네트워킹 회로(890)의 동작들을 수행하게 하도록 프로세서(810)에 의해 실행가능한 컴퓨터-실행가능 명령들(868)을 저장하는 컴퓨터-판독가능 저장 디바이스(예컨대, 비-일시적인 컴퓨터-판독가능 매체)일 수 있다. 예를 들어, 프로세서(810)는, 도 1을 참조하여 설명된 바와 같이, 제1 데이터(150)를 결정할 수 있고, 제2 데이터(152)를 결정할 수 있고, 그리고 라우팅 프리픽스(158), 제1 데이터(150), 및 제2 데이터(152)를 결합시킴으로써 IP 어드레스(154)를 생성할 수 있다. 다른 예로서, 프로세서(810)는, 로컬 어드레스 프리픽스(332), 로컬 표시자 비트(334), 제1 식별자(336), 제2 식별자(338), 및 인터페이스 식별자(340)를 결정할 수 있고, 로컬 어드레스 프리픽스(332), 로컬 표시자 비트(334), 제1 식별자(336), 제2 식별자(338), 및 인터페이스 식별자(340)를 결합시킴으로써 IPv6 어드레스를 생성할 수 있다. 대안적으로 또는 부가하여, 프로세서(810)는, 전역적으로 고유한 프리픽스(362), 서브넷 식별자(364), 및 인터페이스 식별자(366)를 결정할 수 있고, IPv6 어드레스(360)를 생성하기 위해, 전역적으로 고유한 프리픽스(362), 서브넷 식별자(364), 및 인터페이스 식별자(366)를 결합시킬 수 있다.
[0109] 도 8은 또한, 프로세서(810)에 커플링되고 그리고 디스플레이(828)에 커플링되는 디스플레이 제어기(826)를 도시한다. 코더/디코더(CODEC; coder/decoder)(834)가 또한 프로세서(810)에 커플링될 수 있다. 스피커(836) 및 마이크로폰(838)은 CODEC(834)에 커플링될 수 있다.
[0110] 도 8은 또한, 무선 제어기(840)가 프로세서(810)에 그리고 라디오 주파수(RF) 인터페이스(870)를 통해 안테나(842)에 커플링될 수 있다는 것을 표시한다. 예시적인 예에서, 무선 제어기(840), RF 인터페이스(870), 또는 안테나(842) 중 하나 또는 그 초과는 데이터 링크 인터페이스, 이를테면 도 1의 데이터 링크 인터페이스들(162, 164, 또는 112)에 대응한다. 특정 양상들에서, 데이터 링크 인터페이스(예컨대, NDL 인터페이스)는 하드웨어, 소프트웨어, 가상 인터페이스, 또는 이들의 결합에 대응할 수 있다. 예시를 위해,, 제2 디바이스(108)에서의 데이터 링크 인터페이스들(162, 164)은, 무선 제어기(840), RF 인터페이스(870), 또는 안테나(842)와 같은 하드웨어 컴포넌트들에 대한 공유된 액세스, 중재된(arbitrated) 액세스, 또는 이들의 결합을 가질 수 있다. 따라서, 이것은, 디바이스가 인터페이스들 각각에 대한 전용 하드웨어 송신/수신(Tx/Rx) 체인들을 포함하지 않으면서 다수의 데이터 링크 인터페이스들을 가질 수 있다는 것으로 이해될 것이다.
[0111] 디바이스(800)는 데이터 링크 인터페이스(892), 하드웨어 컴포넌트들, 이를테면 무선 제어기(840), RF 인터페이스(870), 또는 안테나(842), 또는 이들의 결합을 통해 다른 디바이스들과 통신할 수 있다. 예를 들어, 디바이스(800)는 제1 무선 네트워크(예컨대, 원격통신 네트워크)의 컴포넌트(예컨대, 기지국)와 통신할 수 있고, 그 컴포넌트로부터 데이터를 수신할 수 있다. 디바이스(800)는 또한, 데이터 링크 인터페이스(892)를 통해 제2 무선 네트워크의 데이터 링크 그룹에 대응하는 제1 세트의 디바이스들과 통신할 수 있다. 디바이스(800)는, 제1 무선 네트워크의 컴포넌트로부터 수신된 데이터를 제2 무선 네트워크의 제1 세트의 디바이스들에 제공할 수 있다.
[0112] 몇몇 구현들에서, 프로세서(810), 디스플레이 제어기(826), 메모리(832), CODEC(834), 및 무선 제어기(840)는 시스템-인-패키지(system-in-package) 또는 시스템-온-칩(system-on-chip) 디바이스(822)에 포함된다. 부가적으로 또는 대안적으로, 입력 디바이스(830) 및 전력 공급부(844)는 시스템-온-칩 디바이스(822)에 커플링된다. 더욱이, 다른 구현들에서, 도 8에 예시된 바와 같이, 디스플레이(828), 입력 디바이스(830), 스피커(836), 마이크로폰(838), 안테나(842), 및 전력 공급부(844)는 시스템-온-칩 디바이스(822) 외부에 있다. 그러나, 디스플레이(828), 입력 디바이스(830), 스피커(836), 마이크로폰(838), 안테나(842), 및 전력 공급부(844) 각각은 시스템-온-칩 디바이스(822)의 컴포넌트, 이를테면 인터페이스 또는 제어기에 커플링될 수 있다.
[0113] 설명된 양상들과 함께, 장치는, 데이터 링크 그룹 식별자에 대응하는 제1 식별자를 결정하기 위한 수단을 포함할 수 있다. 예를 들어, 제1 식별자를 결정하기 위한 수단은, 도 1의 데이터 링크 네트워킹 회로(114), 데이터 링크 네트워킹 회로(166), 도 8의 데이터 링크 네트워킹 회로(890), 명령들(868)을 실행하도록 구성되는 프로세서(810), 데이터 링크 그룹 식별자에 대응하는 제1 식별자를 결정하도록 구성되는 하나 또는 그 초과의 다른 디바이스들 또는 회로들, 또는 이들의 임의의 결합을 포함할 수 있다.
[0114] 장치는 또한, 디바이스에 대응하는 제2 식별자를 결정하기 위한 수단을 포함할 수 있다. 예를 들어, 제2 식별자를 결정하기 위한 수단은, 도 1의 데이터 링크 네트워킹 회로(114), 데이터 링크 네트워킹 회로(166), 도 8의 데이터 링크 네트워킹 회로(890), 명령들(868)을 실행하도록 구성되는 프로세서(810), 디바이스에 대응하는 제2 식별자를 결정하도록 구성되는 하나 또는 그 초과의 다른 디바이스들 또는 회로들, 또는 이들의 임의의 결합을 포함할 수 있다.
[0115] 장치는, 데이터 링크 라우팅 프리픽스, 제1 식별자, 및 제2 식별자를 결합시킴으로써 디바이스의 데이터 링크 인터페이스에 대한 인터넷 프로토콜(IP) 어드레스를 생성하기 위한 수단을 더 포함할 수 있다. 예를 들어, IP 어드레스를 생성하기 위한 수단은, 도 1의 데이터 링크 네트워킹 회로(114), 데이터 링크 네트워킹 회로(166), 도 8의 데이터 링크 네트워킹 회로(890), 명령들(868)을 실행하도록 구성되는 프로세서(810), 디바이스의 데이터 링크 인터페이스에 대한 IP 어드레스를 생성하도록 구성되는 하나 또는 그 초과의 다른 디바이스들 또는 회로들, 또는 이들의 임의의 결합을 포함할 수 있다.
[0116] 추가로, 설명된 양상들과 함께, 제2 장치는, 데이터 링크 그룹의 데이터 링크 그룹 식별자에 대응하는 제1 식별자를 결정하기 위한 수단을 포함할 수 있다. 예를 들어, 제1 식별자를 결정하기 위한 수단은, 도 1의 데이터 링크 네트워킹 회로(114), 데이터 링크 네트워킹 회로(166), 도 8의 데이터 링크 네트워킹 회로(890), 명령들(868)을 실행하도록 구성되는 프로세서(810), 데이터 링크 그룹 식별자에 대응하는 제1 식별자를 결정하도록 구성되는 하나 또는 그 초과의 다른 디바이스들 또는 회로들, 또는 이들의 임의의 결합을 포함할 수 있다.
[0117] 제2 장치는 또한, 제1 식별자를 라우팅 프리픽스와 결합시킴으로써 데이터 링크 서브넷 식별자를 생성하기 위한 수단을 포함할 수 있다. 예를 들어, 데이터 링크 서브넷 식별자를 결정하기 위한 수단은, 도 1의 데이터 링크 네트워킹 회로(114), 데이터 링크 네트워킹 회로(166), 도 8의 데이터 링크 네트워킹 회로(890), 명령들(868)을 실행하도록 구성되는 프로세서(810), 제1 식별자를 라우팅 프리픽스와 결합시킴으로써 데이터 링크 서브넷 식별자를 생성하도록 구성되는 하나 또는 그 초과의 다른 디바이스들 또는 회로들, 또는 이들의 임의의 결합을 포함할 수 있다.
[0118] 제2 장치는, 디바이스에 대응하는 제2 식별자를 결정하기 위한 수단을 더 포함할 수 있다. 예를 들어, 제2 식별자를 결정하기 위한 수단은, 도 1의 데이터 링크 네트워킹 회로(114), 데이터 링크 네트워킹 회로(166), 도 8의 데이터 링크 네트워킹 회로(890), 명령들(868)을 실행하도록 구성되는 프로세서(810), 디바이스에 대응하는 제2 식별자를 결정하도록 구성되는 하나 또는 그 초과의 다른 디바이스들 또는 회로들, 또는 이들의 임의의 결합을 포함할 수 있다.
[0119] 제2 장치는 또한, 데이터 링크 서브넷 식별자와 제2 식별자를 결합시킴으로써 디바이스의 데이터 링크 인터페이스에 대한 IP 어드레스를 생성하기 위한 수단을 포함할 수 있다. 예를 들어, IP 어드레스를 생성하기 위한 수단은, 도 1의 데이터 링크 네트워킹 회로(114), 데이터 링크 네트워킹 회로(166), 도 8의 데이터 링크 네트워킹 회로(890), 명령들(868)을 실행하도록 구성되는 프로세서(810), 디바이스의 데이터 링크 인터페이스에 대한 IP 어드레스를 생성하도록 구성되는 하나 또는 그 초과의 다른 디바이스들 또는 회로들, 또는 이들의 임의의 결합을 포함할 수 있다.
[0120] 추가로, 설명된 양상들과 함께, 제3 장치는 로컬 어드레스 프리픽스를 결정하기 위한 수단을 포함할 수 있다. 예를 들어, 로컬 어드레스 프리픽스를 결정하기 위한 수단은, 데이터 링크 네트워킹 회로(114), 데이터 링크 네트워킹 회로(166), 도 8의 데이터 링크 네트워킹 회로(890), 명령들(868)을 실행하도록 구성되는 프로세서(810), 로컬 어드레스 프리픽스를 결정하도록 구성되는 하나 또는 그 초과의 다른 디바이스들 또는 회로들, 또는 이들의 임의의 결합을 포함할 수 있다.
[0121] 제3 장치는 또한, 조직에 대응하는 제1 식별자를 결정하기 위한 수단을 포함할 수 있다. 예를 들어, 제1 식별자를 결정하기 위한 수단은, 데이터 링크 네트워킹 회로(114), 데이터 링크 네트워킹 회로(166), 도 8의 데이터 링크 네트워킹 회로(890), 명령들(868)을 실행하도록 구성되는 프로세서(810), 조직에 대응하는 제1 식별자를 결정하도록 구성되는 하나 또는 그 초과의 다른 디바이스들 또는 회로들, 또는 이들의 임의의 결합을 포함할 수 있다.
[0122] 제3 장치는, 데이터 링크 그룹 식별자에 대응하는 제2 식별자를 결정하기 위한 수단을 더 포함할 수 있다. 예를 들어, 제2 식별자를 결정하기 위한 수단은, 데이터 링크 네트워킹 회로(114), 데이터 링크 네트워킹 회로(166), 도 8의 데이터 링크 네트워킹 회로(890), 명령들(868)을 실행하도록 구성되는 프로세서(810), 데이터 링크 그룹 식별자에 대응하는 제2 식별자를 결정하도록 구성되는 하나 또는 그 초과의 다른 디바이스들 또는 회로들, 또는 이들의 임의의 결합을 포함할 수 있다.
[0123] 제3 장치는, 적어도 로컬 어드레스 프리픽스, 로컬 표시자 비트, 제1 식별자, 및 제2 식별자를 결합시키는 것에 기초하여 데이터 링크 인터페이스에 대한 IP 어드레스를 생성하기 위한 수단을 포함할 수 있다. 예를 들어, IP 어드레스를 생성하기 위한 수단은, 데이터 링크 네트워킹 회로(114), 데이터 링크 네트워킹 회로(166), 도 8의 데이터 링크 네트워킹 회로(890), 명령들(868)을 실행하도록 구성되는 프로세서(810), 데이터 링크 인터페이스에 대한 IP 어드레스를 생성하도록 구성되는 하나 또는 그 초과의 다른 디바이스들 또는 회로들, 또는 이들의 임의의 결합을 포함할 수 있다.
[0124] 개시된 양상들 중 하나 또는 그 초과는 통신 디바이스, 고정 위치 데이터 유닛, 모바일 위치 데이터 유닛, 모바일 폰, 셀룰러 폰, 위성 폰, 컴퓨터, 태블릿, 휴대가능 컴퓨터, 디스플레이 디바이스, 미디어 플레이어, 또는 데스크톱 컴퓨터를 포함할 수 있는 시스템 또는 장치, 이를테면 디바이스(800)에서 구현될 수 있다. 대안적으로 또는 부가적으로, 디바이스(800)는 셋톱 박스, 엔터테인먼트 유닛, 내비게이션 디바이스, PDA(personal digital assistant), 모니터, 컴퓨터 모니터, 텔레비전, 튜너, 라디오, 위성 라디오, 뮤직 플레이어, 디지털 뮤직 플레이어, 휴대가능 뮤직 플레이어, 비디오 플레이어, 디지털 비디오 플레이어, DVD(digital video disc) 플레이어, 휴대가능 디지털 비디오 플레이어, 드론, 위성, 차량(예컨대, 자동차, 트럭, 비행기, 보트 등), 차량의 또는 차량 내의 컴포넌트, 기지국, 프로세서를 포함하거나 또는 데이터 또는 컴퓨터 명령들을 저장 또는 리트리브(retrieve)하는 임의의 다른 디바이스, 또는 이들의 결합을 포함할 수 있다. 다른 예시적인 비-제한적인 예로서, 시스템 또는 장치는 원격 유닛들, 이를테면 핸드-헬드 PCS(personal communication systems) 유닛들, GPS(global positioning system) 가능 디바이스들과 같은 휴대가능 데이터 유닛들, 검침 장비, 또는 프로세서를 포함하거나 또는 데이터 또는 컴퓨터 명령들을 저장 또는 리트리브하는 임의의 다른 디바이스, 또는 이들의 임의의 조합을 포함할 수 있다.
[0125] 도 1 내지 도 8 중 하나 또는 그 초과가 본 개시내용의 교시들에 따른 시스템들, 장치들, 방법들, 또는 이들의 결합을 예시할 수 있지만, 본 개시내용은 이러한 예시된 시스템들, 장치들, 방법들, 또는 이들의 결합들로 제한되지 않는다. 본원에 예시 또는 설명된 도 1 내지 도 8 중 임의의 도면의 하나 또는 그 초과의 기능들 또는 컴포넌트들은 도 1 내지 도 8의 다른 기능 또는 컴포넌트의 하나 또는 그 초과의 다른 부분들과 결합될 수 있다. 따라서, 본원에서 설명되는 어떠한 단일 양상도 제한적인 것으로서 해석되지 않아야 하며, 본 개시내용의 양상들은 본 개시내용의 교시들로부터 벗어나지 않으면서 적절하게 결합될 수 있다. 도 1의 시스템(100), 도 2의 제2 디바이스들(108), 또는 도 8의 디바이스(800)의 하나 또는 그 초과의 컴포넌트들은, 전용 하드웨어(예컨대, 회로)를 통해, 하나 또는 그 초과의 태스크들을 수행하기 위한 프로세서 실행 명령들(예컨대, 명령들(860))에 의해, 또는 이들의 결합으로 구현될 수 있다.
[0126] 본원에 개시된 양상들과 관련하여 설명된 다양한 예시적인 로직 블록들, 구성들, 회로들, 및 알고리즘 단계들이 전자 하드웨어, 프로세서에 의해 실행되는 컴퓨터 소프트웨어, 또는 이 둘의 결합들로서 구현될 수 있음을 당업자들은 추가적으로 인식할 것이다. 다양한 예시적인 컴포넌트들, 블록들, 구성들, 회로들, 및 단계들은, 일반적으로 그들의 기능의 관점들에서 위에 설명되었다. 그러한 기능이 하드웨어로서 구현되는지 또는 프로세서 실행가능 명령들로서 구현되는지는 특정 애플리케이션 및 전체 시스템에 부과된 설계 제한들에 의존한다. 당업자들은 설명된 기능성을 각각의 특정 애플리케이션에 대해 다양한 방식들로 구현할 수 있지만, 이러한 구현 결정들이 본 개시내용의 범위를 벗어나게 하는 것으로 해석되어서는 안 된다.
[0127] 본원에 개시된 양상들과 관련하여 설명되는 알고리즘 또는 방법의 단계들은 직접적으로 하드웨어에, 프로세서에 의해 실행되는 소프트웨어에, 또는 이 둘의 결합에 포함될 수 있다. 소프트웨어(예컨대, 명령들)는, RAM(random access memory), 플래시 메모리, ROM(read-only memory), PROM(programmable read-only memory), EPROM(erasable programmable read-only memory), EEPROM(electrically erasable programmable read-only memory), 레지스터들, 하드 디스크, 제거가능 디스크, CD-ROM(compact disc read-only memory), 또는 당업계에 알려져 있는 임의의 다른 형태의 비-일시적 저장 매체에 상주할 수 있다. 예를 들어, 저장 매체는, 프로세서가 저장 매체로부터 정보를 판독하고 저장 매체에 정보를 기입할 수 있도록 프로세서에 커플링될 수 있다. 대안으로, 저장 매체는 프로세서에 통합될 수 있다. 프로세서 및 저장 매체는 ASIC(application-specific integrated circuit)에 상주할 수 있다. ASIC는 컴퓨팅 디바이스 또는 사용자 단말에 상주할 수 있다. 대안으로, 프로세서 및 저장 매체는 컴퓨팅 디바이스 또는 사용자 단말에서 이산 컴포넌트들로서 상주할 수 있다.
[0128] 이전 설명은 당업자가 개시된 양상들을 실시 또는 사용하는 것을 가능하게 하도록 제공된다. 이러한 양상들에 대한 다양한 수정들은 당업자들에게 용이하게 명백할 것이며, 본원에서 정의된 원리들은 본 개시내용의 범위로부터 벗어남이 없이 다른 양상들에 적용될 수 있다. 따라서, 본 개시내용은 본원에서 나타낸 양상들로 제한되도록 의도되는 것이 아니라 후속하는 청구항들에 의해 정의되는 바와 같은 원리들 및 신규한 특징들과 부합하는 가능한 가장 넓은 범위를 따르도록 의도된다.

Claims (30)

  1. 장치로서,
    메모리; 및
    상기 메모리에 커플링되는 프로세서를 포함하며,
    상기 프로세서는,
    데이터 링크 그룹의 데이터 링크 그룹 식별자에 대응하는 제1 식별자를 결정하고,
    디바이스에 대응하는 제2 식별자를 결정하고, 그리고
    데이터 링크 라우팅 프리픽스(routing prefix), 상기 제1 식별자, 및 상기 제2 식별자의 결합에 기초하여, 상기 디바이스의 데이터 링크 인터페이스에 대한 인터넷 프로토콜(IP) 어드레스를 생성하도록
    구성되는, 장치.
  2. 제1항에 있어서,
    상기 프로세서는 추가로, 상기 IP 어드레스를 생성하기 위해 상기 데이터 링크 라우팅 프리픽스, 상기 제1 식별자, 및 상기 제2 식별자를 연접(concatenate)시키도록 구성되며,
    상기 데이터 링크 라우팅 프리픽스는 데이터 링크 네트워크들에서의 사용에 전용되는, 장치.
  3. 제1항에 있어서,
    상기 데이터 링크 인터페이스는 상기 데이터 링크 그룹의 하나 또는 그 초과의 디바이스들에 제1 데이터 패킷을 송신하도록 구성되며,
    상기 제1 데이터 패킷의 헤더는, 상기 제1 데이터 패킷의 소스 어드레스로서 상기 데이터 링크 인터페이스에 대한 IP 어드레스를 표시하는 어드레스 데이터를 포함하는, 장치.
  4. 제3항에 있어서,
    상기 프로세서에 커플링되는 수신기를 더 포함하며,
    상기 수신기는,
    상기 데이터 링크 그룹의 제2 디바이스로부터 제2 데이터 패킷을 수신하고 ― 상기 제2 데이터 패킷의 제2 헤더는, 상기 제2 데이터 패킷의 목적지(destination) 어드레스로서 상기 데이터 링크 인터페이스에 대한 IP 어드레스를 표시하는 제2 어드레스 데이터를 포함함 ―; 그리고
    상기 제2 데이터 패킷에 포함된 IP 어드레스에 기초하여 상기 데이터 링크 인터페이스에 상기 제2 데이터 패킷을 제공하도록
    구성되는, 장치.
  5. 제1항에 있어서,
    상기 프로세서는 추가로, 상기 제1 식별자를 결정하기 위해 상기 데이터 링크 그룹 식별자에 해시 함수(hash function)를 적용하도록 구성되는, 장치.
  6. 제1항에 있어서,
    상기 데이터 링크 그룹은 이웃 인식 네트워크(NAN; neighbor aware network)의 이웃 인식 네트워크 데이터 링크(NDL; neighbor aware network data link) 그룹에 대응하고, 그리고
    상기 데이터 링크 그룹 식별자는 상기 NAN 내에서 고유한, 장치.
  7. 제1항에 있어서,
    상기 IP 어드레스는 IPv6(IP version 6) 어드레스 또는 IPv4(IP version 4) 어드레스에 대응하는, 장치.
  8. 제1항에 있어서,
    상기 프로세서는 추가로, 상기 디바이스의 MAC(media access control) 식별자에 기초하여 상기 제2 식별자를 결정하도록 구성되며,
    상기 제2 식별자는 인터페이스 식별자를 포함하는, 장치.
  9. 제8항에 있어서,
    제2 데이터 링크 인터페이스를 더 포함하며,
    상기 프로세서는 추가로,
    제2 데이터 링크 그룹의 제2 데이터 링크 그룹 식별자에 대응하는 제3 식별자를 결정하고;
    상기 디바이스의 제2 MAC 식별자에 기초하여 제4 식별자를 결정하고; 그리고
    상기 데이터 링크 라우팅 프리픽스, 상기 제3 식별자, 및 상기 제4 식별자의 결합에 기초하여 상기 제2 데이터 링크 인터페이스에 대한 제2 IP 어드레스를 생성하도록
    구성되는, 장치.
  10. 제1항에 있어서,
    제2 데이터 링크 인터페이스를 더 포함하며,
    상기 프로세서는 추가로,
    상기 제2 데이터 링크 인터페이스를 생성하고;
    제2 데이터 링크 그룹의 제2 데이터 링크 그룹 식별자에 대응하는 제3 식별자를 결정하고; 그리고
    상기 데이터 링크 라우팅 프리픽스, 상기 제2 식별자, 및 상기 제3 식별자의 결합에 기초하여 상기 제2 데이터 링크 인터페이스에 대한 제2 IP 어드레스를 생성하도록
    구성되는, 장치.
  11. 제1항에 있어서,
    상기 프로세서는 추가로,
    데이터 링크 서브넷(subnet) 식별자를 생성하기 위해 상기 제1 식별자를 상기 데이터 링크 라우팅 프리픽스와 결합시키고 ― 상기 IP 어드레스는 상기 데이터 링크 서브넷 식별자와 상기 제2 식별자의 결합에 추가로 기초하여 생성됨 ―;
    상기 데이터 링크 서브넷 식별자가 이웃 인식 네트워크(NAN)의 디바이스들에 의해 사용되는 서브넷의 식별자와 충돌(conflict)하는지 여부를 결정하고; 그리고
    상기 데이터 링크 서브넷 식별자가 상기 NAN의 디바이스들에 의해 사용되는 서브넷의 식별자와 충돌한다는 결정에 대한 응답으로, 상기 데이터 링크 서브넷 식별자를 업데이트하도록
    구성되는, 장치.
  12. 제11항에 있어서,
    상기 데이터 링크 라우팅 프리픽스는 비-전역적으로(non-globally) 라우팅가능한 프리픽스에 대응하는, 장치.
  13. 제1항에 있어서,
    상기 프로세서는 추가로,
    로컬 어드레스 프리픽스를 결정하고; 그리고
    조직(organization)에 대응하는 제5 식별자를 결정하도록
    구성되며,
    상기 데이터 링크 라우팅 프리픽스는 적어도 상기 로컬 어드레스 프리픽스 및 제5 식별자를 포함하는, 장치.
  14. 제13항에 있어서,
    상기 로컬 어드레스 프리픽스는 IPv6(IP version 6) ULA(unique local address) 프리픽스 또는 특정 IPv4(IP version 4) 프리픽스에 대응하는, 장치.
  15. 제13항에 있어서,
    상기 데이터 링크 라우팅 프리픽스는 로컬 표시자 비트를 더 포함하고, 그리고
    상기 로컬 어드레스 프리픽스, 상기 로컬 표시자 비트, 및 상기 제5 식별자의 결합은 고유 프리픽스에 대응하는, 장치.
  16. 제13항에 있어서,
    상기 IP 어드레스는 128-비트 IPv6(IP version 6) 어드레스를 포함하며,
    상기 128-비트 IPv6 어드레스에서,
    처음 7개의 비트들은 상기 로컬 어드레스 프리픽스를 표시하고;
    상기 로컬 어드레스 프리픽스에 연속하여 후속되는 비트는 로컬 표시자 비트를 포함하고 ― 상기 로컬 표시자 비트는 상기 IPv6 어드레스가 로컬로 할당됨을 표시하는 제1 값을 가짐 ―;
    상기 로컬 표시자 비트에 연속하여 후속되는 40개의 비트들은 상기 제5 식별자를 표시하고;
    상기 제5 식별자에 연속하여 후속되는 16개의 비트들은 상기 제1 식별자를 표시하고; 그리고
    상기 제1 식별자에 연속하여 후속되는 64개의 비트들은 상기 제2 식별자를 표시하는,
    장치.
  17. 방법으로서,
    디바이스에 의해, 데이터 링크 그룹의 데이터 링크 그룹 식별자에 대응하는 제1 식별자를 결정하는 단계;
    상기 디바이스에 의해, 상기 디바이스에 대응하는 제2 식별자를 결정하는 단계; 및
    상기 디바이스에 의해, 데이터 링크 라우팅 프리픽스, 상기 제1 식별자, 및 상기 제2 식별자에 기초하여, 상기 디바이스의 데이터 링크 인터페이스에 대한 인터넷 프로토콜(IP) 어드레스를 생성하는 단계를 포함하는, 방법.
  18. 제17항에 있어서,
    상기 디바이스의 데이터 링크 인터페이스에 대한 IP 어드레스에 기초하여, 상기 디바이스로부터 상기 데이터 링크 그룹의 하나 또는 그 초과의 디바이스들로 제1 데이터 패킷을 전송하는 단계; 및
    상기 디바이스의 데이터 링크 인터페이스에 대한 IP 어드레스에 기초하여, 상기 데이터 링크 그룹의 하나 또는 그 초과의 디바이스들 중 제2 디바이스로부터 제2 데이터 패킷을 수신하는 단계를 더 포함하는, 방법.
  19. 제17항에 있어서,
    제1 무선 네트워크의 기지국으로부터 서비스에 대응하는 데이터를 수신하는 단계; 및
    상기 서비스에 대응하는 데이터를 상기 데이터 링크 그룹의 하나 또는 그 초과의 디바이스들에 제공하는 단계를 더 포함하며,
    데이터 링크의 상기 하나 또는 그 초과의 디바이스들은 제2 무선 네트워크에 대응하는, 방법.
  20. 제17항에 있어서,
    상기 제1 식별자를 결정하기 위해 상기 데이터 링크 그룹 식별자에 해시 함수를 적용하는 단계를 더 포함하며,
    상기 데이터 링크 그룹은 이웃 인식 네트워크(NAN)의 이웃 인식 네트워크 데이터 링크(NDL) 그룹에 대응하고, 그리고
    상기 데이터 링크 그룹 식별자는 상기 NAN 내에서 고유한, 방법.
  21. 제17항에 있어서,
    상기 디바이스에 의해, 데이터 링크 서브넷 식별자를 생성하기 위해 상기 제1 식별자를 상기 데이터 링크 라우팅 프리픽스와 결합시키는 단계를 더 포함하는, 방법.
  22. 제21항에 있어서,
    상기 디바이스에 의해, 상기 IP 어드레스를 생성하기 위해 상기 데이터 링크 서브넷 식별자와 상기 제2 식별자를 결합시키는 단계를 더 포함하며,
    상기 IP 어드레스는 IPv6(IP version 6) 어드레스 또는 IPv4(IP version 4) 어드레스에 대응하는, 방법.
  23. 제21항에 있어서,
    상기 데이터 링크 서브넷 식별자가 데이터 링크 네트워크의 디바이스들에 의해 사용되는 서브넷의 식별자와 충돌하는지 여부를 결정하는 단계; 및
    상기 데이터 링크 서브넷 식별자가 상기 데이터 링크 네트워크의 디바이스들에 의해 사용되는 서브넷의 식별자와 충돌한다고 결정하는 것에 대한 응답으로, 상기 데이터 링크 서브넷 식별자를 업데이트하는 단계를 더 포함하는, 방법.
  24. 제23항에 있어서,
    제2 디바이스로부터 충돌 통지를 수신하는 단계 ― 상기 충돌 통지는, 상기 데이터 링크 서브넷 식별자가 다른 디바이스에 의해 사용 중임을 표시하는 충돌 데이터를 포함함 ―; 및
    상기 충돌 통지를 수신하는 것에 대한 응답으로, 상기 데이터 링크 서브넷 식별자가 상기 데이터 링크 네트워크의 디바이스들에 의해 사용되는 서브넷의 식별자와 충돌한다는 것을 결정하는 단계를 더 포함하는, 방법.
  25. 제17항에 있어서,
    상기 디바이스에 의해, 로컬 어드레스 프리픽스를 결정하는 단계; 및
    상기 디바이스에 의해, 조직에 대응하는 제3 식별자를 결정하는 단계를 더 포함하며,
    상기 데이터 링크 라우팅 프리픽스는 상기 로컬 어드레스 프리픽스, 로컬 표시자 비트, 및 상기 제3 식별자를 포함하는, 방법.
  26. 제25항에 있어서,
    상기 디바이스의 애플리케이션에 의해, 제1 커맨드를 생성하는 단계 ― 상기 제1 커맨드는 제2 데이터 링크 인터페이스의 생성을 야기하도록 구성됨 ―;
    상기 디바이스에서, 상기 제1 커맨드를 실행하는 것에 대한 응답으로 상기 제2 데이터 링크 인터페이스를 생성하는 단계 ― 상기 제2 데이터 링크 인터페이스는 제2 IP 어드레스 및 제2 데이터 링크 그룹에 대응함 ―; 및
    제2 커맨드를 실행하는 것에 대한 응답으로, 상기 제2 데이터 링크 인터페이스에 제3 IP 어드레스를 할당하는 단계를 더 포함하며,
    상기 제2 데이터 링크 인터페이스는 제3 데이터 링크 그룹에 대응하는, 방법.
  27. 장치로서,
    데이터 링크 그룹의 데이터 링크 그룹 식별자에 대응하는 제1 식별자를 결정하기 위한 수단;
    디바이스에 대응하는 제2 식별자를 결정하기 위한 수단; 및
    데이터 링크 라우팅 프리픽스, 상기 제1 식별자, 및 상기 제2 식별자의 결합에 기초하여, 상기 디바이스의 데이터 링크 인터페이스에 대한 인터넷 프로토콜(IP) 어드레스를 생성하기 위한 수단을 포함하는, 장치.
  28. 제27항에 있어서,
    상기 제1 식별자를 상기 라우팅 프리픽스와 결합시킴으로써 데이터 링크 서브넷 식별자를 생성하기 위한 수단; 및
    상기 데이터 링크 서브넷 식별자가 데이터 링크 네트워크의 디바이스들에 의해 사용되는 서브넷의 식별자와 충돌한다고 결정하는 것에 대한 응답으로, 상기 데이터 링크 서브넷 식별자를 업데이트하기 위한 수단을 더 포함하는, 장치.
  29. 명령들을 저장하는 컴퓨터-판독가능 저장 디바이스로서,
    상기 명령들은, 프로세서에 의해 실행되는 경우, 상기 프로세서로 하여금 동작들을 수행하게 하며,
    상기 동작들은,
    데이터 링크 그룹의 데이터 링크 그룹 식별자에 대응하는 제1 식별자를 결정하는 것;
    디바이스에 대응하는 제2 식별자를 결정하는 것; 및
    데이터 링크 라우팅 프리픽스, 상기 제1 식별자, 및 상기 제2 식별자의 결합에 기초하여, 상기 디바이스의 데이터 링크 인터페이스에 대한 인터넷 프로토콜(IP) 어드레스를 생성하는 것
    을 포함하는, 컴퓨터-판독가능 저장 디바이스.
  30. 제29항에 있어서,
    상기 IP 어드레스는 IPv6(IP version 6) 어드레스 또는 IPv4(IP version 4) 어드레스에 대응하고, 그리고
    상기 데이터 링크 라우팅 프리픽스는 데이터 링크 네트워크에서 사용되는, 컴퓨터-판독가능 저장 디바이스.
KR1020177030379A 2015-04-23 2016-04-22 데이터 링크 인터페이스 인터넷 프로토콜(ip) 어드레스 생성 KR20170139544A (ko)

Applications Claiming Priority (7)

Application Number Priority Date Filing Date Title
US201562151954P 2015-04-23 2015-04-23
US62/151,954 2015-04-23
US201562209279P 2015-08-24 2015-08-24
US62/209,279 2015-08-24
US15/134,572 2016-04-21
US15/134,572 US10110488B2 (en) 2015-04-23 2016-04-21 Data link interface internet protocol (IP) address generation
PCT/US2016/028907 WO2016172523A1 (en) 2015-04-23 2016-04-22 Data link interface internet protocol (ip) address generation

Publications (1)

Publication Number Publication Date
KR20170139544A true KR20170139544A (ko) 2017-12-19

Family

ID=55910416

Family Applications (1)

Application Number Title Priority Date Filing Date
KR1020177030379A KR20170139544A (ko) 2015-04-23 2016-04-22 데이터 링크 인터페이스 인터넷 프로토콜(ip) 어드레스 생성

Country Status (6)

Country Link
US (1) US10110488B2 (ko)
EP (1) EP3286906A1 (ko)
JP (1) JP2018518867A (ko)
KR (1) KR20170139544A (ko)
CN (1) CN107534692A (ko)
WO (1) WO2016172523A1 (ko)

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR20200031895A (ko) * 2018-09-17 2020-03-25 주식회사 엘지유플러스 관제 서버, 그를 이용한 무인 비행체의 비행경로 설정방법 및 그를 위한 비행경로 안내 시스템

Families Citing this family (12)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN108029123B (zh) * 2015-07-09 2022-03-25 瑞典爱立信有限公司 用于控制无线电接入节点的方法和装置
US10231258B2 (en) * 2016-08-30 2019-03-12 Apple Inc. Neighbor awareness networking—schedule update
US10412042B2 (en) * 2016-09-21 2019-09-10 Rockwell Automation Technologies, Inc. Topology based internet protocol (IP) addressing
US10924454B2 (en) * 2018-03-06 2021-02-16 Kaloom Inc. Computing device and method for generating a fabric-wide IPV6 address
US10673695B2 (en) 2018-03-06 2020-06-02 Kaloom Inc. Computing device and method for performing a fabric deployment in a data center
US10873500B2 (en) 2018-03-06 2020-12-22 Kaloom Inc. Computing device and method for generating a link IPV6 address
US10915594B2 (en) * 2018-10-22 2021-02-09 Fujitsu Limited Associating documents with application programming interfaces
US20210409328A1 (en) * 2018-11-01 2021-12-30 Nokia Technologies Oy Ipv6 address management in iab system
JP7437722B2 (ja) * 2019-01-31 2024-02-26 コネクトフリー株式会社 データ送信方法、通信処理方法、装置、および通信処理プログラム
US11206640B2 (en) 2019-05-22 2021-12-21 At&T Intellectual Property I, L.P. Private local network access, authentication, and association for 5G or other next generation network
CN111654445A (zh) * 2020-07-10 2020-09-11 清华大学 一种数据包传输方法、信息处理方法、节点设备和介质
CN114051018B (zh) * 2021-09-24 2024-04-12 中盈优创资讯科技有限公司 基于网络架构为网络设备分配IPv6地址的方法及装置

Family Cites Families (17)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR20020022317A (ko) * 2000-09-19 2002-03-27 윤종용 홈 게이트웨이 및 그 운용방법
DE10244612A1 (de) * 2002-09-25 2004-04-08 Siemens Ag Verfahren zum transparenten Austausch von Datenpaketen
KR100579834B1 (ko) * 2003-10-20 2006-05-15 삼성전자주식회사 모바일 애드혹 네트워크에서 ip 사이트로컬 프리픽스풀을 이용한 주소 할당방법
KR100728040B1 (ko) * 2006-04-28 2007-06-13 삼성전자주식회사 IPv6 유니크 로컬 주소 생성 방법 및 장치
CN101378340B (zh) * 2007-08-31 2011-08-24 西门子(中国)有限公司 一种获取互联网协议地址前缀的方法、运营商边缘设备和客户端设备
US20090248841A1 (en) * 2008-03-28 2009-10-01 Motorola, Inc. Unique prefix assignment with automatic address configuration
US8316137B2 (en) * 2008-06-24 2012-11-20 Qualcomm Incorporated Method and apparatus for ensuring IPv6 uniqueness in a mobile subnetted environment
DE102010040020A1 (de) 2010-08-31 2012-03-01 Bayerische Motoren Werke Aktiengesellschaft Bestimmung einer Adresse einer Komponente eines Fahrzeugs
US8661544B2 (en) * 2010-08-31 2014-02-25 Cisco Technology, Inc. Detecting botnets
JP5597624B2 (ja) * 2010-12-29 2014-10-01 ノキア コーポレイション 短距離通信を介したネットワーク設定
US8688807B2 (en) * 2011-08-18 2014-04-01 Cisco Technology, Inc. Deriving unique local addresses from device names
US9231908B2 (en) * 2012-02-08 2016-01-05 Microsoft Technology Licensing, Llc Ensuring symmetric routing to private network
JP5950699B2 (ja) * 2012-05-31 2016-07-13 キヤノン株式会社 通信装置及びその制御方法
US9191209B2 (en) * 2013-06-25 2015-11-17 Google Inc. Efficient communication for devices of a home network
US20160105291A1 (en) * 2014-10-13 2016-04-14 Qualcomm Incorporated Establishing a multicast signaling control channel based on a multicast address that is related to floor arbitration for a p2p session
US9369374B1 (en) * 2015-02-03 2016-06-14 Google Inc. Mesh network addressing
US9860745B2 (en) * 2015-02-23 2018-01-02 Qualcomm Incorporated Methods and apparatuses for NAN data link group formation and data frame address settings

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR20200031895A (ko) * 2018-09-17 2020-03-25 주식회사 엘지유플러스 관제 서버, 그를 이용한 무인 비행체의 비행경로 설정방법 및 그를 위한 비행경로 안내 시스템

Also Published As

Publication number Publication date
US20160315859A1 (en) 2016-10-27
CN107534692A (zh) 2018-01-02
JP2018518867A (ja) 2018-07-12
EP3286906A1 (en) 2018-02-28
WO2016172523A1 (en) 2016-10-27
US10110488B2 (en) 2018-10-23

Similar Documents

Publication Publication Date Title
US10110488B2 (en) Data link interface internet protocol (IP) address generation
US10873896B2 (en) Minimizing link layer discovery based on advertising access technology parameters in a multimode mesh network
US10057342B2 (en) Infrastructure access via neighbor awareness networking data path
ES2633480T3 (es) Sistemas y procedimientos para la sincronización dentro de una red para vecinos
US9621458B2 (en) Internet routing over a service-oriented architecture bus
US9277399B2 (en) Systems and methods for reduced latency when establishing communication with a wireless communication system
US20120120934A1 (en) Method for tethering network connection, method for connecting to network, and wireless communication group applying the same
JP2018528686A (ja) 複数アクセスポイント無線メッシュネットワーク
US9608863B2 (en) Address autoconfiguration using bloom filter parameters for unique address computation
US20190036873A1 (en) Alias-Based Time-Limited Lease Addressing for Internet of Things Devices
JP5820106B2 (ja) 通信装置、および、その制御方法
WO2017024909A1 (zh) 一种进行数据传输的方法和设备
CN101213770A (zh) 用于在无线网络中执行快速切换的方法和装置
US20050157749A1 (en) System and method for communication with an external network in an IPv6 MANET network
WO2007052913A1 (en) Method of generating and managing connection identifiers for supporting multicast for each group in ipv6-based wireless network and network interface using the method
JP2018526923A (ja) 通信ネットワークのための強化近隣発見
CN103037361A (zh) 基于Ad-hoc的无线Mesh网络中的IP分配系统及方法
JP7404185B2 (ja) 通信システム、ノード、通信方法及びプログラム
WO2015027474A1 (zh) 数据报头封装方法、解封装方法、装置及设备
JP4913208B2 (ja) アドレス解決方法
US9936473B2 (en) Method and apparatus for managing radio interfaces
WO2017090158A1 (ja) 基地局装置、端末装置、及び、無線通信システム、通信切替方法
WO2017011947A1 (zh) 一种通信方法、装置和系统
WO2023185992A1 (zh) 中继通信方法与装置
KR20060117085A (ko) 그룹 통신을 위한 마스터 노드 nat 방법 및 이를 이용한이동통신단말기

Legal Events

Date Code Title Description
E701 Decision to grant or registration of patent right