KR20060014875A - Method and apparatus for transmitting ack frame - Google Patents

Method and apparatus for transmitting ack frame Download PDF

Info

Publication number
KR20060014875A
KR20060014875A KR1020040063599A KR20040063599A KR20060014875A KR 20060014875 A KR20060014875 A KR 20060014875A KR 1020040063599 A KR1020040063599 A KR 1020040063599A KR 20040063599 A KR20040063599 A KR 20040063599A KR 20060014875 A KR20060014875 A KR 20060014875A
Authority
KR
South Korea
Prior art keywords
frame
bit
msdu
identification information
field
Prior art date
Application number
KR1020040063599A
Other languages
Korean (ko)
Other versions
KR100631736B1 (en
Inventor
홍진우
배대규
성현아
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 삼성전자주식회사
Priority to KR1020040063599A priority Critical patent/KR100631736B1/en
Priority to MX2007001682A priority patent/MX2007001682A/en
Priority to JP2007525531A priority patent/JP2008509622A/en
Priority to BRPI0514128-1A priority patent/BRPI0514128A/en
Priority to PCT/KR2005/002420 priority patent/WO2006016745A1/en
Priority to CNA2005100907185A priority patent/CN1734998A/en
Priority to US11/201,442 priority patent/US20060034317A1/en
Priority to EP05255018A priority patent/EP1626520A1/en
Publication of KR20060014875A publication Critical patent/KR20060014875A/en
Application granted granted Critical
Publication of KR100631736B1 publication Critical patent/KR100631736B1/en

Links

Images

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L1/00Arrangements for detecting or preventing errors in the information received
    • H04L1/12Arrangements for detecting or preventing errors in the information received by using return channel
    • H04L1/14Arrangements for detecting or preventing errors in the information received by using return channel in which the signals are sent back to the transmitter to be checked ; echo systems
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L1/00Arrangements for detecting or preventing errors in the information received
    • H04L1/12Arrangements for detecting or preventing errors in the information received by using return channel
    • H04L1/16Arrangements for detecting or preventing errors in the information received by using return channel in which the return channel carries supervisory signals, e.g. repetition request signals
    • H04L1/1607Details of the supervisory signal
    • H04L1/1614Details of the supervisory signal using bitmaps
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L1/00Arrangements for detecting or preventing errors in the information received
    • H04L1/12Arrangements for detecting or preventing errors in the information received by using return channel
    • H04L1/16Arrangements for detecting or preventing errors in the information received by using return channel in which the return channel carries supervisory signals, e.g. repetition request signals
    • H04L1/18Automatic repetition systems, e.g. Van Duuren systems
    • H04L1/1867Arrangements specially adapted for the transmitter end
    • 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

Landscapes

  • Engineering & Computer Science (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Signal Processing (AREA)
  • Computer Security & Cryptography (AREA)
  • Communication Control (AREA)
  • Mobile Radio Communication Systems (AREA)

Abstract

본 발명은 보다 효율적인 버스트 ACK(burst ACK)을 이용한 무선 통신 방법에 관한 것이다. The present invention relates to a wireless communication method using more efficient burst ACK.

본 발명에 따른 ACK 프레임 전송 방법은, 송신 디바이스로부터 프레임을 수신하고 수신된 프레임의 식별 정보를 저장하는 단계와, 상기 저장된 식별 정보를 이용하고 상기 수신된 각 프레임에 대한 비트쌍의 집합을 기록하여 제1 필드를 생성하는 단계와, 생성된 제1 필드를 포함하여 ACK 프레임을 생성하는 단계와, 생성된 ACK 프레임을 송신 디바이스에 전송하는 단계를 포함하며, 상기 비트쌍은 해당 프레임이 정상적으로 수신되었는가를 확인하는 제1 비트와, 제1 비트가 해당 프레임 하나에 대한 수신 확인을 나타내는 것인가, 해당 프레임 이후의 모든 프래그먼트에 대한 수신 확인을 나타내는 것인가를 구별하는 제2 비트로서 구성된다.An ACK frame transmission method according to the present invention comprises receiving a frame from a transmitting device and storing identification information of the received frame, using the stored identification information and recording a set of bit pairs for each received frame Generating a first field, generating an ACK frame including the generated first field, and transmitting the generated ACK frame to a transmitting device, wherein the bit pair is whether the corresponding frame has been normally received; And a second bit for identifying whether the first bit indicates an acknowledgment for one frame or an acknowledgment for all fragments after the frame.

무선 네트워크, MSDU, Fragment, ACKWireless network, MSDU, Fragment, ACK

Description

ACK 프레임 전송 방법 및 장치{Method and apparatus for transmitting ACK frame}Method and apparatus for transmitting ACK frame {Method and apparatus for transmitting ACK frame}

도 1은 일반적인 버스트 ACK 프레임 전송 방식을 설명하는 도면.1 is a diagram illustrating a general burst ACK frame transmission scheme.

도 2는 IEEE 802.15.3 표준에 따른 지연 ACK 프레임의 구성을 나타낸 도면.2 is a diagram illustrating a configuration of a delayed ACK frame according to the IEEE 802.15.3 standard.

도 3은 IEEE 802.11e 표준에 따른 블럭 ACK 프레임의 구성을 나타낸 도면.3 is a diagram illustrating a configuration of a block ACK frame according to the IEEE 802.11e standard.

도 4는 본 발명의 일 실시예에 따른 버스트 ACK 프레임의 구성을 나타낸 도면.4 is a diagram illustrating a configuration of a burst ACK frame according to an embodiment of the present invention.

도 5는 종래의 IEEE 802.11 계열 표준의 MAC header 및 IEEE 802.15.3 표준의 MAC header의 구조를 나타낸 도면.5 is a diagram illustrating the structure of the MAC header of the IEEE 802.11 series standard and the MAC header of the IEEE 802.15.3 standard.

도 6 내지 도 10은 여러 가지 실시예에 따라서 버스트 ACK 프레임이 어떻게 결정되는가를 설명하기 위한 도면.6 to 10 are diagrams for describing how a burst ACK frame is determined according to various embodiments.

도 11은 본 발명의 일 실시예에 따른 무선 디바이스의 구성을 나타낸 블록도.11 is a block diagram showing a configuration of a wireless device according to an embodiment of the present invention.

도 12는 버스트 ACK 생성 모듈의 세부 구성을 나타낸 블록도.12 is a block diagram showing a detailed configuration of a burst ACK generation module.

도 13은 종래의 IEEE 802.11 계열 표준에 따른 MAC Header의 구성을 상세히 도시한 도면.13 is a diagram illustrating in detail the configuration of a MAC header according to a conventional IEEE 802.11 series standard.

도 14는 종래의 IEEE 802.15.3 표준에 따른 MAC Header의 구성을 상세히 도 시한 도면.14 is a diagram illustrating in detail the configuration of a MAC header according to the conventional IEEE 802.15.3 standard.

도 15는 본 발명의 일 실시예에 따른 버스트 ACK 프레임 생성 과정을 나타낸 흐름도.15 is a flowchart illustrating a burst ACK frame generation process according to an embodiment of the present invention.

도 16은 도 15의 S50 단계에 대한 보다 자세한 과정을 나타낸 흐름도.16 is a flowchart illustrating a more detailed process for step S50 of FIG.

(도면의 주요부분에 대한 부호 설명)(Symbol description of main part of drawing)

100 : 버스트 ACK 프레임 200 : 무선 디바이스100: burst ACK frame 200: wireless device

210 : 버스트 ACK 생성 모듈 211 : 생성 제어 모듈210: burst ACK generation module 211: generation control module

212 : MPDU ID 생성 모듈 213 : 비트맵 생성 모듈212: MPDU ID generation module 213: Bitmap generation module

214 : 패드 생성 모듈 220 : MAC 모듈214: pad generation module 220: MAC module

230 : 상위층 모듈 240 : PHY 모듈230: upper layer module 240: PHY module

250 : 메모리 260 : 제어 유닛250: memory 260: control unit

본 발명은 무선 통신 방법에 관한 것으로, 보다 상세하게는 보다 효율적인 버스트 ACK(burst ACK)을 이용한 무선 통신 방법에 관한 것이다.The present invention relates to a wireless communication method, and more particularly, to a wireless communication method using more efficient burst ACK (burst ACK).

네트워크가 무선화 되어가고 있고 대용량의 멀티미디어 데이터 전송 요구의 증대로 인하여 무선 네트워크 환경에서의 효과적인 전송법에 대한 연구가 요구되고 있다. 주어진 무선 자원을 여러 디바이스들이 공유하여 사용하는 무선 네트워크의 특성상, 경쟁이 증가하면 통신 중에 충돌로 인해 귀중한 무선 자원을 허비하게 될 가능성이 크다. 이러한 충돌을 줄이고 안정하게 데이터를 송수신하도록 하기 위하여, 무선 LAN(wireless Local Area Network) 환경에서는 경쟁 기반의 DCF(Distributed Coordination Function) 또는 무경쟁 방식의 PCF(Point Coordination Function)를 사용하고 있고, 무선 PAN(wireless Personal Area Network) 환경에서는 채널 시간 할당(channel time allocation)이라는 시분할 방식을 사용하고 있다.Networks are becoming wireless and researches on effective transmission methods in wireless network environments have been required due to the increasing demand for large-capacity multimedia data transmission. Due to the nature of a wireless network in which multiple devices share and use a given radio resource, increasing competition is likely to waste valuable radio resources due to collisions during communication. In order to reduce such collisions and to transmit and receive data stably, a wireless LAN (wireless local area network) environment uses a competitive-based distributed coordination function (DCF) or a contention free point coordination function (PCF), and a wireless PAN. In a wireless personal area network environment, a time division scheme called channel time allocation is used.

이와 같은 방법으로 하여 무선 환경에서 충돌 없이 안정적으로 데이터를 송수신할 수 있지만, 하나의 디바이스가 통신하는 동안에는 같은 전파 범위 내에 존재하는 다른 디바이스는 대기할 수 밖에 없으므로, 디바이스의 수가 늘어나면 전송률은 상당히 감소하게 된다. 따라서, 무선 네트워크 환경에서 안정적인 통신을 보장하면서 동시에 데이터 전송률을 향상시키는 것이 중요한 쟁점이 되고 있다.In this way, data can be reliably transmitted and received in a wireless environment without collision, but while one device communicates, other devices within the same radio range have to wait, so the transmission rate decreases considerably as the number of devices increases. Done. Therefore, it is an important issue to ensure stable communication in a wireless network environment and to improve data transmission rate at the same time.

전송률을 향상시키기 위해서는, 주로 전송하는 데이터에서 불필요한 오버헤드를 줄이는 방법, 또는 디바이스 간에 시간 할당을 보다 효율적으로 하는 방법 등이 있다. 본 발명은 이 중에서도, 무선 네트워크 환경(무선 LAN, 무선 PAN 등)에서 빈번히 사용되는 ACK 프레임(Acknowledgement frame)의 구조를 보다 효율적으로 간략화하여 ACK 프레임으로 인한 트래픽(traffic)을 감소시키기 위한 것이다.In order to improve the transmission rate, there is a method of reducing unnecessary overhead mainly in data to be transmitted, or a method of more efficiently allocating time between devices. The present invention is to reduce the traffic caused by the ACK frame more efficiently by simplifying the structure of the acknowledgment frame frequently used in the wireless network environment (wireless LAN, wireless PAN, etc.).

일반적으로, 데이터를 전송하는 디바이스(이하, 송신 디바이스라 함)가 데이터를 수신하는 디바이스(이하, 수신자 디바이스)에 데이터 프레임을 전송하면, 수신 디바이스가 상기 데이터 프레임을 제대로 수신한 경우에는 이를 알리는 ACK 프레임을 상기 송신 디바이스에 전송하게 된다. In general, when a device that transmits data (hereinafter referred to as a transmission device) transmits a data frame to a device that receives data (hereinafter, referred to as a receiver device), an ACK notifying when the receiving device receives the data frame properly. The frame is transmitted to the transmitting device.

이와 같은 ACK 프레임에는 하나의 프레임을 수신할 때 마다, 제대로 수신하였다는 사실을 즉시 알려 주는 ACK 프레임과, 일정 회수 동안 복수의 프레임을 수신하고 그 복수의 프레임 전체에 대하여 한꺼번에 수신 여부를 알려 주는 ACK 프레임이 있다. 전자의 ACK 프레임을 즉시 ACK 프레임(Immediate ACK frame)으로, 후자의 ACK 프레임을 버스트 ACK 프레임(Burst ACK frame)으로 정의할 수 있는데, 본 발명은 이 중에서도 버스트 ACK 프레임의 구조를 개선에 주안점을 두고 있다. The ACK frame includes an ACK frame immediately indicating that the frame has been properly received every time one frame is received, and an ACK frame that receives a plurality of frames for a predetermined number of times and indicates whether all the frames are received at once. There is a frame. The former ACK frame may be defined as an immediate ACK frame, and the latter ACK frame may be defined as a burst ACK frame. The present invention focuses on improving the structure of the burst ACK frame. have.

일반적인 버스트 ACK 프레임은 도 1에 나타내는 방식과 같이 전송된다. 송신 디바이스는 n개의 데이터 프레임을 수신 디바이스에 전송하면, 수신 디바이스는 n개의 데이터 프레임에 대한 ACK 프레임을 한번에 보냄으로써 즉시 ACK 프레임을 일일이 보내는데 비하여 트래픽을 감소시킬 수 있다.A general burst ACK frame is transmitted as shown in FIG. When the transmitting device transmits n data frames to the receiving device, the receiving device can reduce traffic as compared to sending an ACK frame immediately by sending ACK frames for the n data frames at once.

실제로, 이러한 버스트 ACK 프레임의 개념으로서, IEEE(Institute of Electrical and Electronics Engineers) 802.15.3 무선 PAN 표준에서는 지연 ACK 프레임(Delayed ACK frame)을 사용하고, IEEE 802.11e 무선 LAN 표준에서는 블럭 ACK 프레임(Block ACK frame)을 사용한다.In fact, as a concept of such burst ACK frame, a delayed ACK frame is used in the Institute of Electrical and Electronics Engineers (IEEE) 802.15.3 wireless PAN standard, and a block ACK frame (Block) in the IEEE 802.11e wireless LAN standard. ACK frame).

도 2는 IEEE 802.15.3 표준에 따른 지연 ACK 프레임(10)의 구성을 나타낸 것이다. IEEE 802.15.3에서 프레임 포맷은 우측에서부터 표시하는 것이 일반적이므로 우측단에 MAC header(11)가 표시되어 있다. 지연 ACK 프레임(10)은 MAC header(11)와, 지연 ACK을 대기하고 있는 프레임 중 최대 MAC 프레임 크기를 갖는 프레임의 수를 나타내는 Max burst 필드(12)와, 지연 ACK으로 한꺼번에 처리할 수 있는 최대 프레임 수를 나타내는 Max frames 필드(130)와, n개의 MPDU(MAC Protocol Data Unit) ID block 필드(15, 16, 등)와, 에러 체크섬(checksum)을 계산하기 위한 FCS 필드(17)로 구성될 수 있다.2 shows a configuration of a delayed ACK frame 10 according to the IEEE 802.15.3 standard. In IEEE 802.15.3, the frame format is generally displayed from the right side, so the MAC header 11 is displayed on the right side. The delayed ACK frame 10 includes a MAC header 11, a Max burst field 12 indicating the number of frames having the maximum MAC frame size among the frames waiting for the delayed ACK, and a maximum that can be processed simultaneously with the delayed ACK. Max frames field 130 indicating the number of frames, n MPDU (MAC Protocol Data Unit) ID block fields 15, 16, etc., and an FCS field 17 for calculating an error checksum. Can be.

MPDU ID block 필드(15, 16, 등) 각각은 다시 송신 디바이스의 MAC 단에서 상위층(예를 들어, LLC(Logical Link Control) 층)으로부터 MSDU(MAC Service Data Unit)를 수신할 때마다 1씩 증가되는 MSDU 번호(즉, MSDU의 식별번호)가 기록되는 MSDU number 필드(18)와, MSDU가 프래그먼트화되어 전송될 때 프래그먼트화 순서가 기록되는 Fragment number 필드(19)로 구성된다. 수신 디바이스는 자신이 수신한 데이터에 대하여 MSDU number와, Fragment number를 기록하여 송신 디바이스에 전송함으로써, 송신 디바이스는 전송한 데이터 중 어떤 데이터(MSDU 자체, 또는 MSDU의 일부 프래그먼트)가 제대로 전송되지 않았는지를 알게 된다. 이후 송신 디바이스는 제대로 전송되지 않은 데이터만을 수신 디바이스에 재전송하게 된다.Each of the MPDU ID block fields (15, 16, etc.) is incremented by one each time a MSDU (MAC Service Data Unit) is received from a higher layer (e.g., a Logical Link Control (LLC) layer) at the MAC side of the transmitting device. The MSDU number field 18, which records the MSDU number (that is, the identification number of the MSDU), is recorded, and the fragment number field 19, in which the fragmentation order is recorded when the MSDU is fragmented and transmitted. The receiving device records the MSDU number and the fragment number with respect to the data received by the receiving device and transmits the data to the transmitting device so that the transmitting device knows which data (MSDU itself or some fragment of the MSDU) was not transmitted properly. Get to know. Thereafter, the transmitting device retransmits only the data that is not properly transmitted to the receiving device.

도 2에 나타낸 바와 같이, IEEE 802.15.3 표준에서는 MSDU number 필드(18)에는 9비트가 할당되고, Fragment number 필드(19)에는 7비트가 할당되므로, 하나의 MPDU ID block 필드(15, 16, 등)는 2바이트(2 octet)가 할당된다.As shown in FIG. 2, in the IEEE 802.15.3 standard, 9 bits are allocated to the MSDU number field 18 and 7 bits are allocated to the fragment number field 19. Thus, one MPDU ID block field 15, 16, 2 octets are allocated.

도 3은 IEEE 802.11e 표준에 따른 블럭 ACK 프레임(20)의 구성을 나타낸 것이다. 블럭 ACK 프레임(20)은 MAC header(21)와, 블럭 ACK 프레임의 동작을 제어하기 위한 BA Control 필드(22)와, 첫 번째 MPDU의 fragment number와 sequence number가 기록되는 Block ACK Starting Sequence Control 필드(23)와, 이후의 MPDU에 대한 '수신 확인 정보'(특정 데이터를 올바르게 수신하였는가를 나타내는 정보)가 순서대로 기록되는 Block ACK Bitmap 필드(24)와, 에러 체크섬을 계산하기 위한 FCS 필드(25)로 구성될 수 있다.3 shows a configuration of a block ACK frame 20 according to the IEEE 802.11e standard. The block ACK frame 20 includes a MAC header 21, a BA Control field 22 for controlling the operation of the block ACK frame, and a Block ACK Starting Sequence Control field in which the fragment number and sequence number of the first MPDU are recorded. 23), a Block ACK Bitmap field 24 in which 'acknowledgement information' (information indicating whether the specific data has been received correctly) for subsequent MPDUs are recorded in order, and an FCS field 25 for calculating an error checksum. It can be configured as.

