KR102448146B1 - 단말의 개선을 위한 파일 관리 방법 및 이를 수행하는 장치들 - Google Patents

단말의 개선을 위한 파일 관리 방법 및 이를 수행하는 장치들 Download PDF

Info

Publication number
KR102448146B1
KR102448146B1 KR1020200141080A KR20200141080A KR102448146B1 KR 102448146 B1 KR102448146 B1 KR 102448146B1 KR 1020200141080 A KR1020200141080 A KR 1020200141080A KR 20200141080 A KR20200141080 A KR 20200141080A KR 102448146 B1 KR102448146 B1 KR 102448146B1
Authority
KR
South Korea
Prior art keywords
file
model
distribution table
metadata
channel address
Prior art date
Application number
KR1020200141080A
Other languages
English (en)
Other versions
KR20220056472A (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 KR1020200141080A priority Critical patent/KR102448146B1/ko
Publication of KR20220056472A publication Critical patent/KR20220056472A/ko
Application granted granted Critical
Publication of KR102448146B1 publication Critical patent/KR102448146B1/ko

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F8/00Arrangements for software engineering
    • G06F8/60Software deployment
    • G06F8/65Updates
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/10File systems; File servers
    • G06F16/14Details of searching files based on file metadata
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/10File systems; File servers
    • G06F16/17Details of further file system functions
    • G06F16/176Support for shared access to files; File sharing support
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F8/00Arrangements for software engineering
    • G06F8/70Software maintenance or management
    • G06F8/71Version control; Configuration management
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/44Arrangements for executing specific programs
    • G06F9/4401Bootstrapping
    • G06F9/4406Loading of operating system
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/46Multiprogramming arrangements
    • G06F9/54Interprogram communication
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/46Multiprogramming arrangements
    • G06F9/54Interprogram communication
    • G06F9/547Remote procedure calls [RPC]; Web services

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Software Systems (AREA)
  • General Engineering & Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Computer Security & Cryptography (AREA)
  • Data Mining & Analysis (AREA)
  • Databases & Information Systems (AREA)
  • Library & Information Science (AREA)
  • Information Retrieval, Db Structures And Fs Structures Therefor (AREA)
  • Document Processing Apparatus (AREA)
  • Information Transfer Between Computers (AREA)

Abstract

단말의 개선을 위한 파일 관리 방법 및 이를 수행하는 장치들이 개시된다. 일 실시예에 따른 파일 관리 방법은 단말의 모델별로 제공될 파일의 메타데이터를 포함하는 파일 분배 테이블을 상기 모델별로 생성하는 단계와, 상기 모델별로 생성된 파일 분배 테이블을 포함하는 단일 패킷을 생성하여 제어 채널 주소로 전송하는 단계와, 상기 단말의 모델별로 제공될 파일을 포함하는 패킷을 상기 모델별로 생성하는 단계와, 상기 모델별로 생성된 패킷 각각을 대응하는 데이터 채널 주소로 전송하는 단계를 포함한다.

Description

단말의 개선을 위한 파일 관리 방법 및 이를 수행하는 장치들{A METHOD OF MANAGING FILES FOR TERMINAL IMPROVEMENT, AND APPRATUSES PERFORMING THE SAME}
본 개시는 인터넷 서비스에 연결된 단말의 개선을 위한 파일 관리 방법 및 이를 수행하는 장치들에 관한 것이다.
인터넷 서비스에 연결된 저사양 단말(예를 들어, 셋톱박스)의 기능/성능 개선을 하기 위해서 기기의 펌웨어/앱 업데이트를 OTA(over-the-air) 방식으로 진행하는 것이 추세이다.
OTA 업그레이드는 원격으로 업그레이드를 통한 기능을 추가함으로 서비스 출시 기간을 단축할 수 있지만, 현재 OTA 업그레이드는 서버와 단말이 1:1 통신을 하는 유니캐스트(unicast) 방식이기 때문에 단말 수가 많을수록 인터넷 백본망 트래픽 증가와 플랫폼 서버 증가로 인해 비용적 부담이 발생한다
실시예들은 다수 종의 단말에 동시에 단말 수 제한 없이 트래픽/서버 부하 없이 파일을 전송할 수 있는 기술을 제공할 수 있다.
다만, 기술적 과제는 상술한 기술적 과제들로 한정되는 것은 아니며, 또 다른 기술적 과제들이 존재할 수 있다.
일 실시예에 따른 파일 관리 방법은 단말의 모델별로 제공될 파일의 메타데이터를 포함하는 파일 분배 테이블을 상기 모델별로 생성하는 단계와, 상기 모델별로 생성된 파일 분배 테이블을 포함하는 단일 패킷을 생성하여 제어 채널 주소로 전송하는 단계와, 상기 단말의 모델별로 제공될 파일을 포함하는 패킷을 상기 모델별로 생성하는 단계와, 상기 모델별로 생성된 패킷 각각을 대응하는 데이터 채널 주소로 전송하는 단계를 포함한다.
상기 방법은 새로운 버전의 파일에 응답하여 상기 단일 패킷에서 이전 버전의 파일의 파일 분배 테이블을 상기 새로운 버전의 파일의 파일 분배 테이블로 업데이트하는 단계와, 상기 새로운 버전의 파일 분배 테이블로 업데이트된 상기 단일 패킷을 상기 제어 채널 주소로 전송하는 단계를 더 포함할 수 있다.
상기 업데이트하는 단계는 상기 이전 버전의 파일의 파일 분배 테이블에서 상기 이전 버전의 메타데이터를 상기 새로운 버전의 메타데이터로 업데이트하여 상기 새로운 버전의 파일의 파일 분배 테이블을 생성하는 단계를 포함할 수 있다.
상기 모델별로 생성된 파일 분배 테이블은 상기 모델별로 제공될 펌웨어의 메타데이터를 포함하는 파일 분배 테이블과 상기 모델별로 제공될 애플리케이션 파일의 메타데이터를 포함하는 파일 분배 테이블 중에서 하나 이상을 포함할 수 있다.
상기 파일 분배 테이블은 상기 모델별로 할당된 데이터 채널 주소를 더 포함할 수 있다.
상기 단일 패킷 및 상기 모델별로 생성된 패킷을 FLUTE 프로토콜을 이용하여 일대다 전송 방식으로 전송하는 것일 수 있다.
상기 일대다 전송 방식은 멀티캐스트 전송 방식 및 브로드캐스트 전송 방식 중에서 어느 하나인 것일 수 있다.
일 실시예에 따른 파일 관리 방법은 단말의 모델별로 제공될 파일의 메타데이터 및 상기 모델별로 할당된 데이터 채널 주소를 포함하는 파일 분배 테이블을 상기 모델별로 생성하는 단계와, 상기 모델별로 생성된 파일 분배 테이블을 포함하는 단일 패킷을 생성하는 단계와, 상기 단일 패킷을 제어 채널 주소로 일대다 전송 방식으로 하나 이상의 단말로 전송하는 단계를 포함한다.
일 실시예에 따른 파일 관리 방법은 단말의 모델별로 제공될 파일의 메타데이터 및 상기 모델별로 할당된 데이터 채널 주소를 포함하는 파일 분배 테이블이 상기 모델별로 포함된 단일 패킷을 제어 채널 주소를 통해 수신하는 단계와, 상기 단일 패킷에서 해당 모델에 대응하는 파일 분배 테이블을 획득하는 단계와, 상기 해당 모델에 대응하는 파일 분배 테이블에 포함된 데이터 채널 주소를 이용하여 상기 해당 모델에 제공될 파일이 포함된 패킷을 수신하는 단계를 포함한다.
상기 방법은 하나 이상의 임의의 모델에 제공될 새로운 버전의 파일의 파일 분배 테이블로 업데이트된 상기 단일 패킷을 상기 제어 채널 주소로 수신하는 단계와, 상기 해당 모델에 대응하는 파일 분배 테이블에서 상기 해당 모델에 제공될 파일이 새로운 버전으로 업데이트되었는지 확인하는 단계를 더 포함할 수 있다.
상기 방법은 상기 해당 모델에 제공될 파일의 새로운 버전의 메타데이터에 응답하여 상기 해당 모델에 대응하는 데이터 채널 주소를 통해 상기 해당 모델에 제공될 파일의 새로운 버전을 다운로드하는 단계를 더 포함할 수 있다.
상기 이전 버전의 파일의 파일 분배 테이블에서 이전 버전의 메타데이터가 새로운 버전의 메타데이터로 업데이트되는 것일 수 있다.
상기 모델별로 포함된 파일 분배 테이블은 상기 모델별로 제공될 펌웨어의 메타데이터를 포함하는 파일 분배 테이블과 상기 모델별로 제공될 애플리케이션 파일의 메타데이터를 포함하는 파일 분배 테이블 중에서 하나 이상을 포함할 수 있다.
상기 단일 패킷 및 상기 해당 모델에 제공될 파일이 포함된 패킷은 FLUTE 프로토콜을 이용하여 일대다 전송 방식으로 수신되는 것일 수 있다.
상기 일대다 전송 방식은 멀티캐스트 전송 방식 및 브로드캐스트 전송 방식 중 어느 하나인 것일 수 있다.
일 실시예에 따른 파일 관리 장치는 하나 이상의 인스트럭션을 저장하는 메모리와, 상기 인스트럭션을 실행시키기 위한 프로세서를 포함하고, 상기 인스트럭션이 실행될 때, 상기 프로세서는 단말의 모델별로 제공될 파일의 메타데이터를 포함하는 파일 분배 테이블을 상기 모델별로 생성하고, 모델별로 생성된 파일 분배 테이블을 포함하는 단일 패킷을 제어 채널 주소로 전송하고, 상기 단말의 모델별로 제공될 파일을 포함하는 패킷을 상기 모델별로 생성하고, 상기 모델별로 생성된 패킷 각각을 대응하는 데이터 채널 주소로 전송한다.
상기 프로세서는 새로운 버전의 파일에 응답하여 상기 단일 패킷에서 이전 버전의 파일의 파일 분배 테이블을 상기 새로운 버전의 파일의 파일 분배 테이블로 업데이트하고, 상기 새로운 버전의 파일 분배 테이블로 업데이트된 상기 단일 패킷을 상기 제어 채널 주소로 전송할 수 있다.
상기 프로세서는 상기 이전 버전의 파일의 파일 분배 테이블에서 상기 이전 버전의 메타데이터를 상기 새로운 버전의 메타데이터로 업데이트하여 상기 새로운 버전의 파일의 파일 분배 테이블을 생성할 수 있다.
상기 파일 분배 테이블은 상기 모델별로 할당된 데이터 채널 주소를 더 포함할 수 있다.
일 실시예에 따른 단말은 하나 이상의 인스트럭션을 저장하는 메모리와, 상기 인스트럭션을 실행시키기 위한 프로세서를 포함하고, 상기 인스트럭션이 실행될 때, 상기 프로세서는 단말의 모델별로 제공될 파일의 메타데이터 및 상기 모델별로 할당된 데이터 채널 주소를 포함하는 파일 분배 테이블이 상기 모델별로 포함된 단일 패킷을 제어 채널 주소를 통해 수신하고, 상기 단일 패킷에서 해당 모델에 대응하는 파일 분배 테이블을 획득하고, 상기 해당 모델에 대응하는 파일 분배 테이블에 포함된 데이터 채널 주소를 이용하여 상기 해당 모델에 제공될 파일이 포함된 패킷을 수신한다.
상기 프로세서는 하나 이상의 임의의 모델에 제공될 새로운 버전의 파일의 파일 분배 테이블로 업데이트된 상기 단일 패킷을 상기 제어 채널 주소로 수신하고, 상기 해당 모델에 대응하는 파일 분배 테이블에서 상기 해당 모델에 제공될 파일이 새로운 버전으로 업데이트되었는지 확인할 수 있다.
상기 프로세서는 상기 해당 모델에 제공될 파일의 새로운 버전의 메타데이터에 응답하여 상기 해당 모델에 대응하는 데이터 채널 주소를 통해 상기 해당 모델에 제공될 파일의 새로운 버전을 다운로드할 수 있다.
상기 이전 버전의 파일의 파일 분배 테이블에서 이전 버전의 메타데이터가 새로운 버전의 메타데이터로 업데이트되는 것일 수 있다.
도 1은 일 실시예에 따른 파일 관리 시스템의 개략적인 블록도를 나타내고, 도 2는 프로토콜 계층 구조의 일 예를 나타낸다.
도 3은 파일 정보 전달 프로세스의 일 예를 설명하기 위한 도면이다.
도 4는 파일 전송 프로세스의 일 예를 설명하기 위한 도면이다.
도 5는 파일의 버전 업데이트 프로세스의 일 예를 설명하기 위한 도면이다.
도 6은 파일 관리 장치의 일 예의 개략적인 블록도이다.
도 7은 단말의 일 예의 개략적인 블록도이다.
실시예들에 대한 특정한 구조적 또는 기능적 설명들은 단지 예시를 위한 목적으로 개시된 것으로서, 다양한 형태로 변경되어 구현될 수 있다. 따라서, 실제 구현되는 형태는 개시된 특정 실시예로만 한정되는 것이 아니며, 본 명세서의 범위는 실시예들로 설명한 기술적 사상에 포함되는 변경, 균등물, 또는 대체물을 포함한다.
제1 또는 제2 등의 용어를 다양한 구성요소들을 설명하는데 사용될 수 있지만, 이런 용어들은 하나의 구성요소를 다른 구성요소로부터 구별하는 목적으로만 해석되어야 한다. 예를 들어, 제1 구성요소는 제2 구성요소로 명명될 수 있고, 유사하게 제2 구성요소는 제1 구성요소로도 명명될 수 있다.
어떤 구성요소가 다른 구성요소에 "연결되어" 있다고 언급된 때에는, 그 다른 구성요소에 직접적으로 연결되어 있거나 또는 접속되어 있을 수도 있지만, 중간에 다른 구성요소가 존재할 수도 있다고 이해되어야 할 것이다.
단수의 표현은 문맥상 명백하게 다르게 뜻하지 않는 한, 복수의 표현을 포함한다. 본 명세서에서, "포함하다" 또는 "가지다" 등의 용어는 설명된 특징, 숫자, 단계, 동작, 구성요소, 부분품 또는 이들을 조합한 것이 존재함으로 지정하려는 것이지, 하나 또는 그 이상의 다른 특징들이나 숫자, 단계, 동작, 구성요소, 부분품 또는 이들을 조합한 것들의 존재 또는 부가 가능성을 미리 배제하지 않는 것으로 이해되어야 한다.
다르게 정의되지 않는 한, 기술적이거나 과학적인 용어를 포함해서 여기서 사용되는 모든 용어들은 해당 기술 분야에서 통상의 지식을 가진 자에 의해 일반적으로 이해되는 것과 동일한 의미를 가진다. 일반적으로 사용되는 사전에 정의되어 있는 것과 같은 용어들은 관련 기술의 문맥상 가지는 의미와 일치하는 의미를 갖는 것으로 해석되어야 하며, 본 명세서에서 명백하게 정의하지 않는 한, 이상적이거나 과도하게 형식적인 의미로 해석되지 않는다.
이하, 실시예들을 첨부된 도면들을 참조하여 상세하게 설명한다. 첨부 도면을 참조하여 설명함에 있어, 도면 부호에 관계없이 동일한 구성 요소는 동일한 참조 부호를 부여하고, 이에 대한 중복되는 설명은 생략하기로 한다.
도 1은 일 실시예에 따른 파일 관리 시스템의 개략적인 블록도를 나타내고, 도 2는 프로토콜 계층 구조의 일 예를 나타낸다.
파일 관리 시스템(10)은 파일 관리 장치(100) 및 복수의 단말들(200-1~200-n, n은 1 이상의 자연수)을 포함한다. 파일 관리 장치(100)와 복수의 단말들(200-1~200-n)은 네트워크(50)를 통해 서로 연결되어 통신을 수행한다.
파일 관리 장치(100)는 인터넷 서비스에 연결된 복수의 단말들(200-1~200-n)의 개선을 위한 파일의 전송 및 업그레이드에 관한 파일 관리를 수행할 수 있다. 파일 관리 장치(100)는 일대다(1:n) 전송 방식을 이용하여 파일을 동시에 복수의 단말들(200-1~200-n)에 OTA(over-the-air) 방식으로 전송 및 업그레이드를 가능하게 할 수 있다. 일대다 전송 방식은 멀티캐스트 전송 방식 및 브로드캐스트 전송 방식을 포함할 수 있다.
파일 관리 장치(100)는 복수의 단말들(200-1~200-n)에OTA 방식으로 전송 및 업그레이드를 위해 도 2에 도시된 프로토콜 계층 구조 중에서 일대다 전송 환경에서 파일 전송에 적합한 FLUTE(File Delivery over Unidirectional Transport) 프로토콜을 이용할 수 있다. 파일은 펌웨어 및 애플리케이션 파일 중에서 하나 이상을 포함할 수 있다.
복수의 단말들(200-1~200-n)은 파일 관리 장치(100)로부터 파일을 수신, 예를 들어 다운로드할 수 있다. 복수의 단말들(200-1~200-n)은 동일 종의 단말 및 서로 다른 종의 단말로 구성될 수 있다. 즉, 복수의 단말들(200-1~200-n)은 단말의 모델이 동일하거나 서로 상이할 수 있다.
복수의 단말들(200-1~200-n)은 셋톱박스(예를 들어, 인터넷 셋톱박스), PC(Personal Computer), 랩탑(laptop) 컴퓨터, 이동 전화기, 스마트 폰(smart phone), 태블릿(tablet) PC, 모바일 인터넷 디바이스(mobile internet device(MID)), PDA(personal digital assistant), EDA(enterprise digital assistant), 디지털 스틸 카메라(digital still camera), 디지털 비디오 카메라(digital video camera), PMP(portable multimedia player), PND(personal navigation device 또는 portable navigation device), 휴대용 게임 콘솔(handheld game console), e-북(e-book), 스마트 디바이스(smart device)으로 구현될 수 있다. 이때, 스마트 디바이스는 스마트 안경(smart glasses), 스마트 콘택트 렌즈(smart contact lens)), 헤드 마운트 디스플레이(head mounted display), 스마트 워치(smart watch) 또는 스마트 밴드(smart band)와 같은 웨어러블 디바이스로 구현될 수 있다.
복수의 단말들(200-1~200-n)에 파일을 동시에 전송 및 업그레이드하는 프로세스는 파일 정보 전달 프로세스, 파일 전송 프로세스, 및 파일의 버전 업데이트 프로세스 중에서 하나 이상으로 구성될 수 있다. 파일 전송 프로세스는 파일 정보 전달 프로세스와 동시에 수행될 수 있다.
파일 정보 전달 프로세스는 단말에 다운로드할 파일 정보를 전달하는 것으로, 다음과 같이 수행될 수 있다.
파일 관리 장치(100)는 단말의 모델별로 제공될 파일의 메타데이터를 포함하는 파일 분배 테이블을 모델별로 생성할 수 있다. 메타데이터는 모델명, 파일명, 및 파일 버전 등의 정보를 포함할 수 있다.
모델별로 생성된 파일 분배 테이블은 모델별로 제공될 펌웨어의 메타데이터를 포함하는 파일 분배 테이블 및 모델별로 제공될 애플리케이션 파일의 메타데이터를 포함하는 파일 분배 테이블 중에서 하나 이상을 포함할 수 있다.
또한, 파일 분배 테이블은 모델별로 할당된(또는 사전에 매핑된) 데이터 채널 주소를 더 포함할 수 있다. 데이터 채널 주소는 데이터(예를 들어, 컨텐츠 등)를 전송하기 위한 채널 주소를 의미할 수 있다.
파일 관리 장치(100)는 모델별로 생성된 파일 분배 테이블을 포함하는 단일 패킷을 생성하고, 단일 패킷을 제어 채널 주소를 통해 복수의 단말들(200-1~200-n)에게 전송할 수 있다. 제어 채널 주소는 파일 관리 장치(100)와 복수의 단말들(200-1~200-n) 사이의 세션 관리 등을 위한 채널 주소를 의미할 수 있다.
복수의 단말들(200-1~200-n)은 제어 채널 주소를 통해 단일 패킷을 수신하고, 단일 패킷에서 자신의 해당 모델에 대응하는 파일 분배 테이블을 획득할 수 있다. 복수의 단말들(200-1~200-n)은 자신에게 제공될 파일, 즉 자신이 다운로드받아야 할 파일의 메타데이터를 획득하는 것이다.
파일 전송 프로세스는 복수의 종의 단말에 서로 다른 파일을 전송하는 것으로, 다음과 같이 수행될 수 있다.
파일 관리 장치(100)는 단말의 모델별로 제공될 파일을 분류할 수 있다. 예를 들어, 파일 관리 장치(100)는 단말의 모델별로 제공될 펌웨어 및 애플리케이션 파일을 모델별로 분류할 수 있다.
파일 관리 장치(100)는 단말의 모델별로 제공될 파일을 포함하는 패킷을 모델별로 생성하고, 모델별로 생성된 패킷 각각을 대응하는 데이터 채널 주소를 이용하여 복수의 단말들(200-1~200-n)에게 전송할 수 있다.
복수의 단말들(200-1~200-n)은 자신의 해당 모델에 대응하는 파일 분배 테이블에 포함된 데이터 채널 주소를 이용하여 해당 모델에 제공될 파일이 포함된 패킷을 수신할 수 있다. 복수의 단말들(200-1~200-n)은 제어 채널 주소를 통해 모델별로 할당된 데이터 채널 주소를 획득하고, 획득된 데이터 채널 주소를 이용하여 자신의 해당 모델에 제공될 파일을 다운로드할 수 있는 것이다.
파일의 버전 업데이트 프로세스는 파일의 버전 업데이트 발생 시 파일의 버전을 업데이트하여 단말에 알리기 위한 것으로, 상술한 파일 정보 전달 프로세스 및 파일 전송 프로세스가 수행된 이후에 수행되며 다음과 같이 수행될 수 있다.
파일 관리 장치(100)는 하나 이상의 임의의 모델에 제공될 파일이 새로운 버전으로 업데이트되면 이전 버전의 파일의 분배 테이블을 새로운 버전의 파일의 파일 분배 테이블로 업데이트할 수 있다. 파일 관리 장치(100)는 새로운 버전의 파일에 응답하여 단일 패킷에서 이전 버전의 파일의 파일 분배 테이블을 새로운 버전의 파일의 파일 분배 테이블로 업데이트하는 것이다. 즉, 파일 관리 장치(100)는 기존 단일 패킷에서 이전 버전의 파일의 파일 분배 테이블을 새로운 버전의 파일의 파일 분배 테이블로 교체하는 것이다.
파일 관리 장치(100)는 새로운 버전의 파일의 파일 분배 테이블로 업데이트된 단일 패킷을 제어 채널 주소를 통해 복수의 단말들(200-1~200-n)로 전송할 수 있다.
복수의 단말들(200-1~200-n)은 업데이트된 단일 패킷을 제어 채널 주소로 수신하고, 업데이트된 단일 패킷에서 자신의 해당 모델에 대응하는 파일 분배 테이블을 획득할 수 있다. 다음으로, 복수의 단말들(200-1~200-n)은 파일 분배 테이블에 포함된 새로운 버전의 메타데이터에 기초하여 해당 모델에 제공될 파일이 새로운 버전으로 업데이트되었는지 확인할 수 있다.
복수의 단말들(200)은 해당 모델에 제공될 파일이 새로운 버전으로 업데이트된 경우, 예를 들어, 해당 모델에 제공될 새로운 버전의 메타데이터에 응답하여 해당 모델에 대응하는 데이터 채널 주소를 통해 해당 모델에 제공될 파일의 새로운 버전을 다운로드할 수 있다.
파일 관리 장치(100)는 일대다 전송 방식을 이용하여 인터넷 백본(Internet backbone)의 트래픽 부하를 낮출 수 있고, 일대다 전송 환경에서 파일 전송에 적합한 FLUTE 프로토콜을 이용함으로써 백본아 부하 없이 동시에 대량의 단말에 OTA 업그레이드를 가능하게 할 수 있다. 또한, 파일 관리 장치(100)는 파일의 메타데이터를 통해 파일 수신 대상을 선별할 수 있으며, 파일 버전 업데이트도 즉시 반영할 수 있다.
이하에서는 도 3 내지 도 5를 참조하여 파일 정보 전달 프로세스, 파일 전송 프로세스, 및 파일의 버전 업데이트 프로세스를 상세히 설명하도록 한다. 설명의 편의를 위해 일대다 전송 방식 중에서 멀티캐스트 전송 방식이 이용되는 것으로 가정한다.
도 3은 파일 정보 전달 프로세스의 일 예를 설명하기 위한 도면이다.
파일 관리 장치(100)는 스케줄 생성기(110) 및 송출기(130)를 포함할 수 있다.
운영자는 파일 및 메타데이터를 파일 관리 장치(100)에 입력할 수 있다. 파일은 펌웨어 및 애플리케이션 파일을 포함할 수 있다.
스케줄 생성기(110)는 단말의 모델별(예를 들어, A 타입, B 타입, C 타입 등)로 모델에 해당하는 펌웨어 분배 테이블(310, 330, 350) 및 애플리케이션 분배 테이블(320, 340, 360)을 각각 생성할 수 있다. 펌웨어 분배 테이블(310) 및 애플리케이션 분배 테이블(320)는 단말의 A 타입에 해당하는 것이고, 펌웨어 분배 테이블(330) 및 애플리케이션 분배 테이블(340)는 단말의 B 타입에 해당하는 것이고, 펌웨어 분배 테이블(350) 및 애플리케이션 분배 테이블(360)는 단말의 타입에 해당하는 것이다.
펌웨어 분배 테이블(310, 330, 350) 및 애플리케이션 분배 테이블(320, 340, 360)은 모델별로 제공될 파일의 메타데이터와 모델별로 할당된 멀티캐스트 주소를 포함할 수 있다. 모델별로 할당된 멀티캐스트 주소는 모델별로 사전에 매핑된 것일 수 있다.
송출기(130)는 스케줄 생성기(110)로부터 생성된 파일 분배 테이블들(310~360)을 수신하고, 파일 분배 테이블들(310~360)을 포함하는 FLUTE 규격의 단일 패킷(370)을 생성할 수 있다. 송출기(130)는 단일 패킷(370)을 멀티캐스트 제어 채널 주소(예를 들어, 234.5.6.7)로 전송할 수 있다.
단말들(200-1~200-3)은 멀티캐스트 제어 채널에 항상 참여(join)한 상태를 유지하며, 멀티캐스트 제어 채널을 통해 단일 패킷(370)을 수신하고, 단일 패킷(370)에서 자신의 모델에 맞는 파일 분배 테이블을 획득할 수 있다.
A 타입의 단말(200-1)은 자신의 모델명에 기초하여 단일 패킷(370)에서 펌웨어 분배 테이블(310) 및 애플리케이션 분배 테이블(320)을 파싱하여 다운로드받아야 할 펌웨어의 메타데이터 및 애플리케이션의 메타데이터를 획득할 수 있다. A 타입의 단말(200-1)은 파일 분배 테이블(310, 320)에서 A타입에 할당된 멀티캐스트 주소도 획득할 수 있다.
B 타입의 단말(200-2)은 자신의 모델명에 기초하여 단일 패킷(370)에서 펌웨어 분배 테이블(330) 및 애플리케이션 분배 테이블(340)을 파싱하여 다운로드받아야 할 펌웨어의 메타데이터 및 애플리케이션의 메타데이터를 획득할 수 있다. B 타입의 단말(200-2)은 파일 분배 테이블(330, 340)에서 B타입에 할당된 멀?J캐스트 주소도 획득할 수 있다.
C 타입의 단말(200-3)은 자신의 모델명에 기초하여 단일 패킷(370)에서 펌웨어 분배 테이블(350) 및 애플리케이션 분배 테이블(360)을 파싱하여 다운로드받아야 할 펌웨어의 메타데이터 및 애플리케이션의 메타데이터를 획득할 수 있다. C 타입의 단말(200-3)은 파일 분배 테이블(350, 360)에서 A타입에 할당된 멀티캐스트 주소도 획득할 수 있다.
도 4는 파일 전송 프로세스의 일 예를 설명하기 위한 도면이다.
스케줄 생성기(110)는 단말의 모델별(예를 들어, A 타입, B 타입, C 타입 등)로 제공될 펌웨어(310, 330, 350) 및 애플리케이션 파일(320, 340, 360)을 모델별로 분류하여 송출기(130)로 출력할 수 있다.
펌웨어(410) 및 애플리케이션 파일(420)는 단말의 A 타입에 해당하는 것이고, 펌웨어(430) 및 애플리케이션 파일(440)는 단말의 B 타입에 해당하는 것이고, 펌웨어(450) 및 애플리케이션 파일(460)는 단말의 C 타입에 해당하는 것이다.
스케줄 생성기(110)는 모델별로 할당된 멀티캐스트 주소를 포함하는 멀티캐스트 주소 매핑 정보를 함께 송출기(130)로 출력할 수 있다.
송출기(130)는 멀티캐스트 주소 매핑 정보에 기초하여 모델별로 제공될 파일을 포함하는 FLUTE 규격의 패킷(471, 473, 475)을 모델별로 생성할 수 있다. 제1 패킷(471)은 단말의 A 타입에 제공될 펌웨어(410) 및 애플리케이션 파일(420)을 포함하고, 제2 패킷(473)은 단말의 B 타입에 제공될 펌웨어(430) 및 애플리케이션 파일(440)을 포함하고, 제3 패킷(475)은 C 타입에 제공될 펌웨어(450) 및 애플리케이션 파일(460)을 포함할 수 있다.
송출기(130)는 제1 패킷(471)을 단말의 A 타입에 할당된 제1 멀티캐스트 주소(예를 들어, 234.5.6.8)로 전송하고, 제2 패킷(473)을 단말의 B 타입에 할당된 제2 멀티캐스트 주소(예를 들어, 234.5.6.9)로 전송하고, 제3 패킷(475)을 단말의 C 타입에 할당된 제3 멀티캐스트 주소(예를 들어, 234.5.6.10)로 전송할 수 있다.
단말들(200-1~200-3)은 멀티캐스트 채널 주소를 통해 모델별로 할당된 멀티캐스트 주소를 이미 알고 있으며, 멀티캐스트 주소를 통해 모델별로 제공될 파일을 다운로드할 수 있다.
A 타입의 단말(200-1)은 A 타입에 할당된 제1 멀티캐스트 주소를 이용하여 제1 패킷(471)을 수신하고, 펌웨어(410) 및 애플리케이션 파일(420)을 설치할 수 있다.
B 타입의 단말(200-2)은 B 타입에 할당된 제2 멀티캐스트 주소를 이용하여 제2 패킷(473)을 수신하고, 펌웨어(430) 및 애플리케이션 파일(440)을 설치할 수 있다.
C 타입의 단말(200-3)은 C타입에 할당된 제3 멀티캐스트 주소를 이용하여 제3 패킷(475)을 수신하고, 펌웨어(450) 및 애플리케이션 파일(460)을 설치할 수 있다.
도 5는 파일의 버전 업데이트 프로세스의 일 예를 설명하기 위한 도면이다.
운영자는 하나 이상의 임의의 모델에 제공될 파일의 업데이트 발생시 새로운 버전의 파일 및 메타데이터를 파일 관리 장치(100)에 입력할 수 있다. 도 5에서는 설명의 편의를 위해 단말의 A 타입에 제공될 파일에 대해서 업데이트가 발생한 것으로 가정한다.
스케줄 생성기(110)는 단말의 A 타입에 제공될 새로운 버전의 파일에 응답하여 새로운 버전의 펌웨어의 펌웨어 분배 테이블(510) 및 애플리케이션 파일의 애플리케이션 분배 테이블(520)을 생성할 수 있다. 펌웨어 분배 테이블(510)는 펌웨어 분배 테이블(310)에서 이전 버전의 메타데이터가 새로운 버전의 메타데이터로 업데이트된 것이고, 애플리케이션 분배 테이블(520)은 애플리케이션 분배 테이블(320)에서 이전 버전의 메타데이터가 새로운 버전의 메타데이터로 업데이트된 것일 수 있다. 이때, 펌웨어 분배 테이블(510) 및 애플리케이션 분배 테이블(520)은 이전 버전의 펌웨어 분배 테이블(310) 및 애플리케이션 분배 테이블(320)에 포함된 멀티캐스트 주소를 동일하게 포함할 수 있다.
송출기(130)는 스케줄 생성기(110)로부터 펌웨어 분배 테이블(510) 및 애플리케이션 분배 테이블(520)을 수신하고, 펌웨어 분배 테이블(510) 및 애플리케이션 분배 테이블(520) 각각의 메타데이터에서 버전 정보(예를 들어, 업데이트 버전 정보)를 확인하고 송출 정보 변경을 인지할 수 있다. 송출기(130)는 송출기(130)는 단일 패킷(370)에서 이전 버전의 펌웨어 분배 테이블(310) 및 애플리케이션 분배 테이블(320)을 새로운 버전의 펌웨어 분배 테이블(510) 및 애플리케이션 분배 테이블(520)로 업데이트(예를 들어, 교체)할 수 있다.
송출기(130)는 업데이트된 단일 패킷(370)을 멀티캐스트 제어 채널 주소(예를 들어, 234.5.6.7)로 전송할 수 있다.
단말들(200-1~200-3)은 멀티캐스트 제어 채널에 항상 참여(join)한 상태를 유지하며, 멀티캐스트 제어 채널을 통해 단일 패킷(370)을 수신하고, 단일 패킷(370)에서 자신의 모델에 맞는 파일 분배 테이블을 획득할 수 있다.
단말들(200-1~200-3)은 자신의 해당 모델에 대응하는 파일 분배 테이블에 포함된 메타데이터에 기초하여 해당 모델에 제공될 파일이 새로운 버전으로 업데이트되었는지 확인할 수 있다.
A 타입의 단말(200-1)은 자신의 모델명에 기초하여 단일 패킷(370)에서 펌웨어 분배 테이블(310) 및 애플리케이션 분배 테이블(320)을 파싱하여 메타데이터를 획득하고, 해당 모델에 제공될 펌웨어 및 애플리케이션이 새로운 버전으로 업데이트된 것을 확인할 수 있다. A 타입의 단말(200-1)은 A 타입에 할당된 제1 멀티캐스트 주소를 이용하여 새로운 버전의 펌웨어 및 애플리케이션 파일을 다운로드받을 수 있다.
도 6은 파일 관리 장치의 일 예의 개략적인 블록도이다.
파일 관리 장치(600)는 도 1 내지 도 5를 참조하여 설명한 파일 관리 장치(100)를 의미한다. 파일 관리 장치(600)는 도 1 내지 도 5를 참조하여 설명한 파일 관리 방법, 즉 파일 정보 전달 프로세스, 파일 전송 프로세스, 및 파일의 버전 업데이트 프로세스에 관한 동작을 수행할 수 있다. 파일 관리 장치(600)는 메모리(610) 및 프로세서(630)을 포함할 수 있다. 도 3 내지 도 5에 도시된 스케줄 생성기(110) 및 송출기(130)의 동작은 프로세서(630)를 통해 수행될 수 있다. 스케줄 생성기(110) 및 송출기(130)는 별도의 하드웨어로 구현될 수도 있지만, 프로세서(630)가 수행하는 동작을 기능에 따라 분류된 구성으로 이해될 수도 있다.
메모리(610)는 프로세서(630)에 의해 실행가능한 인스트럭션들(또는 프로그램)을 저장할 수 있다. 예를 들어, 인스트럭션들은 프로세서(630)의 동작 및/또는 프로세서(630)의 각 구성의 동작을 실행하기 위한 인스트럭션들을 포함할 수 있다.
프로세서(630)는 메모리(610)에 저장된 데이터를 처리할 수 있다. 프로세서(630)는 메모리(610)에 저장된 컴퓨터로 읽을 수 있는 코드(예를 들어, 소프트웨어) 및 프로세서(630)에 의해 유발된 인스트럭션(instruction)들을 실행할 수 있다.
프로세서(630)는 목적하는 동작들(desired operations)을 실행시키기 위한 물리적인 구조를 갖는 회로를 가지는 하드웨어로 구현된 데이터 처리 장치일 수 있다. 예를 들어, 목적하는 동작들은 프로그램에 포함된 코드(code) 또는 인스트럭션들(instructions)을 포함할 수 있다.
예를 들어, 하드웨어로 구현된 데이터 처리 장치는 마이크로프로세서(microprocessor), 중앙 처리 장치(central processing unit), 프로세서 코어(processor core), 멀티-코어 프로세서(multi-core processor), 멀티프로세서(multiprocessor), ASIC(Application-Specific Integrated Circuit), FPGA(Field Programmable Gate Array)를 포함할 수 있다.
프로세서(630)에 의해 수행되는 동작은 도 1 내지 도 5를 참조하여 설명한 파일 정보 전달 프로세스, 파일 전송 프로세스, 및 파일의 버전 업데이트 프로세스에서의 파일 관리 장치(100)의 동작과 실질적으로 동일하다. 이에, 상세한 설명은 생략하도록 한다.
도 7은 단말의 일 예의 개략적인 블록도이다.
단말(700)는 도 1 내지 도 5를 참조하여 설명한 단말(200-1~200-n)을 의미한다. 단말(700)는 도 1 내지 도 5를 참조하여 설명한 파일 관리 방법, 즉 파일 정보 전달 프로세스, 파일 전송 프로세스, 및 파일의 버전 업데이트 프로세스에 관한 동작을 수행할 수 있다. 단말(700)는 메모리(710) 및 프로세서(730)을 포함할 수 있다.
메모리(710)는 프로세서(730)에 의해 실행가능한 인스트럭션들(또는 프로그램)을 저장할 수 있다. 예를 들어, 인스트럭션들은 프로세서(730)의 동작 및/또는 프로세서(730)의 각 구성의 동작을 실행하기 위한 인스트럭션들을 포함할 수 있다.
또한, 메모리(610)는 도 1 내지 도 5에서 설명된 파일 분배 테이블 및 파일을 저장할 수 있다.
프로세서(730)는 메모리(710)에 저장된 데이터를 처리할 수 있다. 프로세서(730)는 메모리(710)에 저장된 컴퓨터로 읽을 수 있는 코드(예를 들어, 소프트웨어) 및 프로세서(730)에 의해 유발된 인스트럭션(instruction)들을 실행할 수 있다.
프로세서(730)는 목적하는 동작들(desired operations)을 실행시키기 위한 물리적인 구조를 갖는 회로를 가지는 하드웨어로 구현된 데이터 처리 장치일 수 있다. 예를 들어, 목적하는 동작들은 프로그램에 포함된 코드(code) 또는 인스트럭션들(instructions)을 포함할 수 있다.
예를 들어, 하드웨어로 구현된 데이터 처리 장치는 마이크로프로세서(microprocessor), 중앙 처리 장치(central processing unit), 프로세서 코어(processor core), 멀티-코어 프로세서(multi-core processor), 멀티프로세서(multiprocessor), ASIC(Application-Specific Integrated Circuit), FPGA(Field Programmable Gate Array)를 포함할 수 있다.
프로세서(730)에 의해 수행되는 동작은 도 1 내지 도 5를 참조하여 설명한 파일 정보 전달 프로세스, 파일 전송 프로세스, 및 파일의 버전 업데이트 프로세스에서의 단말(200-1~200-n)의 동작과 실질적으로 동일하다. 이에, 상세한 설명은 생략하도록 한다.
이상에서 설명된 실시예들은 하드웨어 구성요소, 소프트웨어 구성요소, 및/또는 하드웨어 구성요소 및 소프트웨어 구성요소의 조합으로 구현될 수 있다. 예를 들어, 실시예들에서 설명된 장치, 방법 및 구성요소는, 예를 들어, 프로세서, 콘트롤러, ALU(arithmetic logic unit), 디지털 신호 프로세서(digital signal processor), 마이크로컴퓨터, FPGA(field programmable gate array), PLU(programmable logic unit), 마이크로프로세서, 또는 명령(instruction)을 실행하고 응답할 수 있는 다른 어떠한 장치와 같이, 범용 컴퓨터 또는 특수 목적 컴퓨터를 이용하여 구현될 수 있다. 처리 장치는 운영 체제(OS) 및 상기 운영 체제 상에서 수행되는 소프트웨어 애플리케이션을 수행할 수 있다. 또한, 처리 장치는 소프트웨어의 실행에 응답하여, 데이터를 접근, 저장, 조작, 처리 및 생성할 수도 있다. 이해의 편의를 위하여, 처리 장치는 하나가 사용되는 것으로 설명된 경우도 있지만, 해당 기술분야에서 통상의 지식을 가진 자는, 처리 장치가 복수 개의 처리 요소(processing element) 및/또는 복수 유형의 처리 요소를 포함할 수 있음을 알 수 있다. 예를 들어, 처리 장치는 복수 개의 프로세서 또는 하나의 프로세서 및 하나의 컨트롤러를 포함할 수 있다. 또한, 병렬 프로세서(parallel processor)와 같은, 다른 처리 구성(processing configuration)도 가능하다.
소프트웨어는 컴퓨터 프로그램(computer program), 코드(code), 명령(instruction), 또는 이들 중 하나 이상의 조합을 포함할 수 있으며, 원하는 대로 동작하도록 처리 장치를 구성하거나 독립적으로 또는 결합적으로(collectively) 처리 장치를 명령할 수 있다. 소프트웨어 및/또는 데이터는, 처리 장치에 의하여 해석되거나 처리 장치에 명령 또는 데이터를 제공하기 위하여, 어떤 유형의 기계, 구성요소(component), 물리적 장치, 가상 장치(virtual equipment), 컴퓨터 저장 매체 또는 장치, 또는 전송되는 신호 파(signal wave)에 영구적으로, 또는 일시적으로 구체화(embody)될 수 있다. 소프트웨어는 네트워크로 연결된 컴퓨터 시스템 상에 분산되어서, 분산된 방법으로 저장되거나 실행될 수도 있다. 소프트웨어 및 데이터는 컴퓨터 판독 가능 기록 매체에 저장될 수 있다.
실시예에 따른 방법은 다양한 컴퓨터 수단을 통하여 수행될 수 있는 프로그램 명령 형태로 구현되어 컴퓨터 판독 가능 매체에 기록될 수 있다. 컴퓨터 판독 가능 매체는 프로그램 명령, 데이터 파일, 데이터 구조 등을 단독으로 또는 조합하여 포함할 수 있으며 매체에 기록되는 프로그램 명령은 실시예를 위하여 특별히 설계되고 구성된 것들이거나 컴퓨터 소프트웨어 당업자에게 공지되어 사용 가능한 것일 수도 있다. 컴퓨터 판독 가능 기록 매체의 예에는 하드 디스크, 플로피 디스크 및 자기 테이프와 같은 자기 매체(magnetic media), CD-ROM, DVD와 같은 광기록 매체(optical media), 플롭티컬 디스크(floptical disk)와 같은 자기-광 매체(magneto-optical media), 및 롬(ROM), 램(RAM), 플래시 메모리 등과 같은 프로그램 명령을 저장하고 수행하도록 특별히 구성된 하드웨어 장치가 포함된다. 프로그램 명령의 예에는 컴파일러에 의해 만들어지는 것과 같은 기계어 코드뿐만 아니라 인터프리터 등을 사용해서 컴퓨터에 의해서 실행될 수 있는 고급 언어 코드를 포함한다.
위에서 설명한 하드웨어 장치는 실시예의 동작을 수행하기 위해 하나 또는 복수의 소프트웨어 모듈로서 작동하도록 구성될 수 있으며, 그 역도 마찬가지이다.
이상과 같이 실시예들이 비록 한정된 도면에 의해 설명되었으나, 해당 기술분야에서 통상의 지식을 가진 자라면 이를 기초로 다양한 기술적 수정 및 변형을 적용할 수 있다. 예를 들어, 설명된 기술들이 설명된 방법과 다른 순서로 수행되거나, 및/또는 설명된 시스템, 구조, 장치, 회로 등의 구성요소들이 설명된 방법과 다른 형태로 결합 또는 조합되거나, 다른 구성요소 또는 균등물에 의하여 대치되거나 치환되더라도 적절한 결과가 달성될 수 있다.
그러므로, 다른 구현들, 다른 실시예들 및 특허청구범위와 균등한 것들도 후술하는 특허청구범위의 범위에 속한다.

