KR101029074B1 - 호스트 컨트롤러에서의 디스크립터 추적 장치 및 그 추적방법 - Google Patents

호스트 컨트롤러에서의 디스크립터 추적 장치 및 그 추적방법 Download PDF

Info

Publication number
KR101029074B1
KR101029074B1 KR1020070003084A KR20070003084A KR101029074B1 KR 101029074 B1 KR101029074 B1 KR 101029074B1 KR 1020070003084 A KR1020070003084 A KR 1020070003084A KR 20070003084 A KR20070003084 A KR 20070003084A KR 101029074 B1 KR101029074 B1 KR 101029074B1
Authority
KR
South Korea
Prior art keywords
descriptor
data
unit
memory
host controller
Prior art date
Application number
KR1020070003084A
Other languages
English (en)
Other versions
KR20080065873A (ko
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 KR1020070003084A priority Critical patent/KR101029074B1/ko
Priority to US11/744,233 priority patent/US7945714B2/en
Publication of KR20080065873A publication Critical patent/KR20080065873A/ko
Application granted granted Critical
Publication of KR101029074B1 publication Critical patent/KR101029074B1/ko

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/30Monitoring
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/07Responding to the occurrence of a fault, e.g. fault tolerance
    • G06F11/0703Error or fault processing not based on redundancy, i.e. by taking additional measures to deal with the error or fault not making use of redundancy in operation, in hardware, or in data representation
    • G06F11/0751Error or fault detection not based on redundancy
    • G06F11/0754Error or fault detection not based on redundancy by exceeding limits
    • G06F11/0757Error or fault detection not based on redundancy by exceeding limits by exceeding a time limit, i.e. time-out, e.g. watchdogs
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F21/00Security arrangements for protecting computers, components thereof, programs or data against unauthorised activity

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Quality & Reliability (AREA)
  • Computer Hardware Design (AREA)
  • Computer Security & Cryptography (AREA)
  • Software Systems (AREA)
  • Information Transfer Systems (AREA)
  • Debugging And Monitoring (AREA)

Abstract

본 발명은 디스크립터 추적 장치를 구비하는 호스트 컨트롤러에 관한 것으로, 본 발명에 따른 호스트 컨트롤러는 시스템 버스와의 인터페이스를 위한 제1 버스 인터페이스부; 시스템 메모리로부터 제1 버스 인터페이스부를 통해서 수신되는 데이터가 디스크립터 데이터인지 여부를 판단하는 프로세서; 및 프로세서에 수신되는 디스크립터 데이터를 수신하여 저장하는 디스크립터 추적부를 포함함으로써, 호스트 컨트롤러로 하여금 신속하고 다양한 기능 검증 및 디버깅을 할 수 있도록 하는 효과가 있다.

Description

호스트 컨트롤러에서의 디스크립터 추적 장치 및 그 추적 방법{Apparatus and method for tracing descriptors in host controllers}
도 1은 일반적인 USB 호스트 컨트롤러가 내장된 시스템 온 칩의 블록도를 나타낸 도면이다.
도 2는 본 발명의 일 실시예에 따른 USB 호스트 컨트롤러의 블록도를 나타낸 도면이다.
도 3은 본 발명의 일 실시예에 따른 USB 호스트 컨트롤러의 전체적인 블록도를 나타낸 도면이다.
도 4는 본 발명의 일 실시예에 따른 디스크립터 추적부의 내부 구성을 도시하는 도면이다.
도 5는 본 발명의 일 실시예에 따른 USB 호스트 컨트롤러에서의 디스크립터 추적 방법을 도시한 도면이다.
도 6은 본 발명의 다른 실시예에 따른 USB 호스트 컨트롤러에서의 디스크립터 추적 방법을 도시한 도면이다.
본 발명은 호스트 컨트롤러에 관한 것으로 더욱 상세하게는 디스크립터 추적 장치를 구비하는 USB 호스트 컨트롤러에 관한 것이다.
범용 직렬 버스(Universal Serial Bus, 이하 " USB" 라 함)는 퍼스널 컴퓨터(PC: Personal Computer) 주변기기를 위한 버스 규격으로서, 플러그-앤-플레이(Plug & Play), 핫스왑(Hot-Swap) 기능을 지원하므로 설치가 용이하며, 재부팅이나 셋업 과정이 불필요하므로 사용이 편리하다는 장점을 가지고 있다. 이러한 장점 때문에 현재 PC 분야 뿐만 아니라, 비 PC 분야인 임베디드 시스템(Embedded System)까지 그 적용 분야가 넓어지고 있는 상황이다.
이러한 USB는 USB 호스트 및 USB 디바이스로 구분된다. USB 호스트는 주로 PC와 같은 컴퓨팅 모듈에 장착되어 전체 데이터 통신을 관할하는 마스터로서 동작하며, USB 디바이스는 프린터나 마우스 등과 같이 호스트에 연결되어 특정 기능을 제공하는 기기에 장착된다.
한편, 시스템 온 칩(SOC: System On Chip)은 하나의 반도체 칩 안에 여러 가지 기능을 포함하는 집적회로(IC : Integrated Circuit)를 의미한다. 이러한 시스템 온 칩은 시스템 사이즈를 축소할 수 있을 뿐만 아니라, 시스템 테스팅 시간을 단축시키고, 시스템의 신뢰성을 향상시킬 수 있다.
현재 수 많은 USB 디바이스들이 시장에 존재하며, 이를 USB 호스트에 연결하기 위해 SOC 구현시에 USB 호스트 컨트롤러를 기본으로 내장하는 것이 일반화되고 있다.
도 1은 일반적인 USB 호스트 컨트롤러가 내장된 시스템 온 칩의 블록도를 나 타낸 도면이다.
도 1을 참조하면, CPU(102) 및 다수의 마스터들(104)은 시스템 버스(106) 및 메모리 인터페이스(108)를 통해서 시스템 메모리(114)를 공유한다. 또한, USB 호스트 컨트롤러(110)는 USB 디바이스(116)와 데이터 통신을 하는 동안에 시스템 메모리(114)에 액세스할 필요가 있다.
그런데 USB 호스트 컨트롤러(110)가 시스템 메모리(114)에 액세스할 때, 임의의 마스터(104)에 의한 시스템 버스(106)의 독점이 일어날 수 있다. 또한, 다른 복합적인 이유로도 메모리 에러가 발생할 수 있는 가능성이 높다는 문제가 있다.
특히, 디바이스의 종류, 제조자, 어떤 버전의 USB를 지원하는지 등과 같은 중요한 정보인 디스크립터 정보를 전송할 때 에러가 발생하게 되면, USB 호스트 컨트롤러는 오동작하게 되고, 그 오동작에 대한 원인 추적은 쉽지 않게 된다는 문제가 있다.
본 발명은 상술한 문제점을 해결하기 위해 창안된 것으로, 시스템 메모리로부터 호스트 컨트롤러로 전송되는 디스크립터 정보를 추적함으로써, 호스트 컨트롤러로 하여금 신속하고 다양한 기능 검증 및 디버깅을 할 수 있도록 하는 호스트 컨트롤러에서의 디스크립터 추적 장치 및 그 추적 방법을 제공하는데 그 목적이 있다.
상술한 목적을 달성하기 위해서 본 발명에 따른 호스트 컨트롤러는, 시스템 버스와의 인터페이스를 위한 제1 버스 인터페이스부; 시스템 메모리로부터 상기 제1 버스 인터페이스부를 통해서 수신되는 데이터가 디스크립터 데이터인지 여부를 판단하는 프로세서; 및 상기 프로세서에 수신되는 상기 디스크립터 데이터를 저장하는 디스크립터 추적부를 포함하는 것을 특징으로 한다.
상기 호스트 컨트롤러는 USB 디바이스를 제어하기 위한 USB 호스트 컨트롤러인 것을 특징으로 한다.
상기 디스크립터 추적부는 상기 프로세서에 상기 디스크립터 데이터가 수신되는 시점을 검출하고, 상기 시점에 상기 디스크립터 데이터를 수신하는 디스크립터 액세스 시점 검출부; 상기 디스크립터 액세스 시점 검출부로 수신되는 상기 디스크립터 데이터를 저장하는 메모리부를 포함하는 것을 특징으로 한다.
상기 디스크립터 추적부는 중앙처리장치로부터 상기 메모리부에 직접 액세스하기 위한 제2 버스 인터페이스부를 더 포함하는 것을 특징으로 한다.
바람직하게는, 상기 디스크립터 추적부는 상기 디스크립터 액세스 시점 검출부로부터 일정 시간 동안 상기 디스크립터 데이터가 수신되는 시점을 입력받지 못하면, 에러 플래그(error flag)를 발생시키는 플래그 발생부를 더 포함하는 것을 특징으로 한다.
상기 플래그 발생부는 상기 에러 플래그를 상기 중앙처리장치로 전송하는 것을 특징으로 한다.
상기 플래그 발생부는 상기 디스크립터 액세스 시점 검출부로 하여금 상기 메모리부로의 기록 요청을 보류하도록 하는 것을 특징으로 한다.
상기 디스크립터 추적부는 상기 메모리부를 제어하기 위한 메모리 컨트롤러를 더 포함하는 것을 특징으로 한다.
바람직하게는, 상기 메모리부는 듀얼 포트 랜덤 액세스 메모리인 것을 특징으로 한다.
바람직하게는, 상기 메모리부의 크기는 1 킬로 바이트 내지 4 킬로 바이트인 것을 특징으로 한다.
상기 호스트 컨트롤러는 프레임 시작 신호를 주기적으로 생성하여 상기 프로세서에 전송하는 SOF(Start-Of-Frame) 생성기를 더 포함하는 것을 특징으로 한다.
상기 호스트 컨트롤러는 상기 호스트 컨트롤러의 제어 데이터 또는 상태 데이터를 임시로 저장하는 레지스터를 더 포함하는 것을 특징으로 한다.
상기 호스트 컨트롤러는 디바이스로 입출력되는 데이터를 버퍼링하기 위한 버퍼부를 더 포함하는 것을 특징으로 한다.
상기 호스트 컨트롤러는 디바이스와 연결하기 위한 루트 허브를 더 포함하는 것을 특징으로 한다.
상기 디스크립터 액세스 시점 검출부는, 상기 프로세서에서 상기 디스크립터 데이터의 상태가 업데이트되면, 상기 디스크립터 데이터를 수신하여 상기 메모리부에 기록하기 위하여 상기 디스크립터 데이터 및 제어 신호를 상기 메모리 컨트롤러로 출력하는 것을 특징으로 한다.
상기 호스트 컨트롤러는 시스템 온 칩(System-On-Chip)의 내부에 내장되어 있는 것을 특징으로 한다.
또한, 상술한 목적을 달성하기 위해서 본 발명에 따른 호스트 컨트롤러에서의 디스크립터 추적 장치는, 프로세서에 디스크립터 데이터가 수신되는 시점을 검출하고, 상기 시점에 상기 디스크립터 데이터를 수신하는 디스크립터 액세스 시점 검출부; 상기 디스크립터 액세스 시점 검출부에 수신되는 상기 디스크립터 데이터를 저장하는 메모리부; 상기 메모리부를 제어하기 위한 메모리 컨트롤러; 중앙처리장치로부터 상기 메모리부에 직접 액세스하기 위한 제2 버스 인터페이스부; 상기 디스크립터 액세스 시점 검출부로부터 일정 시간 동안 상기 디스크립터 데이터가 수신되는 시점을 입력받지 못하면, 에러 플래그(error flag)를 발생시키는 플래그 발생부를 포함하는 것을 특징으로 한다.
또한, 상술한 목적을 달성하기 위해서 본 발명에 따른 호스트 컨트롤러에서의 디스크립터 추적 방법은, 시스템 메모리로부터 데이터를 판독하는 단계; 판독된 데이터가 디스크립터 데이터인지 여부를 판단하는 단계; 상기 판독된 데이터가 상기 디스크립터 데이터이면, 상기 디스크립터 데이터가 수신되는 시점을 검출하는 단계; 및 상기 시점에 수신되는 상기 디스크립터 데이터를 저장하는 단계를 포함하는 것을 특징으로 한다.
또한, 상술한 목적을 달성하기 위해서 본 발명에 따른 호스트 컨트롤러에서의 디스크립터 추적 방법을 실행하기 위한 프로그램을 저장한 컴퓨터로 판독가능한 기록매체는 시스템 메모리로부터 데이터를 판독하는 단계; 판독된 데이터가 디스크립터 데이터인지 여부를 판단하는 단계; 상기 판독된 데이터가 상기 디스크립터 데이터이면, 상기 디스크립터 데이터가 수신되는 시점을 검출하는 단계; 및 상기 시 점에 수신되는 상기 디스크립터 데이터를 저장하는 단계를 포함하는 방법을 실행하는 것을 특징으로 한다.
이하, 첨부된 도면을 참조하여 본 발명에 따른 바람직한 실시예를 상세하게 설명한다.
도 2는 본 발명의 일 실시예에 따른 USB 호스트 컨트롤러의 블록도를 나타낸 도면이다.
도 2를 참조하면, 본 발명의 일 실시예에 따른 USB 호스트 컨트롤러(200)는 제1 버스 인터페이스부(202), 프로세서(204), 및 디스크립터 추적부(206)를 포함한다.
제1 버스 인터페이스부(202)는 시스템 버스(208) 및 USB 호스트 컨트롤러(200) 간의 인터페이스이다. USB 호스트 컨트롤러(200)가 시스템 메모리(114)에 저장되어 있는 데이터를 수신하기 위해서는 시스템 버스(208) 및 제1 버스 인터페이스부(202)를 거쳐야 한다. 다만, 수신되는 데이터가 디스크립터 데이터인 경우에, 이하에서 설명될 것처럼, 디스크립터 추적부(206)의 디스크립터 데이터의 수신은 제1 버스 인터페이스부(202)를 거치지 않을 수도 있다.
디스크립터 데이터는 USB 호스트 컨트롤러(200)가 USB 디바이스(210)에 액세스하기 위해서 반드시 필요로 되는 정보로서, 디바이스의 종류, 제조자, 어떤 버전의 USB를 지원하는지 등과 같은 정보를 말한다. 이러한 디스크립터 데이터는 대개 시스템 메모리(114)에 저장된다. 시스템 메모리(114)는 SOC 내부에서 CPU(102) 및 복수 개의 마스터들(104)에 의해서 공유된다.
프로세서(204)는 USB 호스트 컨트롤러(200)의 메인 컨트롤러로서, 소프트웨어인 USB 호스트 컨트롤러 드라이버에 의해 생성되는 리스트(즉, USB 데이터 통신 시에 디스크립터 데이터를 이용하여 생성되는 데이터 구조)를 처리하고, USB 호스트 컨트롤러(200) 내부의 다른 구성요소와 인터페이스를 담당한다.
또한, 프로세서(204)는 시스템 메모리(114)로부터 시스템 버스(208) 및 제1 버스 인터페이스부(202)를 통해서 수신되는 데이터가 디스크립터 데이터인지 여부를 판단한다. 수신된 데이터가 디스크립터 데이터라면, 프로세서(204)는 디스크립터 추적부(206)에 이를 알리는 신호를 전송하고, 그에 의해 디스크립터 추적부(206)는 디스크립터 데이터가 수신되는 시점을 검출하고, 디스크립터 데이터를 저장하게 된다.
디스크립터 추적부(206)는 시스템 버스(208), 프로세서(204) 및 제1 버스 인터페이스부(202)에 연결된다. 디스크립터 추적부(206)는 USB 호스트 컨트롤러(200)에 수신되는 데이터가 디스크립터 데이터일 경우, 프로세서로부터 수신된 데이터가 디스크립터 데이터임을 알리는 신호를 받음으로써 디스크립터 데이터가 수신되는 시점을 검출한다.
이에 의해, 디스크립터 추적부(206)는 디스크립터 데이터가 수신되는 시점에 시스템 메모리(114)로부터 USB 호스트 컨트롤러(200)로 전송되는 디스크립터 데이터를 저장한다.
여기서, 디스크립터 데이터는 제1 버스 인터페이스부(202)를 거치지 않고, 시스템 버스(208)로부터 직접 디스크립터 추적부(206)로 수신될 수 있다.
또한, 디스크립터 추적부(206)는 제1 버스 인터페이스부(202)를 거치지 않고 중앙처리장치(212)에 직접 연결될 수 있다. 이에 의해서, 중앙처리장치(212)는 디스크립터 추적부(206)에 저장되어 있는 디스크립터 데이터를 디스크립터 추적부(206)의 인터페이스를 통하여 직접 판독함으로써 디스크립터 데이터를 추적하고, USB 호스트 컨트롤러의 정상 작동 여부를 확인할 수 있다.
또한, 디스크립터 추적부(206)는, 프로세서(204)에서 디스크립터 데이터의 상태가 업데이트되면, 업데이트된 디스크립터 데이터를 수신하여 이를 저장할 수 있다.
또한, USB 호스트 컨트롤러(200)는 시스템 온 칩(System-On-Chip)의 내부에 내장될 수 있다.
상술한 실시예는 USB 호스트 컨트롤러(200) 뿐만 아니라, 기타 규격의 호스트 컨트롤러에도 적용될 수 있음은 자명하다.
도 3은 본 발명의 일 실시예에 따른 USB 호스트 컨트롤러의 전체적인 블록도를 나타낸 도면이다.
도 3을 참조하면, 제1 버스 인터페이스부(202), 프로세서(204), 디스크립터 추적부(206), 시스템 버스(208), USB 디바이스(210), 중앙처리장치(202)는 각각 도 2의 제1 버스 인터페이스부(202), 프로세서(204), 디스크립터 추적부(206), 시스템 버스(208), USB 디바이스(210), 중앙처리장치(202)에 대응된다.
SOF 생성부(314)는 프로세서(204)와 연결되어, USB 데이터 통신을 위하여 매 시간 단위(예를 들어, USB 1.1에서는 1 밀리 초(msec), USB 2.0에서는 125 마이크 로 초(usec))마다 프레임 시작 신호를 주기적으로 생성하여 프로세서(204)에 전송한다.
레지스터(316)는 프로세서(204) 및 루트 허브(320)의 사이에 연결되어, USB 호스트 컨트롤러(300)에 필요한 제어 데이터나 상태 데이터 등을 임시로 저장한다.
버퍼부(318)는 프로세서(204) 및 루트 허브(320)의 사이에 연결되어, USB 디바이스로 입출력되는 USB 인/아웃 전송 데이터(USB IN/OUT Transfer data)를 버퍼링하는데 사용된다.
루트 허브(320)는 레지스터(316), 버퍼부(318) 및 USB 디바이스(210)에 연결되어, USB 디바이스가 연결되는 USB 다운스트림 포트들(USB downstream ports)에 대한 연결 및 차단을 처리하고, 리셋 및 재개(resume) 신호를 발생시키며, USB 요청의 타입에 따라 USB 디바이스의 방향으로 프로토콜에 맞는 패킷을 발생시킨다.
그 밖에, 제1 버스 인터페이스부(202), 프로세서(204), 디스크립터 추적부(206), 시스템 버스(208), USB 디바이스(210), 및 중앙처리장치(202)에 대해서는 도 2에서 설명되었으므로 이에 대한 설명은 생략한다.
도 4는 본 발명의 일 실시예에 따른 디스크립터 추적부의 내부 구성을 도시하는 도면이다.
도 4를 참조하면, 본 발명의 일 실시예에 따른 USB 호스트 컨트롤러(400)는 제1 버스 인터페이스부(202), 프로세서(204), 및 디스크립터 추적부(406)를 포함한다.
제1 버스 인터페이스부(202), 프로세서(204)는 각각 도 2의 제1 버스 인터페 이스부(202), 프로세서(204)에 대응되고, 이에 대해서는 도 2에서 설명되었으므로 이에 대한 설명은 생략한다.
디스크립터 추적부(406)는 디스크립터 액세스 시점 검출부(414) 및 메모리부(418)를 포함한다.
디스크립터 액세스 시점 검출부(414)는 시스템 버스(208), 프로세서(204) 및 제1 버스 인터페이스부(202)에 연결된다. 디스크립터 액세스 시점 검출부(414)는, USB 호스트 컨트롤러(400)에 수신되는 데이터가 디스크립터 데이터일 경우, 프로세서(204)로부터 디스크립터 데이터의 수신을 알리는 신호를 수신함으로써, USB 호스트 컨트롤러(400)에 디스크립터 데이터가 수신되는 시점을 검출한다.
디스크립터 액세스 시점 검출부(414)는, 디스크립터 데이터의 수신 시점을 검출하면, USB 호스트 컨트롤러(400)로 전송되는 디스크립터 데이터를 제1 버스 인터페이스부(202)를 거치지 않고 곧바로 수신한다. 그리고나서, 디스크립터 액세스 시점 검출부(214)는 수신한 디스크립터 데이터 및 메모리부(418)를 제어하기 위한 제어 신호를 메모리 컨트롤러(416)로 출력함으로써, 메모리부(418)에 대한 기록 요청을 한다.
또한, 디스크립터 액세스 시점 검출부(414)는, 프로세서(204)에서 디스크립터 데이터의 상태가 업데이트되면, 업데이트된 디스크립터 데이터를 수신하여 이를 메모리부(418)에 저장하도록 할 수 있다.
메모리부(418)는 USB 호스트 컨트롤러(400)가 시스템 메모리(114)를 통해 판독 또는 기록하는 디스크립터 데이터를 저장하기 위한 메모리로 사용된다. 예를 들 어, USB 호스트 컨트롤러(400)로 전송되는 데이터는 디스크립터 액세스 시점 검출부(214)를 통과함에 따라, 디스크립터 데이터만 메모리부에 저장되게 된다.
바람직하게는, 메모리부(418)는 USB 호스트 컨트롤러(400)로 입력되는 디스크립터 데이터를 저장함과 동시에 중앙처리장치(212)로부터 메모리부(418)를 직접 액세스하여 저장된 디스크립터 데이터를 판독하는 것을 수행할 수 있도록 하기 위하여, 듀얼 포트 랜덤 액세스 메모리(Dual-Port RAM)로 구성될 수 있다.
다만, 메모리부(418)는 전체 SOC의 크기에 영향을 미치는 부분이므로 여러 가지 상황을 고려하여 최적의 메모리 크기를 정할 필요가 있다. 예를 들어, 1 킬로 바이트(KBytes) 내지 4 킬로 바이트 사이에서 선택되는 것이 가능하다.
또한, 본 발명의 일 실시예에 따르면 디스크립터 추적부(406)는 상기 메모리부(418)를 제어하기 위해서 도 4에 나타난 바와 같이 메모리 컨트롤러(416)를 포함할 수 있다.
또한, 디스크립터 추적부(406)는 제2 버스 인터페이스부(418)를 포함할 수 있다. 제2 버스 인터페이스부(418)는 디스크립터 추적부(406)의 외부에 있는 중앙처리장치(212)로부터 메모리부(418)에 직접 액세스하여 메모리부(418)에 저장되어 있는 디스크립터 데이터를 판독하기 위한 것이다. 중앙처리장치(212)는 제2 버스 인터페이스부(418)를 통해서 시스템 메모리(114)로부터 USB 호스트 컨트롤러(400)로 전송된 디스크립터 데이터를 추적할 수 있다. 따라서, USB 호스트 컨트롤러(400)의 신속하고 다양한 기능 검증 및 디버깅이 가능해 진다.
기능 검증(또는 디버깅)의 형태나 방법 등은 특정한 범위 내로 한정되지 않 고, 다양한 방법으로 실행될 수 있다. 예컨데, 메모리부(418)로부터 판독된 디스크립터 데이터와 중앙처리장치(212)가 전송한 디스크립터 데이터를 비교하고, 이들이 서로 일치하지 않으면, 올바른 디스크립터 데이터를 USB 호스트 컨트롤러(400)로 재전송하는 방법 등이 가능할 것이다.
또한, 디스크립터 추적부(406)는 플래그 발생부(422)를 포함할 수 있다. 플래그 발생부(422)는 디스크립터 액세스 시점 검출부(414) 및 중앙처리장치(212)와 연결된다. 플래그 발생부(422)는 디스크립터 액세스 시점 검출부(414)로부터 일정 시간 동안 디스크립터 데이터가 수신되는 시점을 입력받지 못하면, 에러 플래그(error flag)를 발생시킨다. 여기서, 일정 시간은 미리 정해져 있는 규격이나 사용자의 필요에 의해 탄력적으로 결정될 수 있다.
에러 플래그 발생시, 플래그 발생부(422)는, 디스크립터 액세스 시점 검출부(414)로부터 다른 디스크립터 데이터가 계속적으로 입력되어 메모리부(418)에 저장되는 것을 막기 위해서, 디스크립터 액세스 시점 검출부(414)로 하여금 메모리부(418)로의 기록 요청을 보류하도록 하는 제어 신호를 전송한다. 제어 신호를 받은 디스크립터 액세스 시점 검출부(414)는 별도의 명령이 있을 때까지 시스템 버스(208)로부터 입력되는 디스크립터 데이터에 대한 메모리부(418)로의 기록 요청을 보류한다.
한편, 플래그 발생부(422)에 의해서 발생된 에러 플래그는 중앙처리장치(212)로 전송된다. 플래그 발생부(422)에서 발생되는 에러 플래그를 수신한 중앙처리장치(212)는 디스크립터 데이터의 전송에 에러가 있는지 여부를 확 인하는 과정을 거치게 된다.
또한, 본 발명의 다른 일 실시예에 따른 디스크립터 데이터 추적 장치는 디스크립터 액세스 시점 검출부(414), 메모리부(418), 메모리 컨트롤러(416), 제2 버스 인터페이스부(420), 플래그 발생부(422)를 포함할 수 있다. 이들 구성요소의 각각에 대해서는 상술되었으므로 구체적인 설명은 생략하기로 한다.
도 5는 본 발명의 일 실시예에 따른 USB 호스트 컨트롤러에서의 디스크립터 추적 방법을 도시한 도면이다.
도 5를 참조하면, 먼저 USN 호스트 컨트롤러(200)는 시스템 메모리(114)로부터 데이터를 판독한다(단계 501). USB 호스트 컨트롤러(200)가 시스템 메모리(114)에 저장되어 있는 데이터를 판독하기 위해서는 시스템 버스(208) 및 제1 버스 인터페이스부(202)를 거쳐야 한다. 디스크립터 데이터는 대개 시스템 메모리(114)에 저장된다.
다음으로, 판독된 데이터가 디스크립터 데이터인지 여부를 판단한다(단계 502). 예를 들어, 프로세서(204)에 의해서 수신되는 데이터가 디스크립터 데이터인지 여부를 판단한다.
다음으로, 판독된 데이터가 디스크립터 데이터이면(단계 503), 디스크립터 데이터가 수신되는 시점을 검출한다(단계 504). 예를 들어, 디스크립터 추적부(206)는 프로세서(204)로부터 USB 호스트 컨트롤러(200)에 수신된 데이터가 디스크립터 데이터임을 알리는 신호를 받음으로써 디스크립터 데이터가 수신되는 시점을 검출할 수 있다.
마지막으로, 검출된 시점에 수신되는 디스크립터 데이터를 저장한다(단계 505). 예를 들어, 시스템 메모리(114)에 의해 판독 또는 기록하는 디스크립터 데이터를 저장하기 위하여 듀얼 포트 랜덤 액세스 메모리(Dual-Port RAM)가 이용될 수 있다. 이에 의해서, USB 호스트 컨트롤러(200)로 입력되는 디스크립터 데이터를 저장함과 동시에 중앙처리장치(212)로부터 디스크립터 데이터를 판독하는 것을 실행할 수 있다.
메모리는 전체 SOC의 크기에 영향을 미치는 부분이므로 여러 가지 상황을 고려하여 최적의 메모리 크기를 정할 필요가 있다. 예를 들어, 1 킬로 바이트(KBytes) 내지 4 킬로 바이트 사이에서 선택되는 것이 가능하다.
도 6은 본 발명의 다른 실시예에 따른 USB 호스트 컨트롤러에서의 디스크립터 추적 방법을 도시한 도면이다.
도 6을 참조하면, 단계 501 내지 단계 505에 대해서는 도 5에서 설명한 본 발명의 일 실시예에 대응되는 것이다. 따라서 이에 대해서 중복되는 설명은 생략하기로 한다.
도 6의 단계 503에서 판독된 데이터가 디스크립터 데이터가 아니면, 시스템 메모리(114)로부터 일정 시간 동안 디스크립터 데이터가 수신되는지 여부를 판단한다(단계 601). 일정 시간 동안 디스크립터 데이터가 수신되지 않으면, 에러 플래그(error flag)를 발생시킨다(단계 602). 여기서, 일정 시간은 미리 정해져 있는 규격이나 사용자의 필요에 의해 탄력적으로 결정될 수 있다. 또한, 에러 플래그 발생시, 다른 디스크립터 데이터가 계속적으로 입력되어 메모리에 저장되는 것을 막기 위해서, 메모리에 대한 기록 요청을 보류할 수 있다.
다음으로, 발생되는 에러 플래그를 중앙처리장치(212)로 전송하고(단계 603), 마지막으로, 중앙처리장치(212)로부터 디스크립터 데이터를 저장하는 메모리에 직접 액세스한다(단계 604). 그에 의해서, 중앙처리장치(212)는 디스크립터 데이터의 전송에 에러가 있는지 여부를 확인하는 과정을 거치게 된다.
또한, 본 발명은 컴퓨터로 판독가능한 기록매체에 컴퓨터가 읽을 수 있는 코드로서 구현하는 것이 가능하다. 컴퓨터가 읽을 수 있는 기록매체는 컴퓨터 시스템에 의하여 읽혀질 수 있는 데이터가 저장되는 모든 종류의 기록장치를 포함한다.
컴퓨터로 판독가능한 기록매체의 예로는 ROM, RAM, CD-ROM, 자기 테이프, 플로피디스크, 광 데이터 저장장치 등이 있으며, 또한 캐리어 웨이브(예를 들어 인터넷을 통한 전송)의 형태로 구현되는 것도 포함한다. 또한 컴퓨터로 판독가능한 기록매체는 네트워크로 연결된 컴퓨터 시스템에 분산되어, 분산방식으로 컴퓨터가 읽을 수 있는 코드가 저장되고 실행될 수 있다.
상술한 내용은 본 발명의 기술적 사상을 벗어나지 않는 범위 내에서 다양한 실시예들을 만들어 내는 것이 가능하다. 그러므로, 상기 실시예들은 본 발명을 한정하는 것으로 해석되어서는 안 되고, 청구범위에 기재되어 있는 발명의 특징들의 범위 내에서 자유로이 변경될 수도 있다.
상술한 바와 같이, 본 발명에 따른 호스트 컨트롤러에서의 디스크립터 추적 장치 및 그 추적 방법에 따르면, 시스템 메모리로부터 호스트 컨트롤러로 전송되는 디스크립터 데이터를 추적함으로써, 호스트 컨트롤러로 하여금 신속하고 다양한 기능 검증 및 디버깅을 할 수 있도록 하는 효과가 있다.

Claims (29)

  1. 디바이스를 제어하기 위한 호스트 컨트롤러에 있어서,
    시스템 버스와의 인터페이스를 위한 제1 버스 인터페이스부;
    시스템 메모리로부터 상기 제1 버스 인터페이스부를 통해서 수신되는 데이터가 디스크립터 데이터인지 여부를 판단하는 프로세서; 및
    상기 프로세서에 수신되는 상기 디스크립터 데이터를 수신하여 저장하는 디스크립터 추적부를 포함하는 것을 특징으로 하는 호스트 컨트롤러.
  2. 제1항에 있어서,
    상기 호스트 컨트롤러는 USB 디바이스를 제어하기 위한 USB 호스트 컨트롤러인 것을 특징으로 하는 호스트 컨트롤러.
  3. 제2항에 있어서,
    상기 디스크립터 추적부는
    상기 프로세서에 상기 디스크립터 데이터가 수신되는 시점을 검출하고, 상기 시점에 상기 디스크립터 데이터를 수신하는 디스크립터 액세스 시점 검출부;
    상기 디스크립터 액세스 시점 검출부로 수신되는 상기 디스크립터 데이터를 저장하는 메모리부를 포함하는 것을 특징으로 하는 호스트 컨트롤러.
  4. 제3항에 있어서,
    상기 디스크립터 추적부는 중앙처리장치로부터 상기 메모리부에 직접 액세스하기 위한 제2 버스 인터페이스부를 더 포함하는 것을 특징으로 하는 호스트 컨트롤러.
  5. 제4항에 있어서,
    상기 디스크립터 추적부는 상기 디스크립터 액세스 시점 검출부로부터 일정 시간 동안 상기 디스크립터 데이터가 수신되는 시점을 입력받지 못하면, 에러 플래그(error flag)를 발생시키는 플래그 발생부를 더 포함하는 것을 특징으로 하는 호스트 컨트롤러.
  6. 제5항에 있어서,
    상기 플래그 발생부는 상기 에러 플래그를 상기 중앙처리장치로 전송하는 것을 특징으로 하는 호스트 컨트롤러.
  7. 제5항에 있어서,
    상기 플래그 발생부는 상기 디스크립터 액세스 시점 검출부로 하여금 상기 메모리부로의 기록 요청을 보류하도록 하는 것을 특징으로 하는 호스트 컨트롤러.
  8. 제3항에 있어서,
    상기 디스크립터 추적부는 상기 메모리부를 제어하기 위한 메모리 컨트롤러를 더 포함하는 것을 특징으로 하는 호스트 컨트롤러.
  9. 제3항에 있어서,
    상기 메모리부는 듀얼 포트 랜덤 액세스 메모리인 것을 특징으로 하는 호스트 컨트롤러.
  10. 제3항에 있어서,
    상기 메모리부의 크기는 1 킬로 바이트 내지 4 킬로 바이트인 것을 특징으로 하는 호스트 컨트롤러에서 디스크립터 추적 장치.
  11. 제2항에 있어서,
    상기 호스트 컨트롤러는 프레임 시작 신호를 주기적으로 생성하여 상기 프로세서에 전송하는 SOF(Start-Of-Frame) 생성기를 더 포함하는 것을 특징으로 하는 호스트 컨트롤러.
  12. 제2항에 있어서,
    상기 호스트 컨트롤러는 상기 호스트 컨트롤러의 제어 데이터 또는 상태 데이터를 임시로 저장하는 레지스터를 더 포함하는 것을 특징으로 하는 호스트 컨트롤러.
  13. 제2항에 있어서,
    상기 호스트 컨트롤러는 상기 디바이스로 입출력되는 데이터를 버퍼링하기 위한 버퍼부를 더 포함하는 것을 특징으로 하는 호스트 컨트롤러.
  14. 제2항에 있어서,
    상기 호스트 컨트롤러는 상기 디바이스와 연결하기 위한 루트 허브를 더 포함하는 것을 특징으로 하는 호스트 컨트롤러.
  15. 제8항에 있어서,
    상기 디스크립터 액세스 시점 검출부는, 상기 프로세서에서 상기 디스크립터 데이터의 상태가 업데이트되면, 상기 디스크립터 데이터를 수신하여 상기 메모리부에 기록하기 위하여 상기 디스크립터 데이터 및 제어 신호를 상기 메모리 컨트롤러로 출력하는 것을 특징으로 하는 호스트 컨트롤러.
  16. 제2항에 있어서,
    상기 호스트 컨트롤러는 시스템 온 칩(System-On-Chip)의 내부에 내장되어 있는 것을 특징으로 하는 호스트 컨트롤러.
  17. 디바이스를 제어하기 위한 호스트 컨트롤러에서의 디스크립터 추적 장치에 있어서,
    프로세서에 디스크립터 데이터가 수신되는 시점을 검출하고, 상기 시점에 상기 디스크립터 데이터를 수신하는 디스크립터 액세스 시점 검출부;
    상기 디스크립터 액세스 시점 검출부에 수신되는 상기 디스크립터 데이터를 저장하는 메모리부;
    상기 메모리부를 제어하기 위한 메모리 컨트롤러;
    중앙처리장치로부터 상기 메모리부에 직접 액세스하기 위한 제2 버스 인터페이스부;
    상기 디스크립터 액세스 시점 검출부로부터 일정 시간 동안 상기 디스크립터 데이터가 수신되는 시점을 입력받지 못하면, 에러 플래그(error flag)를 발생시키는 플래그 발생부를 포함하는 것을 특징으로 하는 호스트 컨트롤러에서의 디스크립터 추적 장치.
  18. 제17항에 있어서,
    상기 호스트 컨트롤러는 USB 디바이스를 제어하기 위한 USB 호스트 컨트롤러인 것을 특징으로 하는 호스트 컨트롤러에서의 디스크립터 추적 장치.
  19. 제18항에 있어서,
    상기 메모리부는 듀얼 포트 랜덤 액세스 메모리인 것을 특징으로 하는 호스트 컨트롤러에서의 디스크립터 추적 장치.
  20. 제19항에 있어서,
    상기 메모리부는 상기 디스크립터 데이터의 기록 및 판독이 동시에 일어날 수 있도록 동시에 액세스가 가능한 것을 특징으로 하는 호스트 컨트롤러에서의 디스크립터 추적 장치.
  21. 제17항에 있어서,
    상기 디스크립터 액세스 시점 검출부는, 상기 프로세서에서 상기 디스크립터 데이터의 상태가 업데이트되면, 상기 디스크립터 데이터를 수신하여 상기 메모리부에 기록하기 위하여 상기 디스크립터 데이터 및 제어 신호를 상기 메모리 컨트롤러로 출력하는 것을 특징으로 하는 호스트 컨트롤러에서의 디스크립터 추적 장치.
  22. 디바이스를 제어하기 위한 호스트 컨트롤러에서의 디스크립터 추적 방법에 있어서,
    시스템 메모리로부터 데이터를 판독하는 단계;
    상기 판독된 데이터가 디스크립터 데이터인지 여부를 판단하는 단계;
    상기 판독된 데이터가 상기 디스크립터 데이터이면, 상기 디스크립터 데이터가 수신되는 시점을 검출하는 단계; 및
    상기 시점에 수신되는 상기 디스크립터 데이터를 저장하는 단계를 포함하는 것을 특징으로 하는 호스트 컨트롤러에서의 디스크립터 추적 방법.
  23. 제22항에 있어서,
    상기 호스트 컨트롤러는 USB 디바이스를 제어하기 위한 USB 호스트 컨트롤러인 것을 특징으로 하는 호스트 컨트롤러에서의 디스크립터 추적 방법.
  24. 제22항에 있어서,
    상기 시스템 메모리로부터 일정 시간 동안 상기 디스크립터 데이터가 수신되지 않으면, 에러 플래그(error flag)를 발생시키는 단계를 더 포함하는 것을 특징으로 하는 호스트 컨트롤러에서의 디스크립터 추적 방법.
  25. 제22항에 있어서,
    상기 에러 플래그를 중앙처리장치로 전송하는 단계를 더 포함하는 것을 특징으로 하는 호스트 컨트롤러에서의 디스크립터 추적 방법.
  26. 제25항에 있어서,
    상기 중앙처리장치로부터 상기 디스크립터 데이터를 저장하는 메모리에 직접 액세스하는 단계를 더 포함하는 것을 특징으로 하는 호스트 컨트롤러에서의 디스크립터 추적 방법.
  27. 제22항에 있어서,
    상기 디스크립터 데이터를 저장하는 단계는 상기 디스크립터 데이터를 듀얼 포트 랜덤 액세스 메모리에 저장하는 것을 특징으로 하는 호스트 컨트롤러에서의 디스크립터 추적 방법.
  28. 제22항 내지 제27항 중 어느 한 항의 호스트 컨트롤러에서의 디스크립터 추적 방법을 실행하기 위한 프로그램을 저장한 컴퓨터로 판독가능한 기록매체.
  29. 제1항 내지 제16항 중 어느 한 항의 호스트 컨트롤러를 포함하는 시스템 온 칩.
KR1020070003084A 2007-01-10 2007-01-10 호스트 컨트롤러에서의 디스크립터 추적 장치 및 그 추적방법 KR101029074B1 (ko)

Priority Applications (2)

Application Number Priority Date Filing Date Title
KR1020070003084A KR101029074B1 (ko) 2007-01-10 2007-01-10 호스트 컨트롤러에서의 디스크립터 추적 장치 및 그 추적방법
US11/744,233 US7945714B2 (en) 2007-01-10 2007-05-04 Apparatus and method of tracing descriptors in host controller

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
KR1020070003084A KR101029074B1 (ko) 2007-01-10 2007-01-10 호스트 컨트롤러에서의 디스크립터 추적 장치 및 그 추적방법

Publications (2)

Publication Number Publication Date
KR20080065873A KR20080065873A (ko) 2008-07-15
KR101029074B1 true KR101029074B1 (ko) 2011-04-18

Family

ID=39595238

Family Applications (1)

Application Number Title Priority Date Filing Date
KR1020070003084A KR101029074B1 (ko) 2007-01-10 2007-01-10 호스트 컨트롤러에서의 디스크립터 추적 장치 및 그 추적방법

Country Status (2)

Country Link
US (1) US7945714B2 (ko)
KR (1) KR101029074B1 (ko)

Families Citing this family (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20090216517A1 (en) * 2008-02-27 2009-08-27 Ophir Herbst Dedicated simulator for testing a usb host solution
CN102508750A (zh) * 2011-10-27 2012-06-20 青岛海信信芯科技有限公司 Soc内部模块检测装置及方法
US9256569B2 (en) 2014-02-26 2016-02-09 American Megatrends, Inc. Monitoring and managing storage drives and performing backplane controller firmware using a USB interface
US9201833B2 (en) * 2014-02-26 2015-12-01 American Megatrends, Inc. Backplane controller capable of transferring and receiving data through USB interface
KR101996266B1 (ko) * 2014-09-18 2019-10-01 삼성전자주식회사 호스트 및 이를 포함하는 컴퓨터 시스템

Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR20060065960A (ko) * 2004-12-11 2006-06-15 엘지전자 주식회사 Usb를 이용한 휴대 복합 단말기 주변 장치의 접속시스템 및 방법
JP2006209448A (ja) 2005-01-27 2006-08-10 Fujitsu Ltd ダイレクトメモリアクセス制御方法、ダイレクトメモリアクセス制御装置、情報処理システム、プログラム
KR100676011B1 (ko) 2002-01-03 2007-01-29 인텔 코포레이션 인스트럭션 처리 방법 및 장치와 기계 판독가능한 매체

Family Cites Families (17)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6119190A (en) * 1996-11-06 2000-09-12 Intel Corporation Method to reduce system bus load due to USB bandwidth reclamation
US6049842A (en) * 1997-05-01 2000-04-11 International Business Machines Corporation Efficient data transfer mechanism for input/output devices
US6343260B1 (en) * 1999-01-19 2002-01-29 Sun Microsystems, Inc. Universal serial bus test system
US6470388B1 (en) * 1999-06-10 2002-10-22 Cisco Technology, Inc. Coordinated extendable system for logging information from distributed applications
US6829726B1 (en) * 2000-03-06 2004-12-07 Pc-Doctor, Inc. Method and system for testing a universal serial bus within a computing device
US6502146B1 (en) * 2000-03-29 2002-12-31 Intel Corporation Apparatus and method for dedicated interconnection over a shared external bus
WO2001093040A1 (fr) * 2000-05-30 2001-12-06 Matsushita Electric Industrial Co., Ltd. Systeme et procede d'analyse de compteur de programme, et dispositif a semi-conducteur
US7200671B1 (en) * 2000-08-23 2007-04-03 Mks Instruments, Inc. Method and apparatus for monitoring host to tool communications
US6874039B2 (en) * 2000-09-08 2005-03-29 Intel Corporation Method and apparatus for distributed direct memory access for systems on chip
US7007119B2 (en) * 2001-09-28 2006-02-28 Intel Corporation System and method for supporting split transactions on a bus
JP4063593B2 (ja) * 2002-05-30 2008-03-19 富士通株式会社 デバイス情報を管理可能なバスアナライザ
DE10224163B4 (de) * 2002-05-31 2005-05-04 Advanced Micro Devices, Inc., Sunnyvale Transaktionsdauermanagement in einem USB-Hostcontroller
DE10239814B4 (de) * 2002-08-29 2008-06-05 Advanced Micro Devices, Inc., Sunnyvale Erweiterte Testmodusunterstützung für Hostcontroller
US20040179228A1 (en) * 2003-03-10 2004-09-16 Mccluskey Mark Indication of image content modification
CN100476775C (zh) * 2003-05-15 2009-04-08 Nxp股份有限公司 用于总线通信设备的主机控制器以及总线通信设备
TW200622729A (en) * 2004-12-31 2006-07-01 Inventec Corp Computer communication interface transmission control codes analyzing method and system
US8694970B2 (en) * 2005-06-02 2014-04-08 Seagate Technology Llc Unified debug system with multiple user-configurable trace volumes and trace buffers

Patent Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR100676011B1 (ko) 2002-01-03 2007-01-29 인텔 코포레이션 인스트럭션 처리 방법 및 장치와 기계 판독가능한 매체
KR20060065960A (ko) * 2004-12-11 2006-06-15 엘지전자 주식회사 Usb를 이용한 휴대 복합 단말기 주변 장치의 접속시스템 및 방법
JP2006209448A (ja) 2005-01-27 2006-08-10 Fujitsu Ltd ダイレクトメモリアクセス制御方法、ダイレクトメモリアクセス制御装置、情報処理システム、プログラム

Also Published As

Publication number Publication date
US7945714B2 (en) 2011-05-17
US20080168192A1 (en) 2008-07-10
KR20080065873A (ko) 2008-07-15

Similar Documents

Publication Publication Date Title
US7715450B2 (en) Sideband bus setting system and method thereof
US8874959B2 (en) Information processing apparatus, image forming apparatus, and information processing program
CN108268414B (zh) 基于spi模式的sd卡驱动器及其控制方法
US8161221B2 (en) Storage system provided with function for detecting write completion
KR20160106218A (ko) 커맨드/어드레스 레지스터 디바이스 내에 저장된 데이터에의 액세스
US9558086B2 (en) System on chip with debug controller and operating method thereof
US7783817B2 (en) Method and apparatus for conditional broadcast of barrier operations
KR101029074B1 (ko) 호스트 컨트롤러에서의 디스크립터 추적 장치 및 그 추적방법
TWI498743B (zh) 資料儲存系統以及其管理方法
US9626241B2 (en) Watchdogable register-based I/O
US10042585B2 (en) Pervasive drive operating statistics on SAS drives
US9542251B2 (en) Error detection on a low pin count bus
US6584586B1 (en) Apparatus and method for capturing and transferring internal system activity
CN110175146B (zh) 硬盘信息获取方法和获取硬盘信息的装置
US6820149B2 (en) Method, system, and program for testing a bus interface
US7124235B2 (en) USB apparatus with switchable host/hub functions and control method thereof
CN101911035B (zh) 通过存储器地址映射使处理器与外部设备相接口的桥电路
US7797134B2 (en) System and method for testing a memory with an expansion card using DMA
US10911259B1 (en) Server with master-slave architecture and method for reading and writing information thereof
KR100801759B1 (ko) 슬레이브의 디버깅 방법 및 시스템
KR101260313B1 (ko) 전자장치 및 그 데이터 송수신방법과, 슬레이브 장치 및복수의 장치 간의 통신방법
US20140040382A1 (en) Secure digital host controller virtualization
CN111198837B (zh) 基于fpga的sdio接口***、控制器桥接方法
CN112749105B (zh) 一种降低espi总线开销的方法和设备
US7072788B2 (en) System and method for testing an interconnect in a computer system

Legal Events

Date Code Title Description
A201 Request for examination
E701 Decision to grant or registration of patent right
FPAY Annual fee payment
GRNT Written decision to grant
FPAY Annual fee payment

Payment date: 20160330

Year of fee payment: 6

FPAY Annual fee payment

Payment date: 20170330

Year of fee payment: 7

FPAY Annual fee payment

Payment date: 20180329

Year of fee payment: 8

LAPS Lapse due to unpaid annual fee