Block ACK Bitmap 필드(24)에는 128바이트가 할당되므로, 하나의 MSDU에 대하여 2바이트씩 할당한다면 최대, 64개의 MSDU에 대한 수신 확인 정보가 기록될 수 있다. 이와 같이, 하나의 MSDU에 대하여 2바이트가 할당되는 것은, IEEE 802.11e에서 하나의 MSDU는 최대 16개까지 프래그멘테이션(fragmentation) 될 수 있으므로 최대 프래그먼트화 개수만큼의 비트 수(16× 1비트), 즉 2바이트가 할당된 것이다. 따라서, 실제로 프래그멘테이션 되지 않거나, 16보다 작은 수만큼 프래그멘테이션이 이루어진 경우에도 2바이트가 일률적으로 할당되므로 이와 같이 하나의 비트로 수신 확인 정보를 나타내는 것은 효율적이지 못하다.Since 128 bytes are allocated to the Block ACK Bitmap field 24, when two bytes are allocated to one MSDU, acknowledgment information of up to 64 MSDUs can be recorded. In this way, two bytes are allocated to one MSDU. In IEEE 802.11e, up to 16 fragments can be fragmented in one MSDU, so that the maximum number of fragments (16 × 1 bit) can be obtained. 2 bytes are allocated. Therefore, even if the fragment is not actually fragmented or fragmented less than 16, two bytes are uniformly allocated, and thus it is not efficient to indicate the acknowledgment information in one bit.

도 2 또는 도 3에 나타낸 바와 같이 하나의 MSDU를 표현하는데, 2바이트를 사용한다고 하면, 버스트 ACK 프레임의 크기가 필요 이상으로 커지는 문제가 있다. 만약, n개의 데이터를 전송하고 이에 대한 버스트 ACK 프레임을 수신한다고 하면, 버스트 ACK 프레임의 페이로드(payload)는 2n 바이트 이상이 될 것이다. 따라서, 데이터의 전송회수가 증가할수록 따라서 버스트 ACK 프레임의 크기가 커짐으로써 무선 네트워크 환경에 불필요한 트래픽을 유발하게 된다.As shown in FIG. 2 or FIG. 3, when two bytes are used to represent one MSDU, there is a problem that the size of the burst ACK frame becomes larger than necessary. If n data is transmitted and a burst ACK frame is received, the payload of the burst ACK frame will be 2n bytes or more. Therefore, as the number of transmissions of data increases, the size of the burst ACK frame increases, thereby causing unnecessary traffic in the wireless network environment.

따라서, 기존의 버스트 ACK 프레임의 기능을 그대로 수행하면서 보다 작은 크기를 갖는 버스트 ACK 프레임을 개발하여 ACK 프레임으로 인한 트래픽을 감소시킬 필요가 있다. Therefore, it is necessary to reduce the traffic due to the ACK frame by developing a burst ACK frame having a smaller size while still performing the function of the existing burst ACK frame.

본 발명은 상기한 문제점을 고려하여 창안된 것으로, 버스트 ACK 프레임의 오버헤드(overhead)를 감소시키는 방법을 제공하는 것을 목적으로 한다.The present invention has been made in view of the above problems, and an object thereof is to provide a method for reducing overhead of a burst ACK frame.

또한 본 발명은, 하나의 MSDU에 대하여 2비트로 수신 확인 정보를 표시할 수 있는 방법을 제공하는 것을 목적으로 한다.Another object of the present invention is to provide a method capable of displaying reception acknowledgment information in two bits for one MSDU.