Claims (24)

  1. 단말의 모델별로 제공될 파일의 메타데이터를 포함하는 파일 분배 테이블을 상기 모델별로 생성하는 단계;
    상기 모델별로 생성된 파일 분배 테이블을 포함하는 단일 패킷을 생성하여 제어 채널 주소로 전송하는 단계;
    상기 단말의 모델별로 제공될 파일을 포함하는 패킷을 상기 모델별로 생성하는 단계; 및
    상기 모델별로 생성된 패킷 각각을 대응하는 데이터 채널 주소로 전송하는 단계
    를 포함하는, 파일 관리 방법.
  2. 제1항에 있어서,
    새로운 버전의 파일에 응답하여 상기 단일 패킷에서 이전 버전의 파일의 파일 분배 테이블을 상기 새로운 버전의 파일의 파일 분배 테이블로 업데이트하는 단계; 및
    상기 새로운 버전의 파일 분배 테이블로 업데이트된 상기 단일 패킷을 상기 제어 채널 주소로 전송하는 단계
    를 더 포함하는, 파일 관리 방법.
  3. 제2항에 있어서,
    상기 업데이트하는 단계는,
    상기 이전 버전의 파일의 파일 분배 테이블에서 상기 이전 버전의 메타데이터를 상기 새로운 버전의 메타데이터로 업데이트하여 상기 새로운 버전의 파일의 파일 분배 테이블을 생성하는 단계
    를 포함하는, 파일 관리 방법.
  4. 제1항에 있어서,
    상기 모델별로 생성된 파일 분배 테이블은,
    상기 모델별로 제공될 펌웨어의 메타데이터를 포함하는 파일 분배 테이블; 및
    상기 모델별로 제공될 애플리케이션 파일의 메타데이터를 포함하는 파일 분배 테이블
    중에서 하나 이상을 포함하는, 파일 관리 방법.
  5. 제1항에 있어서,
    상기 파일 분배 테이블은,
    상기 모델별로 할당된 데이터 채널 주소를 더 포함하는, 파일 관리 방법.
  6. 제1항에 있어서,
    상기 단일 패킷 및 상기 모델별로 생성된 패킷을 FLUTE 프로토콜을 이용하여 일대다 전송 방식으로 전송하는 것인, 파일 관리 방법.
  7. 제6항에 있어서,
    상기 일대다 전송 방식은,
    멀티캐스트 전송 방식 및 브로드캐스트 전송 방식 중에서 어느 하나인 것인, 파일 관리 방법.
  8. 단말의 모델별로 제공될 파일의 메타데이터 및 상기 모델별로 할당된 데이터 채널 주소를 포함하는 파일 분배 테이블을 상기 모델별로 생성하는 단계;
    상기 모델별로 생성된 파일 분배 테이블을 포함하는 단일 패킷을 생성하는 단계; 및
    상기 단일 패킷을 제어 채널 주소로 일대다 전송 방식으로 하나 이상의 단말로 전송하는 단계
    를 포함하는, 파일 관리 방법.
  9. 단말의 모델별로 제공될 파일의 메타데이터 및 상기 모델별로 할당된 데이터 채널 주소를 포함하는 파일 분배 테이블이 상기 모델별로 포함된 단일 패킷을 제어 채널 주소를 통해 수신하는 단계;
    상기 단일 패킷에서 해당 모델에 대응하는 파일 분배 테이블을 획득하는 단계; 및
    상기 해당 모델에 대응하는 파일 분배 테이블에 포함된 데이터 채널 주소를 이용하여 상기 해당 모델에 제공될 파일이 포함된 패킷을 수신하는 단계
    를 포함하는, 파일 관리 방법.
  10. 제9항에 있어서,
    하나 이상의 임의의 모델에 제공될 새로운 버전의 파일의 파일 분배 테이블로 업데이트된 상기 단일 패킷을 상기 제어 채널 주소로 수신하는 단계; 및
    상기 해당 모델에 대응하는 파일 분배 테이블에서 상기 해당 모델에 제공될 파일이 새로운 버전으로 업데이트되었는지 확인하는 단계
    를 더 포함하는, 파일 관리 방법.
  11. 제10항에 있어서,
    상기 해당 모델에 제공될 파일의 새로운 버전의 메타데이터에 응답하여 상기 해당 모델에 대응하는 데이터 채널 주소를 통해 상기 해당 모델에 제공될 파일의 새로운 버전을 다운로드하는 단계
    를 더 포함하는, 파일 관리 방법.
  12. 제10항에 있어서,
    이전 버전의 파일의 파일 분배 테이블에서 상기 이전 버전의 메타데이터가 새로운 버전의 메타데이터로 업데이트되는 것인, 파일 관리 방법.
  13. 제9항에 있어서,
    상기 모델별로 포함된 파일 분배 테이블은,
    상기 모델별로 제공될 펌웨어의 메타데이터를 포함하는 파일 분배 테이블; 및
    상기 모델별로 제공될 애플리케이션 파일의 메타데이터를 포함하는 파일 분배 테이블
    중에서 하나 이상을 포함하는, 파일 관리 방법.
  14. 제9항에 있어서,
    상기 단일 패킷 및 상기 해당 모델에 제공될 파일이 포함된 패킷은 FLUTE 프로토콜을 이용하여 일대다 전송 방식으로 수신되는 것인, 파일 관리 방법.
  15. 제14항에 있어서,
    상기 일대다 전송 방식은,
    멀티캐스트 전송 방식 및 브로드캐스트 전송 방식 중 어느 하나인 것인, 파일 관리 방법.
  16. 하드웨어와 결합되어 제1항 내지 제15항 중 어느 하나의 항의 방법을 실행시키기 위하여 컴퓨터 판독 가능한 기록매체에 저장된 컴퓨터 프로그램.
  17. 하나 이상의 인스트럭션을 저장하는 메모리; 및
    상기 인스트럭션을 실행시키기 위한 프로세서
    를 포함하고,
    상기 인스트럭션이 실행될 때, 상기 프로세서는,
    단말의 모델별로 제공될 파일의 메타데이터를 포함하는 파일 분배 테이블을 상기 모델별로 생성하고, 모델별로 생성된 파일 분배 테이블을 포함하는 단일 패킷을 제어 채널 주소로 전송하고, 상기 단말의 모델별로 제공될 파일을 포함하는 패킷을 상기 모델별로 생성하고, 상기 모델별로 생성된 패킷 각각을 대응하는 데이터 채널 주소로 전송하는, 파일 관리 장치.
  18. 제17항에 있어서,
    상기 프로세서는,
    새로운 버전의 파일에 응답하여 상기 단일 패킷에서 이전 버전의 파일의 파일 분배 테이블을 상기 새로운 버전의 파일의 파일 분배 테이블로 업데이트하고, 상기 새로운 버전의 파일 분배 테이블로 업데이트된 상기 단일 패킷을 상기 제어 채널 주소로 전송하는, 파일 관리 장치.
  19. 제18항에 있어서,
    상기 프로세서는,
    상기 이전 버전의 파일의 파일 분배 테이블에서 상기 이전 버전의 메타데이터를 상기 새로운 버전의 메타데이터로 업데이트하여 상기 새로운 버전의 파일의 파일 분배 테이블을 생성하는, 파일 관리 장치.
  20. 제17항에 있어서,
    상기 파일 분배 테이블은,
    상기 모델별로 할당된 데이터 채널 주소를 더 포함하는, 파일 관리 장치.
  21. 하나 이상의 인스트럭션을 저장하는 메모리; 및
    상기 인스트럭션을 실행시키기 위한 프로세서
    를 포함하고,
    상기 인스트럭션이 실행될 때, 상기 프로세서는,
    단말의 모델별로 제공될 파일의 메타데이터 및 상기 모델별로 할당된 데이터 채널 주소를 포함하는 파일 분배 테이블이 상기 모델별로 포함된 단일 패킷을 제어 채널 주소를 통해 수신하고, 상기 단일 패킷에서 해당 모델에 대응하는 파일 분배 테이블을 획득하고, 상기 해당 모델에 대응하는 파일 분배 테이블에 포함된 데이터 채널 주소를 이용하여 상기 해당 모델에 제공될 파일이 포함된 패킷을 수신하는, 단말.
  22. 제21항에 있어서,
    상기 프로세서는,
    하나 이상의 임의의 모델에 제공될 새로운 버전의 파일의 파일 분배 테이블로 업데이트된 상기 단일 패킷을 상기 제어 채널 주소로 수신하고, 상기 해당 모델에 대응하는 파일 분배 테이블에서 상기 해당 모델에 제공될 파일이 새로운 버전으로 업데이트되었는지 확인하는, 단말.
  23. 제22항에 있어서,
    상기 프로세서는,
    상기 해당 모델에 제공될 파일의 새로운 버전의 메타데이터에 응답하여 상기 해당 모델에 대응하는 데이터 채널 주소를 통해 상기 해당 모델에 제공될 파일의 새로운 버전을 다운로드하는, 단말.
  24. 제22항에 있어서,
    이전 버전의 파일의 파일 분배 테이블에서 상기 이전 버전의 메타데이터가 새로운 버전의 메타데이터로 업데이트되는 것인, 단말.