상기한 목적을 달성하기 위하여, 송신 디바이스로부터 복수의 프레임을 수신하고 이에 대하여 하나의 ACK 프레임으로 확인 응답을 하는 ACK 프레임 전송 방법으로서, (a) 상기 송신 디바이스로부터 프레임을 수신하고 상기 수신된 프레임의 식별 정보를 저장하는 단계; (b) 상기 저장된 식별 정보를 이용하여, 상기 수신된 각 프레임에 대한 비트쌍의 집합을 기록하여 제1 필드를 생성하는 단계; (c) 상기 생성된 필드를 포함하여 ACK 프레임을 생성하는 단계; 및 (d) 상기 생성된 ACK 프레임을 상기 송신 디바이스에 전송하는 단계를 포함하며, 상기 비트쌍은 해당 프레임이 정상적으로 수신되었는가를 확인하는 제1 비트와, 상기 제1 비트가 해당 프레임 하나에 대한 수신 확인을 나타내는 것인가, 해당 프레임 이후의 모든 프래그먼트에 대한 수신 확인을 나타내는 것인가를 구별하는 제2 비트로서 구성된다.In order to achieve the above object, an ACK frame transmission method for receiving a plurality of frames from the transmitting device and acknowledgment with a single ACK frame, (a) receiving a frame from the transmitting device and of the received frame Storing identification information; (b) using the stored identification information, recording a set of bit pairs for each received frame to generate a first field; (c) generating an ACK frame including the generated field; And (d) transmitting the generated ACK frame to the transmitting device, wherein the bit pair includes a first bit for confirming whether the corresponding frame is normally received, and the first bit is received for the corresponding frame. And a second bit for distinguishing whether to indicate acknowledgment or acknowledgment for all fragments after the frame.

상기한 목적을 달성하기 위하여, 송신 디바이스로부터 복수의 프레임을 수신하고 이에 대하여 하나의 ACK 프레임으로 확인 응답을 하는 ACK 프레임 전송 장치로서, 상기 송신 디바이스로부터 프레임을 수신하는 제1 수단; 상기 수신된 프레임의 식별 정보를 저장하는 제2 수단; 상기 저장된 식별 정보를 이용하여, 상기 수신된 각 프레임에 대한 비트쌍의 집합을 기록하여 제1 필드를 생성하고, 상기 생성된 필드를 포함하여 ACK 프레임을 생성하는 제3 수단; 및 상기 생성된 ACK 프레임을 상기 송신 디바이스에 전송하는 제4 수단을 포함하며, 상기 비트쌍은 해당 프레임이 정상적으로 수신되었는가를 확인하는 제1 비트와, 상기 제1 비트가 해당 프레임 하나에 대한 수신 확인을 나타내는 것인가, 해당 프레임 이후의 모든 프래그먼트에 대한 수신 확인을 나타내는 것인가를 구별하는 제2 비트로서 구성된다.In order to achieve the above object, an ACK frame transmitting apparatus for receiving a plurality of frames from a transmitting device and acknowledgment with one ACK frame, comprising: first means for receiving a frame from the transmitting device; Second means for storing identification information of the received frame; Third means for generating a first field by recording the set of bit pairs for each received frame using the stored identification information, and generating an ACK frame including the generated field; And fourth means for transmitting the generated ACK frame to the transmitting device, wherein the bit pair includes a first bit for confirming whether the corresponding frame is normally received, and the first bit confirms receipt for the corresponding frame. It is configured as a second bit to distinguish whether or not to indicate whether or not to indicate acknowledgment for all fragments after the frame.

이하, 첨부된 도면을 참조하여 본 발명의 바람직한 실시예를 상세히 설명한다. 본 발명의 이점 및 특징, 그리고 그것들을 달성하는 방법은 첨부되는 도면과 함께 상세하게 후술되어 있는 실시예들을 참조하면 명확해질 것이다. 그러나 본 발명은 이하에서 개시되는 실시예들에 한정되는 것이 아니라 서로 다른 다양한 형태로 구현될 것이며, 단지 본 실시예들은 본 발명의 개시가 완전하도록 하며, 본 발명이 속하는 기술분야에서 통상의 지식을 가진 자에게 발명의 범주를 완전하게 알려주기 위해 제공되는 것이며, 본 발명은 청구항의 범주에 의해 정의될 뿐이다. 명세서 전체에 걸쳐 동일 참조 부호는 동일 구성 요소를 지칭한다.Hereinafter, exemplary embodiments of the present invention will be described in detail with reference to the accompanying drawings. Advantages and features of the present invention and methods for achieving them will be apparent with reference to the embodiments described below in detail with the accompanying drawings. However, the present invention is not limited to the embodiments disclosed below, but may be implemented in various forms. It is provided to fully convey the scope of the invention to those skilled in the art, and the present invention is defined only by the scope of the claims. Like reference numerals refer to like elements throughout.

도 4는 본 발명의 일 실시예에 따른 버스트 ACK 프레임(100)의 구성을 나타낸 도면이다. 버스트 ACK 프레임(100)은 MAC header(110)와 페이로드 영역(120, 130, 140)으로 구성될 수 있다. MAC header(110)는 도 5의 110A와 같이 종래의 IEEE 802.11 계열 표준의 MAC header, 또는 도 5의 110B와 같이 종래의 IEEE 802.15.3 표준의 MAC header와 동일한 구성을 가질 수 있다.4 is a diagram illustrating a configuration of a burst ACK frame 100 according to an embodiment of the present invention. The burst ACK frame 100 may be composed of a MAC header 110 and payload regions 120, 130, and 140. The MAC header 110 may have the same configuration as the MAC header of the conventional IEEE 802.11 series standard, such as 110A of FIG. 5, or the MAC header of the conventional IEEE 802.15.3 standard, such as 110B of FIG. 5.

페이로드 영역은 MPDU ID 필드(120)와, Bitmap 필드(130)와, Pad 필드(140)를 포함하여 구성될 수 있다. MPDU ID 필드(120)는 ACK 응답을 할 대상이 되는 프레임(이하 '대상 프레임'이라고 정의함) 중 첫번째 프레임의 식별 정보가 기록되는 데, 이는 다시 MSDU number 필드(121)와, Fragment number 필드(122)로 나뉘어 질 수 있다. 본 발명에 따른 버스트 ACK 프레임(100)은 수신된 프레임뿐만 아니라 수신되지 않은 프레임을 포함한 전체 전송 프레임에 수신 여부를 응답하므로, 상기 대상 프레임이란 일정 기간내의 전체 전송 프레임(ACK을 요하는 전송 프레임에 한정됨)을 의미하는 것이다. The payload region may include an MPDU ID field 120, a Bitmap field 130, and a pad field 140. In the MPDU ID field 120, identification information of the first frame of a frame (hereinafter, referred to as a 'target frame') to which an ACK response is to be recorded is recorded, which is again referred to as an MSDU number field 121 and a fragment number field ( 122). Since the burst ACK frame 100 according to the present invention responds to not only the received frame but also the entire transmission frame including the unreceived frame, the burst frame corresponds to the entire transmission frame (transmission frame requiring ACK) within a predetermined period. Limited).

MSDU number 필드(121)에는 대상 프레임 중 첫번째 프레임의 MSDU number가 기록되며, Fragment number 필드(122)에는 대상 프레임 중 첫번째 프레임의 Fragment number가 기록된다. MSDU number와, Fragment number는 수신되는 대상 프레임의 MAC 헤더를 살펴 보면 알 수 있다.The MSDU number field 121 records the MSDU number of the first frame of the target frame, and the Fragment number field 122 records the Fragment number of the first frame of the target frame. The MSDU number and the fragment number can be known by looking at the MAC header of the received target frame.

Bitmap 필드(130)에는 대상 프레임에 대한 ACK 비트와 Type 비트의 쌍(이하 비트쌍 이라고 함)이 순서대로 기록되는데, 상기 비트 쌍의 개수(m)는 최소인 경우 총 MSDU의 개수와 같고, 최대인 경우 총 프래그먼트의 개수와 같다.In the bitmap field 130, a pair of ACK bits and a type bit (hereinafter referred to as a bit pair) for a target frame are sequentially recorded. The number of bit pairs (m) is the same as the total number of MSDUs when the minimum is m, and the maximum If is equal to the total number of fragments.

주지하는 바와 같이, 대상 프레임은 프래그멘테이션이 이루어지지 않은 경우에는 하나의 MSDU로 이루어지고, 프래그멘테이션이 이루어진 경우에는 MSDU 중 일부 프래그먼트로 이루어질 수 있다. As will be appreciated, the target frame may be composed of one MSDU when the fragmentation is not performed, and some fragments of the MSDU when the fragmentation is performed.

Bitmap 필드(130) 중에서 ACK 비트에는 해당 프레임이 정상적으로 수신되었는가를 확인하는 비트가 기록되는데, 정상적으로 수신된 경우에는 1로, 그렇지 않은 경우에는 0으로 기록될 수 있다. 그리고, Type 비트에는 상기 ACK 비트가 해당 프레임(MSDU 또는 프래그먼트)에 대한 수신 확인을 나타내는 것인가(전자), MSDU 내에서 현재 프래그먼트 이후의 모든 프래그먼트에 대한 수신 확인을 나타내는 것 인가(후자)를 구별하는 비트 정보가 기록된다. Type 비트는 전자의 경우 0으로, 후자의 경우 1로 기록될 수 있다. In the bitmap field 130, a bit for confirming whether a corresponding frame is normally received is recorded in the ACK bit, and may be recorded as 1 if normally received or 0 otherwise. In addition, the Type bit distinguishes whether the ACK bit indicates an acknowledgment for the corresponding frame (MSDU or fragment) (e) or whether the latter indicates an acknowledgment for all fragments after the current fragment in the MSDU (the latter). Bit information is recorded. The Type bit may be written as 0 in the former and 1 in the latter.

Pad 필드(140)는 가변 비트로서 모두 더미 비트(예: 0)로 채워진다. 이 필드(140)는, Bitmap 필드(130)가 비트 단위이므로 소정 개수의 더미 비트(dummy bits), 예를 들어, 소정 개수의 0을 채워 바이트 내지 옥텟(octet) 단위로 만들기 위해서 사용된다. 따라서 Bitmap 필드(130)와 Pad 필드(140)의 크기를 합하면 항상 바이트 단위가 될 것이다. 그러나, Pad 필드(140)는 본 발명에 따른 프로토콜을 정의하기 위한 필수 항목은 아니므로 생략될 수도 있다.The pad field 140 is a variable bit and filled with dummy bits (eg, 0). Since the Bitmap field 130 is a bit unit, this field 140 is used to fill a predetermined number of dummy bits, for example, a predetermined number of zeros into byte to octet units. Therefore, the sum of the sizes of the Bitmap field 130 and the Pad field 140 will always be in bytes. However, since the pad field 140 is not an essential item for defining a protocol according to the present invention, the pad field 140 may be omitted.

이하, 도 6 내지 도 10은 여러 가지 실시예에 따라서 버스트 ACK 프레임(100)이 어떻게 결정되는가를 설명하기 위한 도면들이다. 여기서, [A:B]는 프레임을 식별하는 표시로서, A는 송신 디바이스가 전송한 MSDU number에 부여한 순번(이하 MSDU 순번이라 함)을, B는 Fragment number(0부터 시작)를 의미하는 것으로 한다. 예를 들어서, 송신 디바이스가 MSDU number가 1234에서 1237인 프레임을 전송하였다면, 각각 순서대로 1에서 4까지 MSDU 순번이 부여되는 것이다. 이러한 MSDU 순번은 송신 디바이스가 전송한 MSDU number를 기준으로 하는 것이지, 수신 디바이스가 수신하여 저장한 MSDU number를 기준으로 하는 것은 아니다. 만약, 송신 디바이스는 MSDU number가 1234에서 1237인 프레임을 전송하였지만, 수신 디바이스는 1235, 및 1237인 프레임만을 수신하였더라도, MSDU 순번은 1234에서 1237까지 전체에 대하여 순차적으로 부여된다.6 to 10 are diagrams for describing how the burst ACK frame 100 is determined according to various embodiments. Here, [A: B] is an indication for identifying a frame, where A is a sequence number (hereinafter referred to as MSDU sequence number) assigned to an MSDU number transmitted by a transmitting device, and B is a fragment number (starting from 0). . For example, if the transmitting device transmits a frame whose MSDU number is 1234 to 1237, the MSDU sequence number is assigned from 1 to 4, respectively. The MSDU sequence number is based on the MSDU number transmitted by the transmitting device, and not based on the MSDU number received and stored by the receiving device. If the transmitting device transmits a frame whose MSDU number is 1234 to 1237, but the receiving device receives only frames 1235 and 1237, the MSDU number is sequentially assigned to all of 1234 to 1237.

도 6은 [1:0], [2:0], [3:0], [4:0]를 모두 정상적으로 수신한 경우에 버스 트 ACK 프레임(100)의 구조를 나타낸 것으로 프래그멘테이션(fragmentation)이 전혀 일어 나지 않은 경우이다. MPDU ID 필드(120)에는 [1:0]의 MSDU number(=1) 및 Fragment number(=0)가 기록된다. 그리고, Bitmap 필드(130)에는 대상 프레임에 대한 ACK 비트와 Type 비트로 이루어진 비트쌍이 순서대로 기록된다. 그런데, Bitmap 필드(130) 만으로 바이트 단위가 되므로, 별도의 Pad 필드는 필요 없다. 여기서 순서라 함은 MSDU number 및 Fragment number에 따른 순서이지, 프레임을 수신한 순서가 아님을 명확히 밝혀 둔다. 왜냐하면, 먼저 전송한 프레임이 어떠한 이유로 나중에 수신될 수도 있기 때문이다. 6 illustrates the structure of a burst ACK frame 100 when all of [1: 0], [2: 0], [3: 0], and [4: 0] are normally received. fragmentation) does not occur at all. In the MPDU ID field 120, an MSDU number (= 1) and a fragment number (= 0) of [1: 0] are recorded. In the bitmap field 130, bit pairs consisting of ACK bits and Type bits for the target frame are sequentially recorded. However, since only the Bitmap field 130 is in a byte unit, a separate pad field is not necessary. In this case, the order refers to the order according to the MSDU number and the fragment number, not to the order in which the frames are received. This is because the first transmitted frame may be received later for some reason.

[1:0], [2:0], [3:0], [4:0]는 모두 정상적으로 수신되었으므로 비트쌍의 첫번째 비트는 1로 채워진다. 두번째 비트쌍(X로 표시됨)은 0 또는 1 중 어떤 값으로 채워도 상관이 없다. 그 프레임에서 해당 MSDU가 완결되기 때문에 1로 표시할 수도 있는 것이고 한편, 하나의 프레임에 대한 ACK 여부 표시이기도 하기 때문에 0으로 표시할 수도 있는 것이기 때문이다. 더욱이, 어떠한 MSDU가 프래그멘테이션 되었는가는 송신 디바이스와 수신 디바이스가 그에 관한 정보를 공유함으로써 서로 알고 있기 때문에 혼동을 유발할 가능성은 없다. 하지만, 일단 하나의 MSDU에서 완결되었다는 의미를 명확히 하는 측면에서 1로 채우는 것이 보다 바람직할 것이다. 이하 X는 본 실시예에서와 같은 의미로 해석된다.Since [1: 0], [2: 0], [3: 0], and [4: 0] were all received normally, the first bit of the bit pair is filled with one. The second pair of bits (indicated by X) can be filled with either zero or one. This is because the corresponding MSDU is completed in the frame, and may be marked as 1, while it may also be indicated as 0 because it is an indication of whether an ACK is received for one frame. Moreover, there is no possibility of confusion because which MSDU is fragmented because the sending device and the receiving device know each other by sharing information about it. However, it would be more desirable to fill in 1 in terms of clarifying the meaning of completion in one MSDU. X is interpreted as having the same meaning as in the present embodiment.

도 7은 [1:0], [2:0], [2:1], [3:0], [4:0]를 모두 정상적으로 수신한 경우에 버스트 ACK 프레임(100)의 구조를 나타낸 것으로 두번째 MSDU에서 프래그멘테이션(fragmentation)이 일어난 경우이다. 도 6에서와 마찬가지로 MPDU ID 필드(120) 에는 [1:0]의 MSDU number(=1) 및 Fragment number(=0)가 기록된다. 그리고, Bitmap 필드(130)에는 대상 프레임에 대한 ACK 비트와 Type 비트로 이루어진 비트쌍이 순서대로 기록된다. 7 shows the structure of a burst ACK frame 100 when all of [1: 0], [2: 0], [2: 1], [3: 0], and [4: 0] are normally received. This is the case where fragmentation occurs in the second MSDU. As in FIG. 6, the MSDU number (= 1) and the fragment number (= 0) of [1: 0] are recorded in the MPDU ID field 120. In the bitmap field 130, bit pairs consisting of ACK bits and Type bits for the target frame are sequentially recorded.

[1:0], [2:0], [2:1], [3:0], [4:0]는 모두 정상적으로 수신되었으므로 비트쌍의 첫번째 비트는 1로 채워지며, 이 중 [1:0], [3:0], [4:0]는 완결된 프레임이므로 두번째 비트는 X로 채워진다. 다만, [2:0] 이후에 같은 MSDU number 및 다른 Fragment number를 갖는 [2:1]이 존재하므로, [2:0]에 대한 비트쌍 중 두번째 비트는 1로 표시하여 [2:0] 이후의 모두 프래그먼트가 정상적으로 수신됨을 표시한다.Since [1: 0], [2: 0], [2: 1], [3: 0], and [4: 0] were all received successfully, the first bit of the bit pair is filled with 1, of which [1: 0], [3: 0], and [4: 0] are complete frames, so the second bit is filled with X. However, since [2: 1] with the same MSDU number and different Fragment number exists after [2: 0], the second bit of the pair of bits for [2: 0] is represented by 1 and after [2: 0] All of the fragments indicate that the fragment is received normally.

이와 같이 프래그먼트로 된 MSDU에 대하여 한꺼번에 표시하는 것이 바람직하지만, 동일한 상황에서 버스트 ACK 프레임(100)을 도 8과 같이 MSDU가 프래그먼트로 된 경우에는 각 프래그먼트 별로 표시하는 방법도 생각할 수 있다.It is preferable to display the fragmented MSDUs at once, but in the same situation, when the MSDU is fragmented as shown in FIG. 8, a method of displaying the fragments for each fragment can also be considered.

도 9는 송신 디바이스가 [1:0], [2:0], [2:1], [2:2], [3:0]를 전송하였지만, 수신 디바이스에서는 [1:0], [2:0], [3:0] 만을 정상적으로 수신한 경우에 버스트 ACK 프레임(100)의 구조를 나타낸 것이다. 여기서, 두번째 MSDU는 3개의 프래그먼트로 나뉘어졌음을 알 수 있다. MPDU ID 필드(120)에는 [1:0]의 MSDU number(=1) 및 Fragment number(=0)가 기록된다. 그리고, Bitmap 필드(130)에는 송신 디바이스가 전송한 모든 대상 프레임에 대하여 ACK 비트와 Type 비트로 이루어진 비트쌍이 순서대로 기록된다. 9 shows that the transmitting device has transmitted [1: 0], [2: 0], [2: 1], [2: 2], and [3: 0], but the receiving device has [1: 0], [2] The structure of the burst ACK frame 100 is shown when only: 0] and [3: 0] are normally received. Here, it can be seen that the second MSDU is divided into three fragments. In the MPDU ID field 120, an MSDU number (= 1) and a fragment number (= 0) of [1: 0] are recorded. In the bitmap field 130, bit pairs consisting of ACK bits and Type bits are sequentially recorded for all target frames transmitted by the transmitting device.

[1:0], [3:0]는 모두 정상적으로 수신되었으므로 비트쌍의 첫번째 비트는 1로 채워지며, 완결된 프레임이므로 두번째 비트는 X로 채워진다. 그런데, [2:0]은 정상적으로 수신되었지만 그 후의 프래그먼트가 존재하므로 해당 프레임, 즉 해당 프래그먼트에 대한 수신 확인만을 하기 위하여 해당 위치에 '10' 이 기록된다. 그러나 [2:1] 및 [2:2]는 정상적으로 수신되지 못하였으므로 이 두 프레임을 대표하여 [2:1]의 위치에 해당하는 비트쌍의 첫번째 비트는 0으로 표시된다. 그리고, 두번째 비트는 1로서 표시되는데, 이는 첫번째 비트가 해당 위치 이후 즉, [2:1] 및 [2:2]에 대한 ACK 비트임을 의미한다.Since [1: 0] and [3: 0] are all received normally, the first bit of the bit pair is filled with 1, and the second bit is filled with X because it is a complete frame. However, [2: 0] is normally received, but since there is a fragment thereafter, '10' is recorded in the corresponding position only for acknowledgment of the corresponding frame, that is, the fragment. However, since [2: 1] and [2: 2] were not normally received, the first bit of the bit pair corresponding to the position of [2: 1] is represented by 0 representing these two frames. And, the second bit is indicated as 1, which means that the first bit is the ACK bit after the corresponding position, that is, for [2: 1] and [2: 2].

그런데, 수신 디바이스가 [2:0] 만을 수신하였는데, [2:1] 및 [2:2]가 존재하는지 여부를 어떻게 알 수 있는가가 문제된다. 그러나, 이는 [2:0]의 MAC 헤더를 살펴보면 알 수 있다. 이에 대한 보다 자세한 설명은 도 13 및 도 14의 설명에서 후술하기로 한다.By the way, when the receiving device receives only [2: 0], it is a problem how to know whether [2: 1] and [2: 2] exist. However, this can be seen by looking at the MAC header of [2: 0]. A more detailed description thereof will be described later with reference to FIGS. 13 and 14.

도 10은 송신 디바이스가 [1:0], [2:0], [2:1], [2:2], [3:0]를 전송하였지만, 수신 디바이스에서는 [1:0], [3:0] 만을 정상적으로 수신한 경우에 버스트 ACK 프레임(100)의 구조를 나타낸 것이다. 여기서, 수신 디바이스는 두번째 MSDU에 관한 데이터를 하나도 수신하지 못하였으므로 그것이 3개의 프래그먼트로 이루어져 있음을 알 수는 없다. 하지만, [1:0], 및 [3:0]을 수신하였으므로 2번째 MSDU에 대한 프레임이 전송되지 않았다는 것은 알 수가 있다.10 shows that the transmitting device has transmitted [1: 0], [2: 0], [2: 1], [2: 2], and [3: 0], but the receiving device has [1: 0], [3]. : 0] shows the structure of the burst ACK frame 100 when normally received only. Here, since the receiving device has not received any data regarding the second MSDU, it cannot be known that it is composed of three fragments. However, since [1: 0] and [3: 0] were received, it can be seen that the frame for the second MSDU was not transmitted.