KR1020200141080A 2020-10-28 2020-10-28 단말의 개선을 위한 파일 관리 방법 및 이를 수행하는 장치들 KR102448146B1 (ko)

Priority Applications (1)

Application Number Priority Date Filing Date Title
KR1020200141080A KR102448146B1 (ko) 2020-10-28 2020-10-28 단말의 개선을 위한 파일 관리 방법 및 이를 수행하는 장치들

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
KR1020200141080A KR102448146B1 (ko) 2020-10-28 2020-10-28 단말의 개선을 위한 파일 관리 방법 및 이를 수행하는 장치들

Publications (2)

Publication Number Publication Date
KR20220056472A KR20220056472A (ko) 2022-05-06
KR102448146B1 true KR102448146B1 (ko) 2022-09-28

Family

ID=81584394

Family Applications (1)

Application Number Title Priority Date Filing Date
KR1020200141080A KR102448146B1 (ko) 2020-10-28 2020-10-28 단말의 개선을 위한 파일 관리 방법 및 이를 수행하는 장치들

Country Status (1)

Country Link
KR (1) KR102448146B1 (ko)

Citations (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR102071236B1 (ko) * 2018-10-26 2020-01-30 (주)엔텔스 IoT 플랫폼을 이용한 서비스 개발용 UI 제공 방법 및 IoT 플랫폼 장치

Family Cites Families (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR100469428B1 (ko) * 2002-06-29 2005-02-02 엘지전자 주식회사 이동통신 단말기의 파일 다운로드 방법
KR101843367B1 (ko) * 2011-08-24 2018-03-29 엘지전자 주식회사 애플리케이션 제공 방법, 애플리케이션 다운로드 방법 및 이를 적용한 서버 및 단말기
KR20150007146A (ko) * 2013-07-10 2015-01-20 현대중공업 주식회사 소프트웨어 배포 방법 및 이를 수행하는 소프트웨어 배포 서버

Patent Citations (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR102071236B1 (ko) * 2018-10-26 2020-01-30 (주)엔텔스 IoT 플랫폼을 이용한 서비스 개발용 UI 제공 방법 및 IoT 플랫폼 장치

Also Published As

Publication number Publication date
KR20220056472A (ko) 2022-05-06

Similar Documents

Publication Publication Date Title
EP3758293A1 (en) Service upgrade management method, apparatus, and storage medium
RU2421785C2 (ru) Автоматизированное управление драйверами устройств
US11249744B2 (en) Application deployment method, apparatus, and system
US9451012B1 (en) Heterogeneous cloud processing utilizing consumer devices
CN110471692B (zh) 终端程序的空中升级方法、装置、设备及存储介质
US10404568B2 (en) Agent manager for distributed transaction monitoring system
US9456017B2 (en) System and method for a connector being able to adapt to newer features introduced to a messaging provider with only configuration changes
JP2016508322A (ja) 広告処理方法及び装置
CN111459511B (zh) 应用程序的下载方法、装置及电子设备
WO2016058519A1 (en) Physical switch initialization using representational state transfer services
US20230300406A1 (en) Methods for media streaming content preparation for an application provider in 5g networks
CN111885114B (zh) 网关中的应用程序接口模块的升级方法、设备及存储介质
CN111679837A (zh) 系统安装控制方法、控制系统及计算设备
US10761823B2 (en) Imposing a common build system for services from disparate sources
KR20180050001A (ko) 사물인터넷 기기의 펌웨어 업그레이드 시스템 및 방법
KR102448146B1 (ko) 단말의 개선을 위한 파일 관리 방법 및 이를 수행하는 장치들
JP2022535949A (ja) モデルファイルのディストリビューション方法、プラットホーム、システム、端末及び可読記憶媒体
US8893105B2 (en) Activation-based regulatory updates
US11252457B2 (en) Multimedia streaming and routing apparatus and operation method of the same
WO2023020071A1 (zh) 一种升级包的获取方法及智能设备
US20220164177A1 (en) Systems and methods for managing containerized applications on an edge device
CN112910956B (zh) 一种资源创建方法、装置及电子设备
CN113076128B (zh) 用于机器人配置的方法、装置、电子设备及存储介质
KR20190133132A (ko) 미디어 전송 제어 방법 및 이를 수행하는 네트워크 엔티티
CN112286552B (zh) 一种任务创建方法、装置、电子设备以及存储介质

Legal Events

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