MPDU ID 필드(120)에는 [1:0]의 MSDU number(=1) 및 Fragment number(=0)가 기록된다. 그리고, Bitmap 필드(130)에는 송신 디바이스가 전송한 모든 대상 프레임에 대하여 ACK 비트와 Type 비트로 이루어진 비트쌍이 순서대로 기록된다. In the MPDU ID field 120, an MSDU number (= 1) and a fragment number (= 0) of [1: 0] are recorded. In the bitmap field 130, bit pairs consisting of ACK bits and Type bits are sequentially recorded for all target frames transmitted by the transmitting device.

[1:0], [3:0]는 모두 정상적으로 수신되었으므로 비트쌍의 첫번째 비트는 1 로 채워지며, 완결된 프레임이므로 두번째 비트는 X로 채워진다. 그런데, MSDU가 1인 프레임과 3인 프레임이 수신된 것을 보면 MSDU가 2인 프레임도 전송되었지만 에러로 인하여 수신되지 못하였음을 알 수 있다. 이와 같이, 두번째 MSDU에 대한 프레임은 전혀 수신하지 못하였지만, [2:0]의 위치에 첫번째 비트를 0으로 채우고, 두번째 비트를 1로 채움으로써, [2:0] 이후의 모든 프래그먼트는 수신되지 못하였음을 표시할 수 있는 것이다.Since [1: 0] and [3: 0] are all received normally, the first bit of the bit pair is filled with 1, and the second bit is filled with X because it is a complete frame. However, when the frame having the MSDU of 1 and the frame of the 3 are received, it can be seen that the frame having the MSDU of 2 was also transmitted but was not received due to an error. As such, the frame for the second MSDU was not received at all, but by filling the first bit with 0 at the position of [2: 0] and the second bit with 1, all fragments after [2: 0] are not received. It can indicate that it was not.

도 11은 이상의 같은 버스트 ACK 프레임(100)을 전송하는, 본 발명의 일 실시예에 따른 무선 디바이스(200)의 구성을 나타낸 블록도이다. 무선 디바이스(200)는 버스트 ACK 생성 모듈(210)과, MAC 모듈(220)과, 상위층 모듈(230)과, PHY 모듈(240)과, 메모리(250)와, 제어 유닛(260)를 포함하여 구성될 수 있다.11 is a block diagram illustrating a configuration of a wireless device 200 according to an embodiment of the present invention, which transmits the same burst ACK frame 100. The wireless device 200 includes a burst ACK generation module 210, a MAC module 220, a higher layer module 230, a PHY module 240, a memory 250, and a control unit 260. Can be configured.

버스트 ACK 생성 모듈(210)은, 수신되는 데이터 프레임의 헤더 정보로부터 해당 프레임의 식별 정보로서, MPDU ID 정보를 판독하고 이 정보를 이용하여 본 발명에 따른 버스트 ACK 프레임(100)의 페이로드(payload)를 생성한다. 버스트 ACK 생성 모듈(210)은 다시 도 12와 같은 세부 구조를 갖는다. 즉 버스트 ACK 생성 모듈(210)은 생성 제어 모듈(211)과, MPDU ID 생성 모듈(212)과, 비트맵 생성 모듈(213)과, 패드 생성 모듈(214)을 포함하여 구성될 수 있다.The burst ACK generation module 210 reads MPDU ID information as identification information of the frame from the header information of the received data frame and uses the information to payload the burst ACK frame 100 according to the present invention. ) The burst ACK generation module 210 has a detailed structure as shown in FIG. 12 again. That is, the burst ACK generation module 210 may include a generation control module 211, an MPDU ID generation module 212, a bitmap generation module 213, and a pad generation module 214.

생성 제어 모듈(211)은 특정 송신 디바이스로부터 수신된 소정 개수의 프레임에 대한 버스트 ACK 프레임(100)을 생성하기 위한 조건(이하 'ACK 생성 조건'이라 함)을 체크하여, 조건이 완성되지 않은 동안에는 상기 특정 송신 디바이스로부터 수신되는 프레임의 MAC 헤더에 포함되는 MPDU ID 정보를 MAC 모듈(220)로부터 수신하여 메모리(250)에 저장하여 둔다. 그리고, 조건이 완성되면 MPDU ID 생성 모듈(212), 비트맵 생성 모듈(213), 및 패드 생성 모듈(214)로 하여금 상기 저장된 MPDU ID 정보를 이용하여 버스트 ACK 프레임(100)의 페이로드를 생성하도록 한다. The generation control module 211 checks a condition for generating a burst ACK frame 100 for a predetermined number of frames received from a specific transmitting device (hereinafter referred to as an 'ACK generation condition'). The MPDU ID information included in the MAC header of the frame received from the specific transmitting device is received from the MAC module 220 and stored in the memory 250. When the condition is completed, the MPDU ID generation module 212, the bitmap generation module 213, and the pad generation module 214 generate the payload of the burst ACK frame 100 using the stored MPDU ID information. Do it.

여기서, MPDU ID 정보는, 수신된 프레임의 MSDU에 대한 고유 일련 번호를 나타내는 'MSDU number'와 프래그먼트로 된 순서를 나타내는 'Fragment number'를 포함한다. MPDU ID 정보는 도 13과 같은 IEEE 802.11 계열 표준에 따른 MAC Header(110A)에도 나타나 있고, 도 14과 같은 IEEE 802.15.3 표준에 따른 MAC Header(110B)에도 나타나 있다. Here, the MPDU ID information includes 'MSDU number' indicating a unique serial number for the MSDU of the received frame and 'Fragment number' indicating the order of fragments. The MPDU ID information is also shown in the MAC Header 110A according to the IEEE 802.11 series standard as shown in FIG. 13 and also in the MAC Header 110B according to the IEEE 802.15.3 standard as shown in FIG.

도 13의 MAC Header(110A)에서 Sequence Control 필드(112)는 Fragment Number 필드(114)와, Sequence Number 필드(115)로 나뉘어지는데, Fragment Number 필드(114)에는 'Fragment Number'가 기록되고, Sequence Number 필드(115)에는 'MSDU Number'가 기록된다. 따라서, Sequence Control 필드(112)를 읽음으로써 MSDU ID 정보를 알 수 있다. In the MAC Header 110A of FIG. 13, the Sequence Control field 112 is divided into a Fragment Number field 114 and a Sequence Number field 115. In the Fragment Number field 114, a 'Fragment Number' is recorded. 'MSDU Number' is recorded in the Number field 115. Therefore, the MSDU ID information can be known by reading the Sequence Control field 112.

한편, Frame Control 필드(111)에는 More Frag 비트(113)가 포함되는데, 여기에는 현재 프레임이 마지막 프래그먼트인지 여부를 알려주는 비트 정보가 기록된다. 만약, 비트가 1이면 이후의 프래그먼트가 더 존재한다는 의미이고, 비트가 0이면 현재 프레임이 마지막 프래그먼트라는 의미이다. 도 9와 같은 경우에 [2:0] 만을 수신하고, 전체 프래그먼트가 3개 임을 알 수는 없지만, [2:0]가 최종 프래그먼트가 아니라는 것은 알 수가 있게 된다.The Frame Control field 111 includes a More Frag bit 113, in which bit information indicating whether the current frame is the last fragment is recorded. If the bit is 1, the later fragment is present. If the bit is 0, the current frame is the last fragment. In the case of FIG. 9, only [2: 0] is received and it is not known that the entire fragment is three, but it can be seen that [2: 0] is not the final fragment.

도 14의 MAC Header(110B)에서 Fragmentation Control 필드(112)는 MSDU number 필드(117)와, Fragment number 필드(118)와, Last fragment number 필드(119)로 나뉘어진다. 따라서, Fragmentation Control 필드(112)를 읽음으로써 MSDU ID 정보를 알 수 있다. 다만, 도 12와는 달리 프래그먼트로 된 모든 프레임에는 Last fragment number 필드(119)에 마지막 프래그먼트의 번호가 기록되므로, 도 9와 같은 경우에 [2:0] 만을 수신하여도 [2:1] 및 [2:2]가 존재함을 알 수 있는 것이다.In the MAC Header 110B of FIG. 14, the Fragmentation Control field 112 is divided into an MSDU number field 117, a Fragment number field 118, and a Last fragment number field 119. Therefore, the MSDU ID information can be known by reading the Fragmentation Control field 112. Unlike in FIG. 12, however, since the last fragment number is recorded in the last fragment number field 119 in every frame composed of fragments, even when only [2: 0] is received in the case of FIG. 9, [2: 1] and [ 2: 2].

다시 도 12로 돌아가서, 생성 제어 모듈(211)이 체크하는 조건은, 송신 디바이스가 수신 디바이스에게 대상 프레임을 전송할 때, MAC 헤더 중 버스트 ACK 프레임 요청하는 일부 비트(이하 ' 요청 비트'라 함)가 ON으로 되어 있는지 여부를 기준으로 할 수 있다. 즉, 대상 프레임을 수신할 때마다 해당 프레임의 '요청 비트'의 값을 판독하여, 그 값이 OFF을 나타내는 비트(=0)이면 ACK 생성 조건이 성취되지 않은 것으로, 그 값이 ON을 나타내는 비트(=1)이면 ACK 생성 조건이 성취된 것으로 판단하는 것이다. 12 again, the condition that the generation control module 211 checks is that, when the transmitting device transmits the target frame to the receiving device, some bits (hereinafter, referred to as 'request bits') in the MAC header requesting a burst ACK frame. It can be based on whether it is ON. That is, each time the target frame is received, the value of the 'request bit' of the frame is read, and if the value is a bit indicating OFF (= 0), the ACK generation condition is not achieved, and the bit indicating the value is ON. If (= 1), it is determined that the ACK generation condition has been achieved.

만약 송신 디바이스가 [1:0], [2:0], [3:0]을 전송하고, [3:0]에 요청 비트가 ON으로 설정된 경우에, 수신 디바이스가 [1:0], [2:0] 만을 수신하였다면, 수신 디바이스는 ACK 생성 조건이 성취되지 않았으므로 버스트 ACK 프레임을 생성하지 않을 것이다. 그 후 송신 디바이스는 일정 시간 내에 버스트 ACK 프레임이 수신되지 않으면 전송 에러가 있는 것으로 보고 다시 요청 비트를 ON으로 설정하여 [3:0]을 전송할 것이다.If the sending device sends [1: 0], [2: 0], [3: 0], and the request bit is set to ON in [3: 0], the receiving device is set to [1: 0], [ 2: 0], the receiving device will not generate a burst ACK frame since the ACK generation condition has not been achieved. The transmitting device will then consider that there is a transmission error if a burst ACK frame is not received within a certain time period and send [3: 0] again with the request bit set to ON.

이상에서는 ACK 생성 조건을 송신 디바이스가 결정하는 것으로 하였지만, 이 에 한하지 않고 일정 개수 이상의 대상 프레임이 수신되면 ACK 생성 조건이 만족되는 것으로 하는 방법도 가능하다.In the above description, the ACK generation condition is determined by the transmitting device. However, the ACK generation condition may be satisfied when the number of target frames is received.

MPDU ID 생성 모듈(212)은 메모리(250)에 저장된 MSDU ID 정보를 이용하여, MPDU ID 필드(120), 즉 대상 프레임 중 최초 프레임의 MSDU number 필드(121)와, 대상 프레임 중 최초 프레임의 fragment number 필드(122)를 기록한다. The MPDU ID generation module 212 uses the MSDU ID information stored in the memory 250 to determine the MPDU ID field 120, that is, the MSDU number field 121 of the first frame of the target frame, and the fragment of the first frame of the target frame. Record the number field 122.

비트맵 생성 모듈(213)은 상기 MPDU ID 필드(120)에 덧붙여 대상 프레임에 대한 비트쌍을 순차적으로 기록한다. 첫번째 비트(ACK 비트)에는 현재 비트쌍이 나타내는 프레임이 정상적으로 수신되었는가(정상적으로 수신되면 1, 아니면 0)를 확인하는 비트가 기록되고, 두번째 비트(Type 비트)에는 상기 첫번째 비트가 해당 프레임에 대한 수신 확인을 나타내는 것(0으로 기록)인가, 한 MSDU 내에서 현재 프래그먼트 이후의 모든 프래그먼트에 대한 수신 확인을 나타내는 것(1로 기록)인가를 구별하는 비트 정보가 기록된다.The bitmap generation module 213 sequentially records the bit pairs for the target frame in addition to the MPDU ID field 120. In the first bit (ACK bit), a bit to check whether the frame indicated by the current pair of bits is normally received (1, or 0 if it is normally received) is recorded.In the second bit (Type bit), the first bit is acknowledged for the corresponding frame. Bit information is discriminated whether to indicate (recording as 0) or indicating acknowledgment (recording as 1) for all fragments after the current fragment in one MSDU.

패드 생성 모듈(214)은 비트맵의 크기가 바이트 단위로 되지 않는 경우에 나머지 비트를 0으로 채워 바이트 단위가 되도록 한다.The pad generation module 214 fills the remaining bits with zeros to make the byte unit when the size of the bitmap does not become the byte unit.

다시 도 11을 참조하면, MAC 모듈(220)은 MAC 층(Media Access Control Layer)에서의 동작을 관장한다. 즉, 상위층 모듈(230)로부터 MSDU를 전달받아 여기에 도 13 또는 도 14와 같은 MAC 헤더를 부착하고 그 결과를 PHY 모듈(240)에 전달한다. 또한, MAC 모듈(220)은 버스트 ACK 생성 모듈(210)로부터 버스트 ACK 프레임의 페이로드를 전달받고, 마찬가지로 여기에 MAC 헤더를 부착하여 PHY 모듈(240)에 전달한다. Referring back to FIG. 11, the MAC module 220 manages the operation in the MAC layer. That is, the MSDU is received from the upper layer module 230 and the MAC header of FIG. 13 or 14 is attached thereto, and the result is transmitted to the PHY module 240. In addition, the MAC module 220 receives the payload of the burst ACK frame from the burst ACK generation module 210, and similarly attaches the MAC header to the PHY module 240.

또한, PHY 모듈(240)로부터 다른 디바이스로부터 전송된 프레임을 수신하면 여기서 MAC 헤더를 판독한 후 MAC 헤더를 제거하고 그 결과를 상위층 모듈(230)에 전달한다. 그리고, MAC 헤더 중 판독되는 MPDU ID 정보를 버스트 ACK 생성 모듈(210)에 전달한다.In addition, when receiving a frame transmitted from another device from the PHY module 240, the MAC header is read here, the MAC header is removed, and the result is transmitted to the upper layer module 230. The MPDU ID information read from the MAC header is transmitted to the burst ACK generation module 210.

상위층 모듈(230)은 MSDU를 생성하여 MAC 모듈(220)에 전달하고, MAC 모듈(220)로부터 MAC 헤더가 제거된 데이터를 전달받는다. 이러한 상위층 모듈(230)은 LLC 층(Logical Link Layer) 이상의 네트워크 층을 관장한다.The higher layer module 230 generates an MSDU and delivers the MSDU to the MAC module 220, and receives data from which the MAC header is removed from the MAC module 220. The upper layer module 230 manages a network layer above the LLC layer (Logical Link Layer).

PHY 모듈(240)은 물리층(Physical Layer)에서의 동작을 관장한다. 즉, MAC 모듈(220)로부터 MPDU(MAC Protocol Data Unit)를 전달받아 PPDU(PACKet Protocol Data Unit)를 생성하고 이를 포함하는 무선 신호를 생성하여 전송한다. 또한, 무선 매체를 통하여 전달되는 신호를 수신하여 가공한 후 이를 MAC 모듈(220)에 전달한다. PHY 모듈(240)은 다시 세분화하여 베이스밴드 프로세서(base band processor)와 RF(radio frequency) 모듈로 세분화 될 수 있다.The PHY module 240 manages the operation in the physical layer. That is, the MAC module 220 receives the MPDU (MAC Protocol Data Unit) from the MAC module 220 to generate a PPDU (Packet Protocol Data Unit), and generates and transmits a radio signal including the same. In addition, after receiving and processing the signal transmitted through the wireless medium and delivers it to the MAC module 220. The PHY module 240 may be further subdivided into a base band processor and a radio frequency (RF) module.

메모리(250)는 수신된 프레임에 대한 MPDU ID 정보를 저장하였다가 버스트 ACK 생성 모듈(210)의 요청이 있으면 이 정보를 제공한다.The memory 250 stores the MPDU ID information for the received frame and provides this information when requested by the burst ACK generation module 210.

제어 유닛(260)은 무선 디바이스(100) 내의 다른 모듈의 동작을 제어하는데, 중앙 처리 유닛(CPU), 마이콤(Microcomputer) 등으로 구현될 수 있다.The control unit 260 controls the operation of other modules in the wireless device 100, which may be implemented as a central processing unit (CPU), a microcomputer, or the like.

지금까지의 설명에서, "모듈(module)"이라는 용어는 소프트웨어 구성요소(software component) 또는 FPGA(field-programmable gate array) 또는 ASIC(application-specific integrated circuit)과 같은 하드웨어 구성요소 (hardware component)를 의미하며, 모듈은 어떤 역할들을 수행한다.  그렇지만 모듈은 소프트웨어 또는 하드웨어에 한정되는 의미는 아니다.  모듈은 어드레싱(addressing)할 수 있는 저장 매체에 있도록 구성될 수도 있고 하나 또는 그 이상의 프로세서들을 실행시키도록 구성될 수도 있다.  따라서, 일 예로서 모듈은 소프트웨어 구성요소들, 객체지향 소프트웨어 구성요소들, 클래스(class) 구성요소들 및 태스크(task) 구성요소들과 같은 구성요소들과, 프로세스들(processes), 함수들(functions), 속성들(properties), 프로시저들(procedures), 서브루틴들(sub-routines), 프로그램 코드(program code)의 세그먼트들(segments), 드라이버들(drivers), 펌웨어(firmwares), 마이크로코드(micro-codes), 회로(circuits), 데이터(data), 데이터베이스(databases), 데이터 구조들(data structures), 테이블들(tables), 어레이들(arrays), 및 변수들(variables)을 포함한다.  구성요소들과 모듈들 안에서 제공되는 기능은 더 작은 수의 구성요소들 및 모듈들로 결합되거나 추가적인 구성요소들과 모듈들로 더 분리될 수 있다.  뿐만 아니라, 구성요소들 및 모듈들은 통신 시스템 내의 하나 또는 그 이상의 컴퓨터들을 실행시키도록 구현될 수도 있다.In the description so far, the term "module" refers to a software component or a hardware component such as a field-programmable gate array (FPGA) or an application-specific integrated circuit (ASIC). Means a module plays some role. However, modules are not meant to be limited to software or hardware. The module may be configured to be in an addressable storage medium and may be configured to execute one or more processors. Thus, as an example, a module may include components such as software components, object-oriented software components, class components, and task components, processes, functions, and the like. functions, properties, procedures, sub-routines, segments of program code, drivers, firmwares, microcomputers Includes micro-codes, circuits, data, databases, data structures, tables, arrays, and variables do. The functionality provided within the components and modules may be combined into a smaller number of components and modules or further separated into additional components and modules. In addition, the components and modules may be implemented to execute one or more computers in a communication system.

도 15는 본 발명의 일 실시예에 따른 버스트 ACK 프레임(100) 생성 과정을 나타낸 흐름도이다.15 is a flowchart illustrating a process of generating a burst ACK frame 100 according to an embodiment of the present invention.

먼저, ACK 생성 조건이 완성되기 전까지(S20의 아니오), PHY 모듈(240)을 통하여 '대상 프레임'을 수신하고(S10), 생성 제어 모듈은 상기 수신되는 대상 프레임의 MPDU ID 정보를 저장하는 과정(S25)을 반복한다. MPDU ID 정보에는 해당 대상 프레임의 MSDU number 및 Fragment number가 포함한다. First, until the ACK generation condition is completed (NO in S20), a 'target frame' is received through the PHY module 240 (S10), and the generation control module stores MPDU ID information of the received target frame. Repeat (S25). The MPDU ID information includes the MSDU number and the fragment number of the corresponding target frame.

만약, 생성 제어 모듈(211)은 ACK 생성 조건이 완성되었는지를 판단하여 완성되면(S20의 예), 비로소 버스트 ACK 프레임(100)의 페이로드를 생성하도록 제어하게 된다. 상기 페이로드를 생성하는 과정은 S30 내지 S69 단계에서 이루어진다.If the generation control module 211 determines whether the ACK generation condition is completed (Yes in S20), the generation control module 211 controls to generate the payload of the burst ACK frame 100. The process of generating the payload is performed in steps S30 to S69.

먼저, MPDU ID 생성 모듈(212)은 메모리(250)에 저장된 대상 프레임 중 최초 프레임의 MSDU number 필드(121)와 fragment number 필드(122)를 기록함으로써 MPDU ID 필드(120)를 생성한다(S40).First, the MPDU ID generation module 212 generates the MPDU ID field 120 by recording the MSDU number field 121 and the fragment number field 122 of the first frame among the target frames stored in the memory 250 (S40). .

비트맵 생성 모듈(213)은 상기 MPDU ID 필드(120)에 덧붙여 대상 프레임에 대한 비트쌍을 순차적으로 기록함으로써 Bitmap 필드(130)를 생성한다(S50). S50 단계에 대한 보다 자세한 과정은 도 16의 설명에서 후술하기로 한다.The bitmap generation module 213 generates the bitmap field 130 by sequentially recording the bit pairs for the target frame in addition to the MPDU ID field 120 (S50). A more detailed process for step S50 will be described later in the description of FIG. 16.

상기 생성된 Bitmap 필드(130)의 크기가 바이트 단위인 경우에는(S68의 예), Pad 필드(140)를 생성할 필요가 없지만, 그렇지 않은 경우에는 소정의 비트의 연속된 0 값을 갖는 Pad 필드(140)을 상기 Bitmap 필드(130)에 연속하여 덧붙인다. 상기 연속된 0 값을 갖는 비트 수는 Bitmap 필드(130)와 Pad 필드(140)를 합하여 바이트 단위가 되도록 하는 개수이다.If the size of the generated Bitmap field 130 is in units of bytes (YES in S68), it is not necessary to generate the Pad field 140, but otherwise, a Pad field having a continuous 0 value of a predetermined bit 140 is successively added to the Bitmap field 130. The number of bits having the consecutive zero values is the number of the bitmap field 130 and the pad field 140 to be in a byte unit.

MAC 모듈(120)은 S50 또는 S69에서 생성된 버스트 ACK 프레임(100)의 페이로드에 MAC 헤더를 부착하여 버스트 ACK 프레임(100)을 생성한다(S70). 그리고, PHY 모듈(140)은 대상 프레임을 전송한 디바이스에 생성된 버스트 ACK 프레임(100)을 무선 매체를 통하여 전송한다(S80).The MAC module 120 attaches the MAC header to the payload of the burst ACK frame 100 generated in S50 or S69 to generate the burst ACK frame 100 (S70). The PHY module 140 transmits the burst ACK frame 100 generated to the device that transmitted the target frame through the wireless medium (S80).

도 16은 도 15의 S50 단계를 보다 자세히 나타낸 흐름도이다.FIG. 16 is a flowchart illustrating step S50 of FIG. 15 in more detail.

먼저, 메모리(250)에 저장된 MSDU number에 'MSDU 순번'을 부여한다(S51). 예를 들어, 저장된 MSDU number가 1234에서 1237 까지라면, MSDU number의 MSDU 순번(k)은 순서대로 1에서 4가 된다. 만약, 저장된 MSDU number가 연속적이지 않은 경우, 예를 들어 1234, 1236, 1237인 경우에도 존재하지 않는 1235에 대하여도, 모두 제대로 수신된 경우와 마찬가지로, MSDU 순번(k=3)이 부여된다.First, 'MSDU sequence number' is assigned to the MSDU number stored in the memory 250 (S51). For example, if the stored MSDU number is 1234 to 1237, the MSDU number k of the MSDU number is 1 to 4 in order. If the stored MSDU numbers are not contiguous, the MSDU sequence number (k = 3) is assigned to 1235 which does not exist even in the case of 1234, 1236, 1237, as well as the case where all are properly received.

다음으로, 초기 값으로서 k를 1로 두고 마지막 MSDU 순번을 N으로 둔다(S52).Next, k is set to 1 as an initial value and the last MSDU sequence number is set to N (S52).

수신 에러가 있을 수 있으므로, 인하여 모든 MSDU 순번(k)에 대하여 메모리(250)에 저장된 MSDU number가 존재하는 것은 아니다. 따라서, k번째 MSDU 순번에 대하여 MSDU number가 존재하는지를 판단하여(S53), 존재하지 않으면(S53의 아니오) Bitmap 필드(130)에 비트쌍을 '01'로 기록한다(S59).Since there may be a reception error, the MSDU number stored in the memory 250 does not exist for every MSDU sequence k. Therefore, it is determined whether the MSDU number exists for the k-th MSDU sequence number (S53), and if it does not exist (NO in S53), the bit pair is recorded as '01' in the Bitmap field 130 (S59).

만약 존재하는 경우에는 k번째 MSDU가 프래그먼트 되었는가를 판단하여(S54), 프래그먼트 되어 있지 않으면(S54의 아니오) Bitmap 필드(130)에 비트쌍을 '1X'로 기록한다. 여기서, X는 1 또는 0 아무 값이나 기록하여도 좋다는 의미이다.If it is present, it is determined whether the k-th MSDU is fragmented (S54). If it is not fragmented (NO in S54), the bit pair is recorded as '1X' in the Bitmap field 130. Here, X means that any value of 1 or 0 may be recorded.

프래그먼트 되어 있으면(S54의 예), k번째 MSDU에 해당하는 저장된 모든 프래그먼트의 Fragment number를 읽는다(S55). 그리고, 저장된 Fragment number 중 최대 Fragment number 보다 작은 'Fragment 순번' 각각에 대하여 Bitmap 필드(130)에 순차적으로 비트쌍을 기록한다(S56). 상기 Fragment 순번도 MSDU 순번과 마찬가지로 송신 디바이스가 전송한 프레임을 기준으로 하여 순차적으로 부여된다. If it is fragmented (YES in S54), the fragment numbers of all the stored fragments corresponding to the kth MSDU are read (S55). The bit pairs are sequentially recorded in the Bitmap field 130 for each of the 'fragment sequence numbers' smaller than the maximum fragment number among the stored fragment numbers (S56). Like the MSDU sequence, the fragment sequence number is sequentially assigned based on the frame transmitted by the transmitting device.

예를 들어, [2:0], [2:1], [2:2], 및 [2:3]이 전송되었지만, [2:1]과 [2:3] 만이 수신된 경우를 생각하면, 저장된 프래그먼트의 Fragment number는 1, 3이므로 최대 Fragment number은 3이 된다. 3보다 작은 'Fragment 순번'은 0, 1, 2를 의미하므로, 이에 대하여 Bitmap 필드(130)에 순차적으로 비트쌍을 기록하면, '00', '10', '00'이 되는 것이다.For example, suppose that [2: 0], [2: 1], [2: 2], and [2: 3] were sent, but only [2: 1] and [2: 3] were received. Since the fragment number of the stored fragment is 1, 3, the maximum fragment number is 3. Since the 'fragment sequence number' smaller than 3 means 0, 1, and 2, when the bit pairs are sequentially written in the bitmap field 130, '00', '10', and '00' are obtained.

다음, 최대 Fragment number가 최종 Fragment number와 같으면(S57의 예), Bitmap 필드(130)에 비트쌍을 '1X'로 기록한다. 여기서, 최대 Fragment number는 전술한 바와 같이 메모리(250)에 저장된 Fragment number 중 최대 값을 의미하고, 최종 Fragment number는 송신 디바이스가 전송한 대상 프레임의 최종 Fragment number를 의미한다. 최대 Fragment number가 최종 Fragment number 인지 여부는 도 13에서 More Frag 필드(113) 또는 도 14에서 Last fragment number 필드(119)를 참조하여 알 수 있다.Next, if the maximum fragment number is the same as the final fragment number (YES in S57), the bit pair is recorded as '1X' in the Bitmap field 130. As described above, the maximum fragment number refers to the maximum value of the fragment numbers stored in the memory 250, and the final fragment number refers to the final fragment number of the target frame transmitted by the transmitting device. Whether the maximum fragment number is the final fragment number can be known by referring to the More Frag field 113 in FIG. 13 or the Last fragment number field 119 in FIG.

S57 단계에서 '아니오'인 경우에는 Bitmap 필드(130)에 최대 Fragment number를 갖는 프래그먼트에 대한 비트쌍, 즉 '10'을 기록하고(S61), 이후의 모든 Fragment number에 대한 비트쌍은 '01'로 총괄하여 기록한다(S62).In the case of NO in step S57, the bit pair for the fragment having the maximum fragment number in the Bitmap field 130, that is, '10' is recorded (S61), and the bit pair for all subsequent fragment numbers is '01'. Collectively record as (S62).

S58 단계, S59 단계, S60 단계, 또는 S66 단계를 수행한 이후에는 k가 N과 같으면 Bitmap 필드(130)의 기록은 완료되었으므로 종료하고, 그렇지 않으면 k를 1증가시킨 후 다시 S53 단계로 돌아간다.After performing step S58, step S59, step S60, or step S66, if k equals to N, the recording of the bitmap field 130 is completed since the completion of the step. Otherwise, the process returns to step S53 after incrementing k by one.

이상 첨부된 도면을 참조하여 본 발명의 실시예를 설명하였지만, 본 발명이 속하는 기술분야에서 통상의 지식을 가진 자는 본 발명이 그 기술적 사상이나 필수적인 특징을 변경하지 않고서 다른 구체적인 형태로 실시될 수 있다는 것을 이해할 수 있을 것이다. 그러므로 이상에서 기술한 실시예들은 모든 면에서 예시적인 것이며 한정적이 아닌 것으로 이해해야 한다.Although embodiments of the present invention have been described above with reference to the accompanying drawings, those skilled in the art to which the present invention pertains may implement the present invention in other specific forms without changing the technical spirit or essential features thereof. I can understand that. Therefore, it should be understood that the embodiments described above are exemplary in all respects and not restrictive.

본 발명에 따르면, 버스트 ACK 프레임을 전송하는데 따른 오버헤드를 절감하는 효과가 있다.According to the present invention, there is an effect of reducing the overhead of transmitting a burst ACK frame.

또한 본 발명에 따르면, 상기 ACK 프레임의 오버헤드 절감으로 인하여 무선 네트워크 전체에서 총 데이터 전송률을 향상시키는 효과가 있다.In addition, according to the present invention, due to the overhead reduction of the ACK frame has the effect of improving the total data rate in the entire wireless network.

그리고, 본 발명에 따른 버스트 ACK 프레임 포맷은 IEEE 802.11e 표준에서의 블럭 ACK 프레임이나 IEEE 802.15.3 표준에서의 지연 ACK 프레임에 적용될 수 있다.The burst ACK frame format according to the present invention can be applied to a block ACK frame in the IEEE 802.11e standard or a delayed ACK frame in the IEEE 802.15.3 standard.

Claims (15)

송신 디바이스로부터 복수의 프레임을 수신하고 이에 대하여 하나의 ACK 프레임으로 확인 응답을 하는 ACK 프레임 전송 방법으로서,An ACK frame transmission method for receiving a plurality of frames from a transmitting device and acknowledgment with one ACK frame thereto, (a) 상기 송신 디바이스로부터 프레임을 수신하고 상기 수신된 프레임의 식별 정보를 저장하는 단계;(a) receiving a frame from the transmitting device and storing identification information of the received frame; (b) 상기 저장된 식별 정보를 이용하여, 상기 수신된 각 프레임에 대한 비트쌍의 집합을 기록함으로써 제1 필드를 생성하는 단계;(b) using the stored identification information to generate a first field by recording a set of bit pairs for each received frame; (c) 상기 생성된 제1 필드를 포함하여 ACK 프레임을 생성하는 단계; 및(c) generating an ACK frame including the generated first field; And (d) 상기 생성된 ACK 프레임을 상기 송신 디바이스에 전송하는 단계를 포함하며, (d) sending the generated ACK frame to the transmitting device, 상기 비트쌍은 해당 프레임이 정상적으로 수신되었는가를 확인하는 제1 비트와, The bit pair may include a first bit for confirming whether the corresponding frame is normally received, 상기 제1 비트가 해당 프레임 하나에 대한 수신 확인을 나타내는 것인가, 해당 프레임 이후의 모든 프래그먼트에 대한 수신 확인을 나타내는 것인가를 구별하는 제2 비트로서 구성되는, ACK 프레임 전송 방법.And a second bit for distinguishing whether the first bit indicates an acknowledgment for one frame or an acknowledgment for all fragments after the frame. 제1항에 있어서, 상기 (c) 단계는The method of claim 1, wherein step (c) (c1) 상기 식별 정보 중 최초의 식별 정보를 기록하는 제2 필드를 생성하는 단계를 포함하는, ACK 프레임 전송 방법.(c1) generating a second field for recording first identification information of the identification information. 제2항에 있어서, 상기 (c) 단계는The method of claim 2, wherein step (c) (c2) 상기 제1 필드가 바이트 단위로 되지 않는 경우에는 소정의 더미(dummy) 비트를 추가하여 바이트 단위로 만드는 단계를 더 포함하는, ACK 프레임 전송 방법.(c2) if the first field is not in a byte unit, adding a predetermined dummy bit to make it in a byte unit. 제3항에 있어서, 상기 식별 정보는The method of claim 3, wherein the identification information 상기 수신된 프레임의 MSDU number 및 Fragment number를 포함하는, ACK 프레임 전송 방법.And a MSDU number and a Fragment number of the received frame. 제4항에 있어서,The method of claim 4, wherein 상기 최초의 식별 정보는 상기 MSDU number가 가장 앞서는 식별 정보 중에서 Fragment number가 가장 앞서는 식별 정보인, ACK 프레임 전송 방법.And the first identification information is identification information with the first fragment number among the identification information with the MSDU number leading. 제1항에 있어서, The method of claim 1, 상기 제1 비트는, 해당 프레임이 정상적으로 수신된 경우에 1으로, 그 이외에는 0으로 기록되고,The first bit is recorded as 1 when the frame is normally received and 0 otherwise. 상기 제2 비트는, 상기 제1 비트가 해당 프레임 하나에 대한 수신 확인을 나타내는 것이면 1로, 그 이외에는 0으로 기록된다고 가정할 때, 상기 (b) 단계는Assuming that the second bit is written as 1 if the first bit indicates an acknowledgment for one frame, the step (b) is performed otherwise. (b1) 특정 MSDU 순번에 대하여 MSDU number가 존재하지 않으면 비트쌍을 '01'로 기록하고, 존재하면 상기 순번의 MSDU가 프래그먼트 되었는가를 판단하는 단계; 및(b1) if the MSDU number does not exist for a specific MSDU number, recording a bit pair as '01', and if present, determining whether the MSDU of the sequence is fragmented; And (b2) 상기 MSDU가 프래그먼트 되지 않은 경우에는 비트쌍을 '1X'로 기록하는 단계를 포함하며,(b2) if the MSDU is not fragmented, recording a bit pair as '1X', 상기 X는 1 또는 0 중 어느 하나의 값인, ACK 프레임 전송 방법. X is any one of 1 or 0, ACK frame transmission method. 제6항에 있어서, 상기 MSDU가 프래그먼트 된 경우에 상기 (b) 단계는The method of claim 6, wherein when the MSDU is fragmented, step (b) (b3) 최대 Fragment number 보다 작은 Fragment 순번 각각에 대하여 순차적으로 비트쌍을 기록하는 단계;(b3) sequentially recording the bit pairs for each of the Fragment sequence numbers smaller than the maximum Fragment number; (b4) 최대 Fragment number가 최종 Fragment number와 같으면 비트쌍을 '1X'로 기록하는 단계를 더 포함하는, ACK 프레임 전송 방법.(b4) if the maximum fragment number is the same as the final fragment number, further comprising: recording a bit pair as '1X'. 제7항에 있어서, 상기 최대 Fragment number가 최종 Fragment number와 같지 않으면 비트쌍을 '10'로 기록하고 연이은 비트쌍을 '01'로 기록하는 단계를 더 포함하는, ACK 프레임 전송 방법.8. The method according to claim 7, further comprising the step of writing a bit pair as '10' and subsequent bit pairs as '01' if the maximum fragment number is not equal to the final fragment number. 제1항에 있어서, 상기 (b) 단계는The method of claim 1, wherein step (b) 상기 송신 디바이스로부터 ACK 프레임 전송 요청을 받은 경우에 수행되는 ACK 프레임 전송 방법.ACK frame transmission method performed when an ACK frame transmission request is received from the transmitting device. 송신 디바이스로부터 복수의 프레임을 수신하고 이에 대하여 하나의 ACK 프레임으로 확인 응답을 하는 ACK 프레임 전송 장치로서,An ACK frame transmission apparatus for receiving a plurality of frames from the transmitting device and to respond to the response as one ACK frame, 상기 송신 디바이스로부터 프레임을 수신하는 제1 수단;First means for receiving a frame from the transmitting device; 상기 수신된 프레임의 식별 정보를 저장하는 제2 수단;Second means for storing identification information of the received frame; 상기 저장된 식별 정보를 이용하여, 상기 수신된 각 프레임에 대한 비트쌍의 집합을 기록함으로써 제1 필드를 생성하고, 상기 생성된 제1 필드를 포함하여 ACK 프레임을 생성하는 제3 수단; 및Third means for generating a first field by recording the set of bit pairs for each received frame using the stored identification information, and generating an ACK frame including the generated first field; And 상기 생성된 ACK 프레임을 상기 송신 디바이스에 전송하는 제4 수단을 포함하며, Fourth means for transmitting the generated ACK frame to the transmitting device, 상기 비트쌍은 해당 프레임이 정상적으로 수신되었는가를 확인하는 제1 비트와, The bit pair may include a first bit for confirming whether the corresponding frame is normally received, 상기 제1 비트가 해당 프레임 하나에 대한 수신 확인을 나타내는 것인가, 해당 프레임 이후의 모든 프래그먼트에 대한 수신 확인을 나타내는 것인가를 구별하는 제2 비트로서 구성되는, ACK 프레임 전송 장치.And a second bit for discriminating whether the first bit indicates an acknowledgment for one frame or an acknowledgment for all fragments after the frame. 제10항에 있어서, 상기 제3 수단은 The method of claim 10, wherein the third means 상기 식별 정보 중 최초의 식별 정보를 기록하는 제2 필드를 생성하는, ACK 프레임 전송 장치.And a second field for recording first identification information of the identification information. 제11항에 있어서, 상기 제3 수단은The method of claim 11, wherein the third means 상기 제1 필드가 바이트 단위로 되지 않는 경우에는 소정의 더미(dummy) 비트를 추가하여 바이트 단위로 만드는, ACK 프레임 전송 장치.And when the first field is not in bytes, adds a predetermined dummy bit to make it in bytes. 제12항에 있어서, 상기 식별 정보는The method of claim 12, wherein the identification information 상기 수신된 프레임의 MSDU number 및 Fragment number를 포함하는, ACK 프레임 전송 장치.And an MSDU number and a Fragment number of the received frame. 제13항에 있어서,The method of claim 13, 상기 최초의 식별 정보는 상기 MSDU number가 가장 앞서는 식별 정보 중에서 Fragment number가 가장 앞서는 식별 정보인, ACK 프레임 전송 장치.And the first identification information is identification information of which the fragment number is the earliest among identification information of which the MSDU number is the earliest. 제10항에 있어서, 상기 제3 수단은The method of claim 10, wherein the third means 상기 송신 디바이스로부터 ACK 프레임 전송 요청을 받을 받음에 따라서 동작하는 ACK 프레임 전송 방법. And receiving an ACK frame transmission request from the transmitting device.
KR1020040063599A 2004-08-12 2004-08-12 AC frame transmission method and device KR100631736B1 (en)

Priority Applications (8)

Application Number Priority Date Filing Date Title
KR1020040063599A KR100631736B1 (en) 2004-08-12 2004-08-12 AC frame transmission method and device
MX2007001682A MX2007001682A (en) 2004-08-12 2005-07-26 Method and apparatus for transmitting ack frame.
JP2007525531A JP2008509622A (en) 2004-08-12 2005-07-26 ACK frame transmission method and apparatus
BRPI0514128-1A BRPI0514128A (en) 2004-08-12 2005-07-26 ack frame transmission method, and ack frame transmission apparatus
PCT/KR2005/002420 WO2006016745A1 (en) 2004-08-12 2005-07-26 Method and apparatus for transmitting ack frame
CNA2005100907185A CN1734998A (en) 2004-08-12 2005-08-11 Send the method and apparatus of acknowledgement frame
US11/201,442 US20060034317A1 (en) 2004-08-12 2005-08-11 Method and apparatus for transmitting ACK frame
EP05255018A EP1626520A1 (en) 2004-08-12 2005-08-12 Method and apparatus for transmitting acknowledgement frames

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
KR1020040063599A KR100631736B1 (en) 2004-08-12 2004-08-12 AC frame transmission method and device

Publications (2)

Publication Number Publication Date
KR20060014875A true KR20060014875A (en) 2006-02-16
KR100631736B1 KR100631736B1 (en) 2006-10-09

Family

ID=36077218

Family Applications (1)

Application Number Title Priority Date Filing Date
KR1020040063599A KR100631736B1 (en) 2004-08-12 2004-08-12 AC frame transmission method and device

Country Status (2)

Country Link
KR (1) KR100631736B1 (en)
CN (1) CN1734998A (en)

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN113162867A (en) * 2020-01-07 2021-07-23 联发科技(新加坡)私人有限公司 Spreading sequence control for segmented frames in WLAN

Families Citing this family (7)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US9929847B2 (en) * 2014-12-23 2018-03-27 Qualcomm Incorporated Shortened block acknowledgement with fragmentation acknowledgement signaling
CN106161583B (en) * 2015-05-12 2020-02-21 华为技术有限公司 Method and equipment for transmitting block acknowledgement frame
CN106612159B (en) * 2015-10-23 2020-06-26 华为技术有限公司 Confirmation method and device based on service type indication
US10361832B2 (en) * 2016-04-22 2019-07-23 Qualcomm Incorporated Block acknowledgment generation and selection rules
CN105790896B (en) * 2016-05-04 2019-03-29 珠海市魅族科技有限公司 Communication means, communication device, access point and the website of WLAN
CN106792903A (en) * 2016-12-13 2017-05-31 深圳中科讯联科技股份有限公司 A kind of multi-to-multi wireless data sending method and device, method of reseptance and device
US12003329B2 (en) 2019-11-11 2024-06-04 Beijing Xiaomi Mobile Software Co., Ltd. Method for transmitting hybrid automatic repeat request feedback, and communication device

Family Cites Families (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP3757758B2 (en) 2000-05-24 2006-03-22 株式会社豊田自動織機 Wireless communication device
US6658619B1 (en) 2000-10-06 2003-12-02 Ericsson Inc. Systems and methods for implementing hierarchical acknowledgement bitmaps in an ARQ protocol

Cited By (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN113162867A (en) * 2020-01-07 2021-07-23 联发科技(新加坡)私人有限公司 Spreading sequence control for segmented frames in WLAN
CN113162867B (en) * 2020-01-07 2024-02-13 联发科技(新加坡)私人有限公司 Spreading sequence control for segmented frames in WLAN

Also Published As

Publication number Publication date
CN1734998A (en) 2006-02-15
KR100631736B1 (en) 2006-10-09

Similar Documents

Publication Publication Date Title
KR100678943B1 (en) Method and apparatus for transmitting block ACK frame
US11239958B2 (en) Method and apparatus for transmitting and receiving data in a communication system
US7680148B2 (en) Communication apparatus and communication method
JP4047836B2 (en) COMMUNICATION DEVICE, COMMUNICATION SYSTEM, COMMUNICATION METHOD, AND COMMUNICATION CONTROL PROGRAM
KR100750166B1 (en) Method and apparatus for transmitting Data efficiently in wireless network system
US7729665B2 (en) Down-link data transmission and receiving system and method of ARQ in wireless communication system
US20060136614A1 (en) System and method for variable length aggregate acknowledgements in a shared resource network
EP1548990A1 (en) Aggregated frame, generated above, within or below a MAC layer or in a physical layer
US20060034274A1 (en) System and method for variable length acknowledgements in a shared resource network
KR100750170B1 (en) Method and apparatus for transmitting data frame efficiently in communication network
JP4314294B2 (en) COMMUNICATION DEVICE, COMMUNICATION SYSTEM, COMMUNICATION METHOD, AND COMMUNICATION CONTROL PROGRAM
KR100714675B1 (en) Method for frame retransmission and network apparatus employing the method
US7477630B2 (en) Transmission controller used in media access control processing apparatus and transmission controlling method thereof
CN1260658A (en) Method for distributing radio resource in radio communication system
KR100631736B1 (en) AC frame transmission method and device
CN103178943A (en) Method, device and system for link adaption
US20050117541A1 (en) System and method for dynamically determining reservation parameters in a wireless network
US11984985B2 (en) Method of performing wireless communication, wireless transmission device and wireless reception device performing the same
CN114938340A (en) Service indication method and device
CN117480810A (en) Score plate shape updating method, device, equipment and storage medium

Legal Events

Date Code Title Description
A201 Request for examination
E902 Notification of reason for refusal
E701 Decision to grant or registration of patent right
GRNT Written decision to grant
LAPS Lapse due to unpaid annual fee