KR100940178B1 - 무선 통신 장치의 현장 업그레이드형 소프트웨어 조직시스템 및 방법 - Google Patents
무선 통신 장치의 현장 업그레이드형 소프트웨어 조직시스템 및 방법 Download PDFInfo
- Publication number
- KR100940178B1 KR100940178B1 KR1020047000719A KR20047000719A KR100940178B1 KR 100940178 B1 KR100940178 B1 KR 100940178B1 KR 1020047000719 A KR1020047000719 A KR 1020047000719A KR 20047000719 A KR20047000719 A KR 20047000719A KR 100940178 B1 KR100940178 B1 KR 100940178B1
- Authority
- KR
- South Korea
- Prior art keywords
- symbol
- code
- code section
- section
- address table
- Prior art date
Links
- 238000004891 communication Methods 0.000 title claims abstract description 41
- 238000000034 method Methods 0.000 title claims abstract description 36
- 230000015654 memory Effects 0.000 claims abstract description 95
- 238000003860 storage Methods 0.000 claims description 15
- 238000004513 sizing Methods 0.000 claims description 2
- 238000013507 mapping Methods 0.000 claims 1
- 238000010586 diagram Methods 0.000 description 9
- 238000000280 densification Methods 0.000 description 8
- 230000008569 process Effects 0.000 description 7
- 230000005540 biological transmission Effects 0.000 description 5
- 238000012545 processing Methods 0.000 description 4
- 230000006870 function Effects 0.000 description 3
- 238000009434 installation Methods 0.000 description 3
- 230000007246 mechanism Effects 0.000 description 3
- 238000004519 manufacturing process Methods 0.000 description 2
- 230000009471 action Effects 0.000 description 1
- 238000004458 analytical method Methods 0.000 description 1
- 238000013459 approach Methods 0.000 description 1
- 230000006399 behavior Effects 0.000 description 1
- 230000015556 catabolic process Effects 0.000 description 1
- 238000006243 chemical reaction Methods 0.000 description 1
- 238000005056 compaction Methods 0.000 description 1
- 238000007405 data analysis Methods 0.000 description 1
- 238000012986 modification Methods 0.000 description 1
- 230000004048 modification Effects 0.000 description 1
- 230000008520 organization Effects 0.000 description 1
- 238000012546 transfer Methods 0.000 description 1
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F8/00—Arrangements for software engineering
- G06F8/60—Software deployment
- G06F8/65—Updates
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F8/00—Arrangements for software engineering
- G06F8/60—Software deployment
- G06F8/65—Updates
- G06F8/654—Updates using techniques specially adapted for alterable solid state memories, e.g. for EEPROM or flash memories
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements 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/44—Arrangements for executing specific programs
- G06F9/445—Program loading or initiating
- G06F9/44521—Dynamic linking or loading; Link editing at or after load time, e.g. Java class loading
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04W—WIRELESS COMMUNICATION NETWORKS
- H04W12/00—Security arrangements; Authentication; Protecting privacy or anonymity
- H04W12/08—Access security
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04W—WIRELESS COMMUNICATION NETWORKS
- H04W12/00—Security arrangements; Authentication; Protecting privacy or anonymity
- H04W12/30—Security of mobile devices; Security of mobile applications
- H04W12/35—Protecting application or service provisioning, e.g. securing SIM application provisioning
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04W—WIRELESS COMMUNICATION NETWORKS
- H04W8/00—Network data management
- H04W8/22—Processing or transfer of terminal data, e.g. status or physical capabilities
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04W—WIRELESS COMMUNICATION NETWORKS
- H04W8/00—Network data management
- H04W8/22—Processing or transfer of terminal data, e.g. status or physical capabilities
- H04W8/24—Transfer of terminal data
- H04W8/245—Transfer of terminal data from a network towards a terminal
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04W—WIRELESS COMMUNICATION NETWORKS
- H04W8/00—Network data management
- H04W8/18—Processing of user or subscriber data, e.g. subscribed services, user preferences or user profiles; Transfer of user or subscriber data
- H04W8/20—Transfer of user or subscriber data
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04W—WIRELESS COMMUNICATION NETWORKS
- H04W88/00—Devices specially adapted for wireless communication networks, e.g. terminals, base stations or access point devices
- H04W88/02—Terminal devices
Landscapes
- Engineering & Computer Science (AREA)
- Software Systems (AREA)
- Theoretical Computer Science (AREA)
- Computer Networks & Wireless Communication (AREA)
- Signal Processing (AREA)
- Computer Security & Cryptography (AREA)
- General Engineering & Computer Science (AREA)
- Databases & Information Systems (AREA)
- Physics & Mathematics (AREA)
- General Physics & Mathematics (AREA)
- Mobile Radio Communication Systems (AREA)
- Stored Programmes (AREA)
- Transceivers (AREA)
- Telephonic Communication Services (AREA)
- Communication Control (AREA)
- Sub-Exchange Stations And Push- Button Telephones (AREA)
- Test And Diagnosis Of Digital Computers (AREA)
- Information Transfer Between Computers (AREA)
- Circuits Of Receivers In General (AREA)
- Debugging And Monitoring (AREA)
- Two-Way Televisions, Distribution Of Moving Picture Or The Like (AREA)
- Selective Calling Equipment (AREA)
Abstract
무선 통신 장치에서 현장 업그레이드형 시스템 소프트웨어를 조직하기 위한 시스템 및 방법이 제공된다. 이 방법은, 시스템 소프트웨어 코드를 다수의 제 1 심벌 라이브러리들로 형성하고, 이때, 각각의 라이브러리는 관련 기능을 가진 심벌들로 구성되며, 다수의 제 1 심벌 라이브러리들을 다수의 제 2 코드 섹션들로 배열하여, 심벌 라이브러리가 코드 섹션의 시작점에서 시작하게 하며, 연속적으로 어드레싱되는 다수의 제 2 메모리 블록을 생성하고, 해당 코드 섹션으로 각각의 메모리 블록을 식별하며, 식별된 메모리 블록에 코드 섹션을 저장하고, 이때, 코드 섹션이 해당 시작 어드레스에서 시작되고, 코드 섹션 식별자를 해당 시작 어드레스와 상호참조시키는 코드 섹션 어드레스 표를 관리하며, 그리고 무선 장치 시스템 소프트웨어를 실행하는, 이상의 단계를 포함한다.
시스템 소프트웨어 코드를 다수의 제 1 심벌 라이브러리로 형성하는 것은 심벌 액세서 코드를 형성하는 과정을 포함한다. 다수의 제 1 심벌 라이브러리들을 다수의 제 2 코드 섹션으로 배열하는 것은 각각의 심벌을 코드 섹션 시작 어드레스로부터 각각 이격되도록 배열하는 과정을 포함하며, 제 1 코드 섹션에 심벌 액세서 코드를 배열하는 과정을 포함한다. 그후, 이 방법은, 심벌 식별자를 해당 오프셋 어드레스 및 해당 코드 섹션 식별자와 상호참조시키는 심벌 오프셋 어드레스 표를 관리하고, 그리고 심벌 액세서 코드 어드레스를 메모리의 제 1 위치에 저장하는 단계를 포함한다.
Description
본 발명은 무선 통신 장치에 관한 것으로서, 특히, 배포되어 현장에서 사용중인 무선 통신 장치의 시스템 소프트웨어를 에어 링크 인터페이스를 통해 업데이트시키고 변경을 가하는 방식으로 소프트웨어를 조직하는 시스템 및 방법에 관한 것이다.
당 분야에 이미 존재하는 전화에 대한 소프트웨어 업데이트를 배포하는 것은 아주 흔한 일이다. 이 업데이트들은 전화가 제작되어 공공에게 배포된 후 소프트웨어적으로 발견되는 문제점에 관한 것들일 수 있다. 일부 업데이트는 전화에 새로운 특징의 이용을 포함할 수 있고, 서비스 제공자에 의해 제공되는 서비스의 이용을 포함할 수도 있다. 또다른 업데이트는 지역적 문제를 포함할 수 있고, 캐리어에 관련된 문제일 수도 있다. 예를 들어, 어떤 영역에서, 캐리어의 네트워크 배치는 핸드셋 상에 에어 링크 인터페이스 조건을 부과할 수 있어서, 부적절한 채널 검색, 부적절한 통화 종료, 부적절한 오디오, 등처럼 예기치 않은 거동을 핸드셋이 나타낼 수 있다.
이러한 업데이트에 대한 전통적인 접근법은 무선 장치, 전화, 핸드셋 등으로 불리는 무선 통신 장치를 가장 가까운 캐리어 소매점/서비스센터에 리콜시키거나 이러한 변화 처리를 위해 제작자에게 리콜시키는 것이다. 이러한 업데이트에 관련된 비용은 비싸고 순이익을 잠식할 수 있다. 더욱이, 고객이 불편하고 짜증내기 쉽다. 가끔씩 실용적 해법은 고객에게 새 전화를 발급해주는 것이다.
무선 통신 장치 소프트웨어가 저렴하면서도 고객측면에서 편리하게 업그레이드될 수 있다면 바람직할 것이다.
상당한 시간동안 고객이 전화를 사용할 수 없는 불편함없이 무선 통신 장치 소프트웨어가 업그레이드될 수 있다면 바람직할 것이다.
무선 통신 장치 소프트웨어가 최소한의 기술 서비스 시간만으로, 서비스 센터에 통신 장치를 보낼 필요없이 업그레이드될 수 있다면 바람직할 것이다.
무선 장치 소프트웨어가 에어 링크 인터페이스를 통한 현장 변경이 가능하도록 조직될 수 있다면 바람직할 것이다.
무선 통신 장치 소프트웨어 업데이트는 가장 좋은 제품과 사용자 경험을 고객에게 제공한다. 사업상의 고비용 요인은 소프트웨어 업데이트를 위한 핸드셋 리콜을 포함한다. 이 업데이트는 사용자에게 추가적 서비스를 제공하기 위해 필요할 수도 있고, 제작 후 전화 사용시 발견되는 문제점을 해결하기 위해 필요할 수도 있다. 본 발명은 핸드셋 소프트웨어를 에어 링크 인터페이스를 통해 실용적으로 업그레이드할 수 있게 한다.
따라서, 무선 통신 장치에서 현장 업그레이드형 시스템 소프트웨어를 조직하기 위한 방법이 제공된다. 이 방법은, 시스템 소프트웨어를 다수의 제 1 심벌 라이브러리들로 형성하고, 이때, 각각의 라이브러리는 관련 기능을 가진 심벌들로 구성되며, 다수의 제 1 심벌 라이브러리들을 다수의 제 2 코드 섹션들로 배열하여, 심벌 라이브러리가 코드 섹션의 시작점에서 시작하게 하며, 연속적으로 어드레싱되는 다수의 제 2 메모리 블록을 생성하고, 해당 코드 섹션으로 각각의 메모리 블록을 식별하며, 식별된 메모리 블록에 코드 섹션을 저장하고, 이때, 코드 섹션의 시작점은 해당 시작 어드레스이고, 코드 섹션 식별자를 해당 시작 어드레스와 상호참조시키는 코드 섹션 어드레스 테이블을 관리하며, 그리고 무선 장치 시스템 소프트웨어를 실행하는, 이상의 단계를 포함한다.
시스템 소프트웨어 코드를 다수의 제 1 심벌 라이브러리로 형성하는 것은 심벌 액세서 코드를 형성하는 과정을 포함한다. 다수의 제 1 심벌 라이브러리들을 다수의 제 2 코드 섹션으로 배열하는 것은 각각의 심벌을 코드 섹션 시작 어드레스로부터 각각 이격되도록 배열하는 과정을 포함하며, 제 1 코드 섹션에 심벌 액세서 코드를 배열하는 과정을 포함한다. 그후, 이 방법은, 심벌 식별자를 해당 오프셋 어드레스 및 해당 코드 섹션 식별자와 상호참조시키는 심벌 오프셋 어드레스 테이블을 관리하고, 그리고 심벌 액세서 코드 어드레스를 메모리의 제 1 위치에 저장하는 단계를 포함한다.
코드 섹션 어드레스 테이블, 심벌 오프셋 어드레스 테이블, 모든 심벌 라이브러리에 대한 판독-기록기쓰기 데이터, 시스템 소프트웨어를 실행하면서 라이브러리 내 심벌들의 주소를 연산하는 심벌 액세서 코드, 그리고 심벌 액세서 코드 어드레스가 공통 코드 섹션, 통상적으로 패치 매니저 코드 섹션에 심벌 라이브러리로 배열된다. 판독-기록 데이터, 코드 섹션 어드레스 테이블, 심벌 오프셋 어드레스 테이블, 심벌 액세서 코드 어드레스, 그리고 심벌 액세서 코드가 임의 접근 판독-기록 메모리로부터 로딩되고 액세스된다.
코드 섹션들은, 심벌 라이브러리가 더 큰 라이브러리로 업데이트될 경우를 대비하여, 배열된 심벌 라이브러리를 수용할 수 있게, 또는 배열된 심벌 라이브러리보다 크게 그 크기가 설정된다. 연속적으로 어드레싱되는 메모리 블록은 해당 코드 섹션을 정확하게 수용한다.
상술한 방법 및 무선 통신 장치 현장 업그레이드형 시스템 소프트웨어 구조가 아래에 제시된다.
도 1은 전체 무선 장치 소프트웨어 관리 시스템의 블록도표.
도 2는 에어 링크 인터페이스를 통해 명령 세트의 설치를 강조한, 소프트웨어 관리 시스템의 블록도표.
도 3은 무선 통신 장치에 사용하기 위한, 본 발명에 따른 현장 업그레이드형 시스템 소프트웨어 구조의 블록도표.
도 4는 무선 장치 메모리의 블록도표.
도 5는 도 3의 코드 섹션 어드레스 테이블을 보여주는 표.
도 6은 도 3의 심벌 라이브러리의 상세한 도면.
도 7은 도 3의 심벌 오프셋 어드레스 테이블을 보여주는 표.
도 8a와 8b는 무선 통신 장치에서 현장 업그레이드형 시스템 소프트웨어를 조직하기 위한 본 발명에 따른 방법을 설명하는 순서도.
* 본원 기재내용 중 "현장"이라는 표현은 영문의 "field"를 번역한 용어로서, 제작 후 사용자에게 이미 배포된 상태를 의미하는 용어이다. *
아래에 이어지는 실시예의 일부분이 과정, 단계, 로직 블록, 코드, 처리공정, 그리고 무선 장치 마이크로프로세서나 메모리 내 데이터 비트의 동작을 표현하는 다른 심벌을 들어 설명된다. 이 표현들은 데이터 처리 분야에 통상의 지식을 가진 자들에 의해 사용되는 수단이다. 과정, 마이크로프로세서 실행 단계, 데이터 아이템, 애플리케이션, 로직 블록, 처리공정 등은 요망 결과를 이끄는 단계들이나 명령들의 사리에 맞는 시퀀스로 간주된다. 이 단계들은 물리적 양의 물리적 조작을 필요로하는 단계들이다. 일반적으로, 반드시 그러한 것은 아니지만, 이 양들은 저장, 전송, 조합, 비교, 마이크로프로세서 기반 무선 장치의 조작이 가능한 전기/자기 신호의 형태를 취한다. 비트, 값, 요소, 심벌, 캐릭터, 데이터 아이템, 수치 등으로 이 신호들을 명명하는 것은 대중적으로 널리 사용되기 때문에 편리한 것으로 인식되고 있다. 메모리같은 물리적 소자들이 언급되는 데, 이들은 버스나 다른 전기적 연결을 통해 다른 물리적 소자들에 연결된다. 이 물리적 소자들은 로직 처리공정이나 애플리케이션과 상호작용할 수 있다고 간주될 수 있고, 따라서, 로직 동작에 "연결"된다. 예를 들어, 메모리는 추가적인 로직 동작에 코드를 저장할 수 있 다.
그러나, 이 용어들이 적절한 물리적 양에 관련된 것으로서, 이 양들에 적용된 편리한 라벨에 지나지 않음을 명심하여야 한다. 다음의 설명으로부터 명백하겠지만, 본 발명을 통해, "처리", "연결", "변환", "디스플레이", 또는 "프람프트", "결정", "디스플레이", "인식", "비교", "대체(교체)", "어드레스(해결처리)", "불러오기", 등같은 용어들을 이용한 설명은 컴퓨터 시스템의 레지스터와 메모리 내의 물리적 양으로 표현되는 데이터를 무선 장치 메모리나 레지스터, 또는 그 외 다른 이러한 정보 저장, 전송, 또는 디스플레이 장치 내의 물리적 양으로 표현되는 다른 데이터로 조작하고 변환하는 무선 장치 마이크로프로세서 시스템의 동작들을 의미한다.
도 1은 전체 무선 장치 소프트웨어 관리 시스템(100)의 블록도표이다. 본 발명의 시스템 소프트웨어 조직은 아래에 상세하게 제시되며, 소프트웨어 관리 시스템(100)의 일반적 개관을 따른다. 일반 시스템(100)은 시스템 소프트웨어 업데이트 및 명령 세트(프로그램)의 전달 과정과, 무선 장치에서 전달된 소프트웨어의 설치 과정을 소개한다. 시스템 소프트웨어 업데이트와 패치 매니저 런타임 명령(PMRTI)(명령 세트나 동적 명령 세트로 알려짐)은 핸드셋 제작자에 의해 생성된다. 시스템 소프트웨어는 심벌 라이브러리로 조직된다. 심벌 라이브러리는 코드섹션들로 배열된다. 심벌 라이브러리가 업데이트되어야 할 때, 소프트웨어 업데이트(102)가 한개 이상의 코드 섹션으로 전달된다. 소프트웨어 업데이트는 이미 배포된 무선 장치에 송출되며, 그 무선 통신 장치(104)의 소프트웨어 업데이트(102)는 잘 알려진 기존 의 에어, 데이터, 또는 메시지 전송 프로토콜을 이용하여 기지국(106)으로부터 별도의 통신들로 전송된다. 발명은 어떤 특정 전송 포맷에 국한되지 않는다. 왜냐하면, 무선 통신 장치가 시스템 소프트웨어 및 PMRTI 업데이트를 수신하기 위해 어떤 가용한 에어 전송 프로토콜을 처리하도록 용이하게 수정될 수 있기 때문이다.
이 시스템 소프트웨어는 여러 다른 서브시스템들의 집합체로 보일 수 있다. 코드 객체들은 이 추상적 서브시스템들 중 하나에 강력하게 연결될 수 있고, 결과적인 집합체가 심벌 라이브러리의 라벨을 달 수 있다. 이는 코드 베이스의 로직 파괴를 제공하고, 소프트웨어 패치와 처방(fixes)이 심벌 라이브러리 중 하나에 관련될 수 있다. 대부분의 경우에, 단일 업데이트가 한개나 두개의 심벌 라이브러리에 관련된다. 나머지 코드 베이스, 나머지 심벌 라이브러리는 불변으로 유지된다.
심벌 라이브러리의 표현은 코드와 상수를 취급하기 위한 메커니즘을 제공한다. 다른 한편, 판독-기록(Read-Write) 데이터는 모든 라이브러리에 대해 RAM 기반 데이터를 내포한 독자적이고 개별적인 판독-기록 라이브러리에 부합한다.
무선 장치(104)에 의해 수신되었을 때, 전송된 코드 섹션이 반드시 처리되어야 한다. 무선 장치는 비휘발성 메모리의 특정 코드 섹션을 덮어쓴다. 비휘발성 메모리(108)는 파일 시스템 섹션(FSS)(110)과 코드 저장 섹션(112)을 포함한다. 코드 섹션은 FSS(110)의 점유를 최소화시키기 위해 전송 전에 일반적으로 압축된다. 업데이트된 코드 섹션이 판독-기록 데이터를 동반하는 경우가 자주 있으며, 이는 각각의 심벌 라이브러리에 대해 모든 판독-기록 데이터를 내포한 또다른 종류의 심벌 라이브버리이다. 시스템 소프트웨어가 실행 중일 때 휘발성 판독-기록 RAM(114)에 로딩되지만, 판독-기록 데이터는 비휘발성 메모리(108)에 저장될 필요가 항상 있으며, 따라서, 무선 장치가 리셋될 때마다 판독-기록 데이터가 휘발성 판독-기록 RAM(114)에 로딩될 수 있다. 이는 판독-기록 데이터가 휘발성 판독-기록 RAM으로 로딩되는 첫 번째를 포함한다. 아래에 상세하게 설명되겠으나, 판독-기록 데이터는 패치 매니저 코드 섹션으로 배열되는 것이 일반적이다.
시스템(100)은 가상 테이블의 개념을 포함한다. 이러한 테이블을 이용하여, 한 코드 섹션의 심벌 라이브러리들이 시스템 소프트웨어의 다른 부분(다른 코드 섹션)을 파괴(교체)하지 않으면서 패치(교체)될 수 있다. 가상 테이블은 효율성을 위해 휘발성 판독-기록 RAM(114)으로부터 실행된다. 코드 섹션 어드레스 테이블와 심벌 오프셋 어드레스 테이블은 가상 테이블이다.
업데이트된 코드 섹션들이 무선 장치(104)에 의해 수신되어 FSS(110)에 저장된다. 무선 장치 사용자 인터페이스(UI)는 통상적으로 새 소프트웨어가 가용함을 사용자에게 알릴 것이다. 사용자 인터페이스 프람프트에 따라 사용자는 이 통지를 확인하고 패치나 업데이트 동작을 신호한다. 대안으로, 업데이트 동작이 자동적으로 시행된다. 업데이트 처리가 실행됨에 따라 무선 장치가 표준 통신 작업을 수행하지 못할 수가 있다. 패치 매니저 코드 섹션은 휘발성 판독-기록 RAM(114)에 또한 로딩되는 비휘발성 판독-기록 드라이버 심벌 라이브러리를 포함한다. 비휘발성 판독-기록 드라이버 심벌 라이브러리는 코드 섹션들을 업데이트된 코드 섹션으로 덮어쓴다. 도시되는 바와 같이, 코드 섹션 n과 패치 매니저 코드 섹션이 업데이트된 코드 섹션으로 덮어써진다. 패치 매니저 코드 섹션은 판독-기록 데이터, 코드 섹션 어드레스 테이블, 그리고 심벌 오프셋 어드레스 테이블을 포함하고, 또한, 심벌 액세서 코드와 심벌 액세서 코드 어드레스도 포함한다. 업데이트된 코드 섹션들이 도입되면 이 데이터의 일부분들이 유효하지 않으며, 업데이트된 패치 매니저 코드 섹션들은 업데이트된 코드 섹션에 대해 유효한 판독-기록 데이터, 코드 섹션 어드레스 테이블, 그리고 심벌 오프셋 어드레스 테이블을 포함한다. 업데이트된 코드 섹션이 코드 저장 섹션(112)으로 로딩되면, 무선 장치가 리셋된다. 리셋 동작에 이어, 무선 장치는 업데이트된 시스템 소프트웨어를 실행할 수 있다. 패치 매니저 코드 섹션이 상술하지 않은 다른 심벌 라이브러리를 포함할 수도 있다. 이러한 다른 심벌 라이브러리들은 휘발성 판독-기록 메모리(114)로 로딩될 필요가 없다.
도 2는 에어 링크 인터페이스를 통해 명령 세트의 설치를 강조한, 소프트웨어 관리 시스템(100)의 블록도표이다. 시스템 소프트웨어 코드 섹션의 업데이트에 추가하여, 관리 시스템(100)은 패치 매니저 명령 세트(PMIS)라 불리는 명령 세트나 프로그램을 다운로드하고 설치할 수 있다. PMIS 코드 섹션(200)은 상술한 시스템 소프트웨어 코드 섹션과 같은 방식으로 무선 장치(104)에 전달된다. PMIS 코드 섹션은 최초에 파일 시스템 섹션(110)에 저장된다. PMIS 코드 섹션은 핸드셋에 컴파일된 명령으로 나타날 수 있는 이진(binary) 파일이다. PMIS 코드 섹션은 조건부 실행 동작의 성능과 기본 수학적 동작의 성능을 제공할 만큼 충분히 포괄적이다. 예를 들어, RF 조정 PMIS는 다음의 동작을 수행할 수 있다.
IF RF CAL ITEM IS LESS THAN X
EXECUTE INSTRUCTION
ELSE
EXECUTE INSTRUCTION
PMIS는 덧셈, 뺄셈, 곱셈, 나눗셈같은 기본적 수학 연산을 지원할 수 있다. 시스템 소프트웨어 코드 섹션에 대하여, PMIS 코드 섹션은 UI 프람프트에 따라 로딩될 수 있고, 무선 장치는 PMIS가 코드 저장 섹션(112)으로 로딩된 후 리셋되어야 한다. 그후 PMIS 섹션이 실행될 수 있다. PMIS 코드 섹션이 어떤 가상 테이블이나 판독-기록 데이터에 연계될 경우, 업데이트된 패치 매니저 코드 섹션이 코드 저장 섹션(112)에서의 설치를 위해 PMIS로 전송될 것이다. 대안으로, PMIS가 유지되어 FSS(110)로부터 처리될 수 있다. 핸드셋(104)이 PMIS 섹션의 모든 명령을 수행한 후, PMIS 섹션이 FSS(110)로부터 삭제될 수 있다.
발명의 일부 태양에 따르면, 시스템 소프트웨어를 심벌 라이브러리로 조직하는 것은 실행에 필요한 휘발성 메모리(114)와 비휘발성 메모리(108)의 크기에 영향을 미친다. 이는 코드 섹션들이 코드 섹션에 배열된 심벌 라이브러리들보다 통상적으로 크기 때문이다. 업데이트된 코드 섹션을 수용하기 위해서 코드 섹션이 큰 것이다. 시스템 소프트웨어를 라이브러리들의 집합체로 조직하는 것은 비휘발성 메모리 크기 요건에 영향을 미친다. 동일한 코드 크기의 경우, 사용되는 비휘발성 메모리의 양이 클 것이다. 왜냐하면, 코드 섹션이 그 안에 배열되는 심벌 라이브러리보다 크기가 클 수 있기 때문이다.
PMIS는 매우 강력한 런타임 명령 엔진이다. 핸드셋이 PMIS 환경을 통해 전달되는 어떤 명령도 실행할 수 있다. 이 메커니즘은 RF 조정 및 PRI 업데이트를 지원하는 데 사용될 수 있다. 보다 일반적으로, PMIS는 제작자나 서비스 제공자에 의해 소프트웨어 문제가 인지되었을 때 무선 장치 소프트웨어를 원격 디버깅(remote debug)하는 데 사용될 수 있다. PMIS는 소프트웨어 문제점의 진단에 필요한 데이터를 레코딩할 수도 있다. PMIS는 데이터 분석, 디버그, 처방을 위해 새로이 다운로드받은 시스템 애플리케이션을 발진시킬 수 있다. PMIS는 업데이트된 시스템 소프트웨어 코드 섹션 대신에 문제점에 대한 단기 처방과 분석에 대한 판독-기록 데이터 기반 업데이트를 제공할 수 있다. PMIS는 무선 장치에 의한 이용을 위해 메모리 치밀화 알고리즘을 제공할 수 있다.
소프트웨어 업데이트가 무선 장치에 전달되면, 소프트웨어 관리 시스템(100)은 메모리 치밀화를 지원한다. 메모리 치밀화는 데스크탑 컴퓨터의 디스크 디프래그먼트 애플리케이션(disk defragmentation application)과 유사하다. 치밀화 메커니즘은 메모리가 최적으로 사용되고 차후 코드 섹션 업데이트에 대해 우수한 균형을 유지함을 보장한다. 이때, 업데이트된 코드 섹션의 크기는 예측불가능하다. 시스템(100)은 패치(업데이트) 실행 중에 코드 저장 섹션을 분석한다. 시스템(100)은 교체되는 코드 섹션에 의해 점유되는 메모리 공간에 업데이트된 코드 섹션을 맞추려고 시도한다. 업데이트된 코드 섹션이 교체되는 코드 섹션보다 클 경우, 시스템(100)은 메모리(112)의 코드 섹션을 치밀화한다. 대안으로, 제작자나 서비스 제공자에 의해 치밀화가 연산될 수 있고, 치밀화 명령이 무선 장치(104)에 전달될 수 있다.
치밀화는 알고리즘의 복잡도와 방대한 분량의 데이터 이동 때문에 시간이 소 요되는 공정일 수 있다. 치밀화 알고리즘은 어떤 공정을 시작하기 전에 가능성을 예측한다. UI 프람프트는 치밀화가 시도되기 전에 사용자로부터의 허가를 얻는 데 사용될 수 있다.
일부 발명의 태양에서, 모든 시스템 소프트웨어 코드 섹션들이 동시에 업데이트될 수 있다. 완전한 시스템 소프트웨어 업그레이드는 더 큰 FSS(110)를 필요로 할 것이다.
도 3은 무선 통신 장치(104)에 사용하기 위한, 본 발명에 따른 현장 업그레이드형 시스템 소프트웨어 구조의 블록도표이다. 시스템 소프트웨어 구조(300)는 다수의 제 2 코드 섹션들로 구분된 실행형 시스템 소프트웨어를 포함한다. 코드 섹션 1(302), 코드 섹션 2(304), 코드 섹션 n(306), 그리고 패치 매니저 코드 섹션(308)이 도시된다. 그러나, 발명이 어떤 특정 수치의 코드 섹션에 제한되지는 않는다. 시스템(300)은 다수의 제 2 코드 섹션들로 배열되는 다수의 제 1 심벌 라이브러리를 추가로 포함한다. 심벌 라이브러리 1(310)이 코드 섹션 1(302)에, 심벌 라이브러리 2(312)와 3(314)이 코드 섹션 2(304)에 배열되며, 심벌 라이브러리 m(316)은 코드 섹션 n(306)에 배열된다. 각각의 라이브러리는 관련 기능을 가진 심벌들을 포함한다. 예를 들어, 심벌 라이브러리 1(310)은 무선 장치 LCD의 동작에 관련될 수 있다. 그후, 심벌은 디스플레이 기능에 관련될 수 있다. 아래 설명되는 바와 같이, 추가적인 심벌 라이브러리들이 패치 매니저 코드 섹션(308)에 배열된다.
도 4는 무선 장치 메모리의 블록도표이다. 도시되는 바와 같이, 메모리는 도 1의 코드 저장 섹션(112)이다. 메모리는 쓰기가능한 비휘발성 메모리이다(가령, 플래시 메모리). 코드 섹션이 반드시 FSS(110)와 같은 메모리에 저장될 필요는 없다. 본 발명의 시스템 소프트웨어 구조가 다수의 협력 메모리에 저장된 코드 섹션들로 구현될 수 있다. 코드 저장 섹션(112)은 다수의 제 2 연속 어드레싱 메모리 블록을 포함하며, 이때, 각각의 메모리 블록은 다수의 리소스 섹션들로부터 해당 코드 섹션을 저장한다. 따라서, 코드 섹션 1(302)이 제 1 메모리 블록(400)에 저장되고, 코드 섹션 2(304)가 제 2 메모리 블록(402)에 저장되며, 코드 섹션 n(306)이 제 n 메모리 블록(404)에 저장되고, 패치 매니저 코드 섹션(308)이 제 p 메모리 블록(406)에 저장된다.
도 3과 4를 대조해보면, 각각의 코드 섹션의 시작점이 메모리의 해당 시작 어드레스에 저장되고, 심벌 라이브러리들이 코드 섹션의 시작점에서 시작되도록 배열된다. 즉, 각각의 심벌 라이브러리는 제 1 어드레스에서 시작하여 제 1 어드레스로부터 순서대로 어드레스 범위를 따라 진행된다. 예를 들어, 코드 섹션 1(302)은 코드 저장 섹션 메모리(112)의 제 1 시작 어드레스(408)("S"로 표시)에서 시작된다. 도 3에서, 심벌 라이브러리 1(310)은 제 1 코드 섹션의 시작점(318)에서 시작된다. 마찬가지로 코드 섹션 2(304)는 제 2 시작 어드레스(410)(도 4)에서 시작되고, 심벌 라이브러리 2는 코드 섹션 2의 시작점(320)(도 3)에서 시작된다. 코드 섹션 n(306)은 코드 저장 섹션 메모리(112)의 제 3 시작 어드레스(412)에서 시작되고(도 4), 심벌 라이브러리 m(316)은 코드 섹션 n(322)의 시점에서 시작된다(도 3). 패치 매니저 코드 섹션은 코드 저장 섹션 메모리(112)의 제 p 시 작 어드레스(414)에서 시작하고, 패치 매니저 코드 섹션(310)의 제 1 심벌 라이브러리는 제 1 메모리 블록(400)에 궁극적으로 저장된다. 한 코드 섹션이 다수의 심벌 라이브러리를 포함할 경우(가령, 코드 섹션 2(304)), 다수의 심벌 라이브러리는 제 2 메모리 블록(402)의 경우에, 해당 메모리 블록에 저장된다.
도 3에서, 시스템 소프트웨어 구조(300)는 패치 매니저 코드 섹션(308)에 배열되는 심벌 라이브러리에 포함된 심벌 종류로 코드 섹션 어드레스 테이블(326)을 추가로 포함한다. 코드 섹션 어드레스 테이블은 코드 섹션 식별자를 메모리의 해당 코드 섹션 시점 어드레스와 상호참조(cross-reference)한다.
도 5는 도 3의 코드 섹션 어드레스 테이블(326)을 나타내는 표다. 코드 섹션 어드레스 테이블(326)은 심벌 라이브러리에 대한 코드 섹션 시작 어드레스를 찾기 위해 참고된다. 예를 들어, 심벌 라이브러리 1의 한 심벌이 실행에 필요할 경우 시스템(300)이 코드 섹션 1을 찾는다. 코드 섹션 1의 시작 어드레스를 찾기 위해, 그래서 심벌 라이브러리 1의 심벌을 위치시키기 위해, 코드 섹션 어드레스 테이블(326)이 참고된다. 코드 섹션들에서 심벌 라이브러리들의 배열과, 코드 섹션을 테이블로 찾아가는 것은 코드 섹션을 이동시키거나 확장시킬 수 있다. 확장이나 이동 동작은 업그레이드된 코드 섹션을 설치하는 데 필요할 수 있다.
도 3으로 돌아가서, 모든 심벌 라이브러리들이 반드시 코드 섹션의 시점에서 시작되는 것은 아니다. 도시되는 바와 같이, 심벌 라이브러리 3(314)은 코드 섹션 2(304)에 베열되지만, 코드 섹션 시작 어드레스(320)의 시작점은 아니다. 따라서, 심벌 라이브러리 3(314)의 한 심벌이 실행에 필요할 경우, 시스템(300)은 코드 섹션 2(304)의 시작 어드레스에 대한 코드 섹션 어드레스 테이블(326)을 참조한다. 아래 설명되는 바와 같이, 심벌 오프셋 어드레스 테이블이 심벌 라이브러리 3(314)의 심벌들을 위치시킨다. 심벌들이 동일한 코드 섹션으로 유지되기 때문에 심벌들이 다중 라이브러리 사이에 퍼지는 것은 문제가 되지 않는다.
상술한 바와 같이, 각각의 심벌 라이브러리는 기능적으로 관련된 심벌들을 포함한다. 심벌은 루틴 바디(routine body), 변수, 또는 데이터 구조를 위치시키고 이용하기 위한 프로그래머-지정 명칭이다. 따라서, 심벌이 한개의 어드레스거나 한개의 값(value)일 수 있다. 심벌들은 내부적일 수도 있고 외부적일 수도 있다. 내부적 심벌은 현 코드 섹션의 범위를 넘으면 보이지 않는다. 보다 구체적으로, 내부적 심벌들은 다른 코드 섹션의 다른 심벌 라이브러리로 찾을 수 없다. 외부적 심벌은 코드 섹션 사이에서 사용되고 호출되며, 여러 다른 코드 섹션의 라이브러리로 찾을 수 있다. 심벌 오프셋 어드레스 테이블은 모든 외부적 심벌들의 리스트를 포함하는 것이 일반적이다.
예를 들어, 심벌 라이브러리 1(310)은 무선 장치 디스플레이 상에 문자들을 발생시킨다. 이 라이브러리의 심벌들은 전화 번호, 성명, 시간, 또는 그 외 다른 디스플레이 특징들을 발생시킨다. 각각의 특징은 심벌이라고 불리는 루틴으로 발생된다. 가령, 심벌 라이브러리 1(310)의 한개의 심벌이 디스플레이 장치에 전화번호를 발생시킨다. 이 심벌은 X로 표시되며 외부적이다. 무선 장치가 전화통화를 수신하고 호출자 ID 서비스가 활성화되면, 시스템은 디스플레이 장치 상에 번호를 발생시키도록 "x" 심벌을 실행하여야 한다. 따라서 시스템은 X 심벌을 위치시켜야 한다.
도 6은 심벌들로 구성된 도 3의 심벌 라이브러리 1(310)의 상세한 도면이다. 심벌들은 각각 코드 섹션 시작 어드레스로부터 이격되어 배치된다. 여러 상황에서, 심벌 라이브러리의 시작점은 코드 섹션의 시작점이지만, 이는 코드 섹션이 두개 이상의 심벌 라이브러리를 포함할 경우 사실이 아니다. 심벌 라이브러리 1(310)은 코드 섹션 1의 시작점에서 시작된다(도 3 참조). 도 6에 도시되는 바와 같이, "X"심벌은 심벌 라이브러리의 시작점으로부터 (03)만큼 이격되어 위치하고, "Y"심벌은 (15)만큼 이격되어 위치한다. 심벌 오프셋 어드레스들은 패치 매니저 코드 섹션의 심벌 오프셋 어드레스 테이블(328)에 저장된다(도 3 참조).
도 7은 도 3의 심벌 오프셋 어드레스 테이블(328)을 도시하는 표이다. 심벌 오프셋 어드레스 테이블(328)은 심벌 식별자를 해당 오프셋 어드레스와, 메모리의 해당 코드 섹션 식별자와 상호참고(cross-reference)시킨다. 따라서, 시스템이 심벌 라이브러리 1의 "X"심벌을 실행하려할 경우, 심벌 오프셋 어드레스 테이블(328)이 코드 섹션에 대해 심벌의 정확한 어드레스를 위치시키기 위해 참고된다.
도 3으로 되돌아가서, 다수의 제 1 심벌 라이브러리들은 이 심벌 라이브러리들의 실행시 설정되거나 참고되어야 하는 모든 판독-기록(read-write; RW) 데이터를 포함하는 것이 일반적이다. 예를 들어, 심벌 라이브러리가 조건부 문장에 따라 좌우되는 동작을 포함할 수 있다. 판독-기록 데이터 섹션은 조건부 문장(conditional statement)을 완성시키는 데 필요한 상태(status)를 결정하기 위해 참고된다. 본 발명은 모든 심벌 라이브러리로부터의 판독-기록 데이터를 공유 판독-기록 섹션으로 묶는다. 발명의 일부 태양에서, 판독-기록 데이터(330)는 패치 매니저 코드 섹션(308)에 배열된다. 대안으로(도시되지 않음), 판독-기록 데이터가 앞서와 다른 코드 섹션, 가령, 코드 섹션 n(306)으로 배열될 수 있다.
다수의 제 1 심벌 라이브러리들은 찾는 심벌의 어드레스를 계산하기 위해 코드 섹션에 배열되는 심벌 액세서 코드를 또한 포함한다. 심벌 액세서 코드는 별도의 코드 섹션, 가령, 코드 섹션 2(304)의 어드레스에 배열되고 저장될 수 있다. 그러나 도시되는 바와 같이, 심벌 액세서 코드(332)는 패치 매니저 코드 섹션(308)의 어드레스에 배열되고 저장된다. 시스템 소프트웨어 구조(300)는 심벌 액세서 코드 어드레스의 저장을 위한 제 1 위치를 추가로 포함한다. 제 1 위치는 코드 저장 섹션(112)의 코드섹션일 수도 있고, 무선 장치의 별도 메모리 섹션의 코드 섹션일 수도 있다. 제 1 위치는 판독-기록 데이터와 동일한 코드 섹션에 배열될 수도 있다. 도시되는 바와 같이, 제 1 위치(334)는 판독-기록 데이터(330), 심벌 오프셋 어드레스 테이블(328), 코드 섹션 어드레스 테이블(326), 그리고 심벌 액세서 코드(332), 그리고 패치 라이브러리(패치 심벌 라이브러리)(336)로 패치 매니저 코드 섹션(308)에 저장된다.
심벌 액세서 코드는 메모리에서 찾는 심벌의 정확한 어드레스를 발견하기 위해 코드 섹션 어드레스 테이블과 심벌 오프셋 어드레스 테이블을 이용한다. 즉, 심벌 액세서 코드는 코드 섹션 어드레스 테이블과 심벌 오프셋 어드레스 테이블에 액세스하여 찾는 심벌의 어드레스를 연산할 수 있다. 예를 들어, 심벌 라이브러리 1의 "X"심벌을 찾을 경우, "X"심벌에 해당하는 심벌 식별자(심벌 ID) "X_1"을 찾기 위해 심벌 액세스가 호출된다(도 7 참조). 심벌 액세서 코드는 "X_1"심벌 식별자가 코드 섹션 1의 시작점으로부터 (03)만큼 이격되는 지를 결정하기 위해 심벌 오프셋 어드레스 테이블을 참고한다. 심벌 액세서 코드는 코드 섹션 1에 대응하는 코드 섹션 식별자(코드 섹션 ID) "CS_1"를 찾기 위해 호출된다. 심벌 액세서 코드는 코드 섹션 식별자 "CS_1"에 관련된 시작 어드레스를 결정하기 위해 코드 섹션 어드레스 테이블을 참고한다. 이 방식으로, 심벌 식별자 "X_1"이 (00100)의 어드레스로부터 (03)만큼 이격되거나 (00103)에 위치함을 심벌 액세서 코드가 결정한다.
심벌 "X"는 실제 코드의 일부분이기 때문에 예약된 명칭이다. 다시 말해서, 이와 관련된 절대적 데이터를 가진다. 이 데이터는 하나의 어드레스일 수도 있고 하나의 값(value)일 수도 있다. 심벌 식별자는 심벌 추적을 위해 생성되는 별칭이다. 심벌 오프셋 어드레스 테이블과 코드 섹션 어드레스 테이블은 예약된 심벌과 코드 섹션 명칭과의 혼동을 피하기 위해 식별자와 함께 기능한다. 동일한 심벌 명칭이 여러 심벌 라이브러리 사이에서 사용되는 것도 또한 가능하다. 식별자 사용은 이 심벌들간 혼동을 방지한다.
도 1로 되돌아가서, 시스템 소프트웨어 구조(300)는 판독-기록 휘발성 메모리(114), 통상적으로 RAM을 추가로 포함한다. 판독-기록 데이터(330), 코드 섹션 어드레스 테이블(326), 심벌 오프셋 어드레스 테이블(328), 심벌 액세서 코드(332), 그리고 심벌 액세서 코드 어드레스(334)가 시스템 소프트웨어 실행 중 액세스를 위해 패치 매니저 코드 섹션으로부터 판독-기록 휘발성 메모리(114)로 로딩된다. 당 분야에 잘 알려진 바와 같이, RAM 에 저장되는 코드에 대한 액세스 시간은 플래시같은 비휘발성 메모리에 대한 액세스보다 상당히 작다.
도 3으로 되돌아가서, 메모리 블록이 그 안에 저장되는 해당 코드 섹션을 정확하게 수용할 수 있는 크기를 가지지만, 심벌 라이브러리들이 배열될 코드 섹션들을 반드시 채울 필요는 없다. 달리 말하자면, 다수의 제 2 코드 섹션들 각각은 배열되는 심벌 라이브러리들을 수용하는 바이트 크기를 가지며, 연속적으로 어드레싱되는 메모리 블록들 각각은 해당 코드 섹션들을 수용하는 바이트 크기를 가진다. 가령, 코드 섹션 1(302)은 100 바이트의 길이를 가진 심벌 라이브러리를 수용하기 위해 100 바이트 섹션일 수 있다. 제 1 메모리 블록은 코드 섹션 1의 바이트 크기와 일치하기 위해 100바이트일 것이다. 그러나, 코드 섹션 1에 로딩되는 심벌 라이브러리가 100바이트보다 작을 수 있다. 도 3에 도시되는 바와 같이, 심벌 라이브러리 1(310)이 100바이트보다 작기 때문에 코드 섹션 1(302)은 사용하지 않은 섹션(340)을 가진다. 따라서, 다수의 제 2 코드 섹션들 각각은 배열된 심벌 라이브러리들을 수용하는 데 필요한 크기보다 더 큰 크기를 가질 수 있다. 코드 섹션 크기를 과설정함(oversizing)으로서, 업데이트된 더 큰 심벌 라이브러리들을 수용할 수 있다.
도 8a와 8b는 무선 통신 장치의 현장 업그레이드형 시스템 소프트웨어를 조직하기 위한 본 발명에 따른 방법을 설명하는 순서도이다. 이 방법은 단계 800에서 시작된다. 단계 802는 시스템 소프트웨어를 다수의 제 1 심벌 라이브러리로 형성하고, 이때, 각각의 심벌 라이브러리는 관련 기능을 가진 심벌들을 포함한다. 단계 804는 다수의 제 1 심벌 라이브러리들을 다수의 제 2 코드 섹션에 배열한다. 단계 806은 무선 장치 시스템 소프트웨어를 실행한다.
단계 804에서 다수의 제 1심벌 라이브러리들을 다수의 제 2 코드 섹션에 배열하는 것은 코드 섹션의 시작점에서 심벌 라이브러리들을 시작하게 하는 과정을 포함하며, 이 방법은 추가적인 단계들을 포함한다. 단계 805a는 해당 시작 어드레스에서 코드 섹션의 시작을 저장한다. 단계 805b는 코드 섹션 식별자를 해당 시작 어드레스와 상호참조시키는 코드 섹션 어드레스 테이블을 관리한다.
다수의 제 1 심벌 라이브러리들을 다수의 제 2 코드 섹션에 배열하는 것(단계 804)은 심벌들을 코드 섹션 시작 어드레스로부터 각각 이격시키도록 배열하는 과정을 포함한다. 그후, 단계 805c는 심벌 식별자를 해당 오프셋 어드레스 및 해당 코드 섹션 식별자와 상호참조시키기 위한 심벌 오프셋 어드레스를 관리한다.
발명의 일부 태양에 따르면, 시스템 소프트웨어 코드를 다수의 제 1 심벌 라이브러리로 배열하는 것(단계 802)은 심벌 액세서 코드를 형성하는 과정을 포함하고, 다수의 제 1 심벌 라이브러리들을 다수의 제 2 코드 섹션에 배열하는 것(단계 804)은 제 1 코드 섹션에 심벌 액세서 코드를 배열하는 과정을 포함한다. 그후, 이 방법은 추가 단계를 포함한다. 단계 805d는 메모리의 제 1 위치에 심벌 액세서 코드 어드레스를 저장한다. 그후, 코드 섹션을 시스템 소프트웨어로 실행하는 것(단계 806)은 서브단계들을 포함한다. 단계 806a는 다수의 제 3 심벌 라이브러리들을 판독-기록 휘발성 메모리, 통상적으로 RAM으로 로딩한다. 다수의 제 3 심벌 라이브러리들이 패치 매니저 코드 섹션에 모든 심벌 라이브러리들을 반드시 포함할 필요는 없다. 다수의 제 3 심벌 라이브러리들은 패치 매니저 코드 섹션 옆에 다른 코드 섹션에 배열되는 심벌 라이브러리들도 포함할 수 있다. 단계 806b는 메모리의 제 1 위치를 참조함으로서, 심벌 액세서 코드에 액세스한다. 단계 806c는 해당 심벌 식별자와 해당 코드 섹션 식별자를 이용하여 찾는 심벌의 어드레스를 연산하기 위해 심벌 액세서 코드를 불러들인다. 단계 806d는 RAM의 다수의 제 3 심벌 라이브러리에 액세스한다.
찾는 심벌의 어드레스를 연산하기 위해 심벌 액세서 코드를 불러들이는 것(단계 806b)은 찾는 심벌의 어드레스를 연산하기 위해 코드 섹션 어드레스 테이블과 심벌 오프셋 어드레스 테이블에 액세스하는 과정을 포함한다. 통상적으로, 심벌 액세서 코드 어드레스를 메모리의 제 1 위치에 저장하는 것(단계 805d)은 제 1 코드 섹션에 심벌 액세서 코드 어드레스를 저장하는 과정을 포함한다.
발명의 일부 태양에 따르면, 다수의 제 1 심벌 라이브러리를 다수의 제 2 코드 섹션에 배열하는 것(단계 804)은 판독-기록 데이터, 코드 섹션 어드레스 테이블, 심벌 오프셋 어드레스 테이블, 그리고 심벌 액세서 코드를 제 1 코드 섹션, 통상적으로 패치 매니저 코드 섹션에 배열하는 과정을 포함한다. 그후, 단계 806a는 판독-기록 데이터, 코드 섹션 어드레스 테이블, 심벌 오프셋 어드레스 테이블, 심벌 액세서 코드, 그리고 심벌 액세서 코드 어드레스를 제 1 코드 섹션으로부터 판독-기록 휘발성 메모리(통상적으로 RAM)에게로 로딩시킨다. 단계 806d는 판독-기록 휘발성 메모리로부터 판독-기록 데이터, 코드 섹션 어드레스 테이블, 심벌 오프셋 어드레스 테이블, 심벌 액세서 코드, 그리고 심벌 액세서 코드 어드레스에 액세스한다.
해당 시작 어드레스에서 코드 섹션의 시작을 저장하는 것(단계 805a)은 서브 단계들을 포함한다. 단계805a1은 연속적으로 어드레싱되는 다수의 제 2 메모리 블록을 생성한다. 단계 805a2는 해당 코드 섹션으로 각각의 메모리 블록을 식별한다. 단계 805a3는 식별된 메모리 블록에 코드 섹션들을 저장한다.
발명의 일부 태양에 따르면, 다수의 제 1심벌 라이브러리를 다수의 제 2 코드 섹션에 배열하는 것(단계 804)은 다수의 제 3 심벌 라이브러리를 제 1 코드 섹션에 배열하는 과정을 포함한다. 그후, 해당 코드 섹션으로 각각의 메모리 블록을 식별하는 것(단계 805a2)은 제 1 코드 섹션으로 제 1 메모리 블록을 식별하는 과정을 포함하고, 식별된 메모리 블록에 코드 섹션들을 저장하는 것(단계 805a3)은 다수의 제 3 심벌 라이브러리들을 제 1 메모리 블록에 저장하는 과정을 포함한다.
대안으로, 다수의 제 1 심벌 라이브러리들을 다수의 제 2 코드 섹션에 배열하는 것(단계 804)은 제 1 코드 섹션에 제 1 심벌 라이브러리를 배열하는 과정을 포함한다. 그후, 단계 805a3에서 각각의 메모리 블록을 해당 코드 섹션으로 식별하는 것은 제 1 메모리 블록을 제 1 코드 섹션으로 식별하는 과정을 포함하고, 식별된 메모리 블록에 코드 섹션을 저장하는 것(단계 805a3)은 제 1 심벌 라이브러리를 제 1 메모리 블록에 저장하는 과정을 포함한다.
다수의 제 1 심벌 라이브러리들을 다수의 제 2 코드 섹션에 배열하는 것(단계 804)은 배열된 심벌 라이브러리들을 수용하도록 코드 섹션들의 크기를 정하는 과정을 포함한다. 그후, 연속적으로 어드레싱되는 다수의 제 2 메모리 블록을 생성하는 것(단계 805a1)은 해당 코드 섹션을 수용하도록 메모리 블록의 크기를 설정하는 과정을 포함한다. 대안으로, 다수의 제 1 심벌 라이브러리들을 다수의 제 2 코 드 섹션으로 배열하는 것(단계804)은 배열된 심벌 라이브러리들보다 큰 크기를 수용하도록 코드 섹션의 크기를 지정하는 과정을 포함한다.
에어 링크 인터페이스를 통한 현장 업데이트를 위한 무선 장치 시스템 소프트웨어를 조직하는 시스템 및 방법이 제시되었다. 이 시스템은, 심벌 라이브러리들 내 심벌들의 오프셋 어드레스와 메모리 내 코드섹션의 시작 어드레스에 액세스하기 위한 테이블을 이용하여, 코드 섹션의 심벌 라이브러리들 배열 때문에 쉽게 업데이트될 수 있다. 동적 명령 세트 이용은 상기 장치의 구체적 특성을 바탕으로 각각의 무선 장치마다 개별적인 수정을 가능하게 한다.
Claims (32)
- 무선 통신 장치(104)의 소프트웨어(field upgradeable system software) 관리 방법에 있어서, 상기 방법은,- 다수의 심벌들을 무선 통신 장치(204)의 메모리 내 다수의 코드 섹션(302, 304, 306, 308)에 배열하는 단계,- 각각의 심벌에 대한 심벌 식별자들을, 이에 대응하는 오프셋 어드레스와, 각각의 코드 섹션(302, 304, 306, 308)에 대한 대응하는 코드 섹션 식별자들과 상호참조하는 심벌 오프셋 어드레스 표(328)를 형성하는 단계로서, 이때, 심벌 오프셋 어드레스 표는 메모리 내 다수의 코드 섹션의 패치 매니저 코드 섹션(308)에 저장되는 것을 특징으로 하는 단계,- 무선 통신 네트워크를 통해 소프트웨어 업데이트(102)를 수신하는 단계로서, 이때, 상기 소프트웨어 업데이트(102)는 심벌 오프셋 어드레스 표(328)의 일부분 이상을 업데이트하기 위한 업데이트 심벌과 업데이트 심벌 오프셋 어드레스 표 부분을 포함하는 것을 특징으로 하는 단계,- 다수의 코드 섹션(302, 304, 306, 308) 중 하나에 업데이트 심벌을 저장하는 단계,- 업데이트 심벌 오프셋 어드레스 표 부분을 심벌 오프셋 어드레스 표(328)에 병합하는 단계,- 코드 섹션(302, 304, 306, 308)들의 시작점에 시작 어드레스(318, 320, 322, 324, 408, 410, 412, 414)를 저장하는 단계, 그리고,- 패치 매니저 코드 섹션(308)에 코드 섹션 어드레스 표(326)를 저장하는 단계로서, 이때, 코드 섹션 어드레스 표(326)는 코드 섹션(302, 304, 306, 308)들을 이에 대응하는 시작 어드레스(318, 320, 322, 324, 408, 410, 412, 414)와 상호참조하는 것을 특징으로 하는 단계를 포함하는 것을 특징으로 하는 무선 통신 장치의 소프트웨어 관리 방법.
- 제 1 항에 있어서, 심벌은 판독-기록 데이터(330)를 포함하며, 상기 배열하는 단계는, 공유된 판독-기록 코드 섹션에 상기 판독-기록 데이터를 배열하는 단계를 포함하는 것을 특징으로 하는 무선 통신 장치의 소프트웨어 관리 방법.
- 제 1 항에 있어서, 상기 형성하는 단계는- 심벌 액세서 코드(symbol accessor code)(332)를 형성하는 단계,- 다수의 코드 섹션(302, 304, 306, 308)의 패치 매니저 코드 섹션(308)에 심벌 액세서 코드(332)를 배열하는 단계,- 패치 매니저 코드 섹션(308)에 심벌 액세서 코드 어드레스(334)를 저장하는 단계, 그리고,- 심벌 식별자 및 코드 섹션 식별자를 이용하여, 다수의 심벌들 중 검색되는 심벌의 어드레스를 연산하기 위해 심벌 액세서 코드(332)를 호출하는 단계를 포함하는 것을 특징으로 하는 무선 통신 장치의 소프트웨어 관리 방법.
- 제 3 항에 있어서, 상기 호출하는 단계는, 검색되는 심벌의 어드레스 연산을 위해 코드 섹션 어드레스 표와 심벌 오프셋 어드레스 표(328)에 액세스하는 단계를 포함하는 것을 특징으로 하는 무선 통신 장치의 소프트웨어 관리 방법.
- 삭제
- 제 3 항에 있어서, 상기 심벌 액세서 코드(332)를 배열하는 단계는, 판독-기록 데이터(330), 코드 섹션 어드레스 표, 심벌 오프셋 어드레스 표(328) 및 심벌 액세서 코드(332) 모두를 코드 섹션(302, 304, 306, 308)들 중 하나에 배열하는 단계를 포함하는 것을 특징으로 하는 무선 통신 장치의 소프트웨어 관리 방법.
- 제 6 항에 있어서, 상기 방법은 현장 업그레이드형 시스템 소프트웨어를 실행하는 단계를 추가로 포함하고, 상기 실행하는 단계는,- 상기 판독-기록 데이터(330)와, 코드 섹션 어드레스 표와, 심벌 오프셋 어드레스 표(328)와, 심벌 액세서 코드(332)와, 심벌 액세서 코드 어드레스(334)를 코드 섹션으로부터 판독-기록 휘발성 메모리(114)로 로딩하는 단계, 그리고- 상기 판독-기록 데이터(330)와, 코드 섹션 어드레스 표와, 심벌 오프셋 어드레스 표(328)와, 심벌 액세서 코드(332)와, 심벌 액세서 코드 어드레스(334)를 판독-기록 휘발성 메모리로부터 액세스하는 단계를 포함하는 것을 특징으로 하는 무선 통신 장치의 소프트웨어 관리 방법.
- 제 1 항에 있어서, 코드 섹션(302, 304, 306, 308)들은,- 비휘발성 메모리(108)에 연속적으로 어드레싱되는 다수의 메모리 블록들을 생성하는 단계,- 각각의 코드 섹션(302, 304, 306, 308)을 연속적으로 어드레싱되는 다수의 메모리 블록 중 하나씩에 대응시키는 단계, 그리고- 각각의 코드 섹션(302, 304, 306, 308)을 대응하는 각각의 메모리 블록에 저장하는 단계에 의해 형성되는 것을 특징으로 하는 무선 통신 장치의 소프트웨어 관리 방법.
- 제 8 항에 있어서, 다수의 심벌들을 다수의 코드 섹션(302, 304, 306, 308)에 배열하는 단계는, 한개의 단일 코드 섹션(302, 304, 306, 308)에 두개 이상의 심벌들을 배열하는 것을 특징으로 하는 무선 통신 장치의 소프트웨어 관리 방법.
- 제 8 항에 있어서, 다수의 심벌들을 다수의 코드 섹션(302, 304, 306, 308)에 배열하는 단계는, 하나의 단일 심벌을 하나의 단일 코드 섹션에 배열하는 단계를 포함하는 것을 특징으로 하는 무선 통신 장치의 소프트웨어 관리 방법.
- 제 8 항에 있어서, 다수의 심벌들을 배열하는 단계는, 코드 섹션 내에 포함된 현재의 심벌보다 큰 업데이트 심벌의 크기를 수용하도록 코드 섹션의 크기를 조정(re-size)하는 단계를 포함하는 것을 특징으로 하는 무선 통신 장치의 소프트웨어 관리 방법.
- 현장 업그레이드형 시스템 소프트웨어를 구비한 무선 통신 장치(104)에 있어서, 상기 장치는- 무선 통신 장치(104)의 메모리 내 다수의 코드 섹션(302, 304, 306, 308)에 저장되는 실행가능한 현장 업그레이드형 시스템 소프트웨어로서, 이때, 각각의 코드 섹션(302, 304, 306, 308)은 한개 이상의 심벌들을 포함하고, 상기 심벌들은 코드 섹션의 시작 어드레스(318, 320, 322, 324, 408, 410, 412, 414)로부터의 오프셋을 나타내는 오프셋 어드레스를 가지는 것을 특징으로 하는 상기 현장 업그레이드형 시스템 소프트웨어,- 심벌들을, 오프셋 어드레스 및 코드 섹션(302, 304, 306, 308)들과 상호참조하는 심벌 오프셋 어드레스 표(328), 그리고,- 코드 섹션(302, 304, 306, 308)들을 코드 섹션 시작 어드레스(318, 320, 322, 324, 408, 410, 412, 414)들과 상호참조하는 코드 섹션 어드레스 표를 포함하는 것을 특징으로 하는 현장 업그레이드형 시스템 소프트웨어를 구비한 무선 통신 장치.
- 제 12 항에 있어서,다수의 코드 섹션(302, 304, 306, 308)들은 공유된 판독-기록 섹션을 포함하며, 다수의 심벌들은 판독-기록 섹션에 배열된 판독-기록 데이터를 포함하는 것을 특징으로 하는 현장 업그레이드형 시스템 소프트웨어를 구비한 무선 통신 장치.
- 제 12 항에 있어서, 다수의 심벌들은, 검색되는 심벌의 어드레스를 계산하기 위해 다수의 코드 섹션(302, 304, 306, 308) 중 한개의 코드 섹션에 배열되는 심벌 액세서 코드(332)를 포함하고,상기 장치는 심벌 액세서 코드 어드레스(334)의 저장을 위한 제 1 위치를 더 포함하는 것을 특징으로 하는 현장 업그레이드형 시스템 소프트웨어를 구비한 무선 통신 장치.
- 제 14 항에 있어서, 상기 검색되는 심벌의 어드레스를 계산하기 위해, 상기 심벌 액세서 코드(332)는 코드 섹션 어드레스 표와 심벌 오프셋 어드레스 표(328)에 액세스하는 것을 특징으로 하는 현장 업그레이드형 시스템 소프트웨어를 구비한 무선 통신 장치.
- 제 15 항에 있어서, 상기 제 1 위치가 상기 한개의 코드 섹션에 위치하는 것을 특징으로 하는 현장 업그레이드형 시스템 소프트웨어를 구비한 무선 통신 장치.
- 제 15 항에 있어서, 판독-기록 데이터(330)와, 코드 섹션 어드레스 표(326)와, 심벌 오프셋 어드레스 표(328)와, 심벌 액세서 코드(332)가 패치 매니저 코드 섹션(308)에 배열되는 것을 특징으로 하는 현장 업그레이드형 시스템 소프트웨어를 구비한 무선 통신 장치.
- 제 17 항에 있어서, 상기 장치는,- 판독-기록 휘발성 메모리(114)를 추가로 포함하고, 시스템 소프트웨어의 실행 중 액세스를 위해, 판독-기록 데이터(330)와, 코드 섹션 어드레스 표와, 심벌 오프셋 어드레스 표(328)와, 심벌 액세서 코드(332)와, 심벌 액세서 코드 어드레스(334)가 패치 매니저 코드 섹션(308)으로부터 상기 판독-기록 휘발성 메모리(114)로 로딩되는 것을 특징으로 하는 현장 업그레이드형 시스템 소프트웨어를 구비한 무선 통신 장치.
- 제 12 항에 있어서, 상기 메모리는 연속적으로 어드레싱되는 다수의 메모리 블록들을 포함하며, 각각의 메모리 블록은 상기 다수의 코드 섹션(302, 304, 306, 308) 중에서 이에 대응하는 코드 섹션(302, 304, 306, 308)을 저장하는 것을 특징으로 하는 현장 업그레이드형 시스템 소프트웨어를 구비한 무선 통신 장치.
- 제 19 항에 있어서, 상기 장치는 제 1 코드 섹션을 저장하기 위한 메모리 블록을 더 포함하며, 이때, 상기 제 1 코드 섹션에는 다수의 심벌들이 배열되는 것을 특징으로 하는 현장 업그레이드형 시스템 소프트웨어를 구비한 무선 통신 장치.
- 제 19 항에 있어서, 상기 장치는 제 1 코드 섹션을 저장하기 위한 메모리 블럭을 더 포함하며, 이때 상기 제 1 코드 섹션에는 하나의 단일 심벌이 배열되는 것을 특징으로 하는 현장 업그레이드형 시스템 소프트웨어를 구비한 무선 통신 장치.
- 제 19 항에 있어서, 다수의 코드 섹션의 각각은 배열된 심벌을 수용하는 데 필요한 크기보다 더 큰 크기를 가지는 것을 특징으로 하는 현장 업그레이드형 시스템 소프트웨어를 구비한 무선 통신 장치.
- 제 12 항에 있어서, 상기 메모리는 기록가능한 비휘발성인 메모리인 것을 특징으로 하는 현장 업그레이드형 시스템 소프트웨어를 구비한 무선 통신 장치.
- 삭제
- 삭제
- 삭제
- 삭제
- 삭제
- 삭제
- 삭제
- 삭제
- 삭제
Applications Claiming Priority (11)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US09/916,460 US7159214B2 (en) | 2001-07-26 | 2001-07-26 | System and method for compacting field upgradeable wireless communication device software code sections |
US09/917,026 US7328007B2 (en) | 2001-07-26 | 2001-07-26 | System and method for organizing wireless communication device system software |
US09/916,460 | 2001-07-26 | ||
US09/916,900 | 2001-07-26 | ||
US09/916,900 US7027806B2 (en) | 2001-07-26 | 2001-07-26 | System and method for field downloading a wireless communications device software code section |
US09/917,026 | 2001-07-26 | ||
US09/927,131 | 2001-08-10 | ||
US09/927,131 US7143407B2 (en) | 2001-07-26 | 2001-08-10 | System and method for executing wireless communications device dynamic instruction sets |
US09/969,305 US7386846B2 (en) | 2001-07-26 | 2001-10-02 | System and method for the management of wireless communications device system software downloads in the field |
US09/969,305 | 2001-10-02 | ||
PCT/IB2002/002867 WO2003010658A2 (en) | 2001-07-26 | 2002-07-22 | System and method for organizing field upgradable wireless communication device software |
Publications (2)
Publication Number | Publication Date |
---|---|
KR20040022461A KR20040022461A (ko) | 2004-03-12 |
KR100940178B1 true KR100940178B1 (ko) | 2010-02-03 |
Family
ID=27542295
Family Applications (10)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
KR1020047000719A KR100940178B1 (ko) | 2001-07-26 | 2002-07-22 | 무선 통신 장치의 현장 업그레이드형 소프트웨어 조직시스템 및 방법 |
KR1020047000721A KR100940180B1 (ko) | 2001-07-26 | 2002-07-22 | 무선 통신 장치의 업데이트 명령 실행 방법 및 시스템 |
KR1020047000723A KR100911604B1 (ko) | 2001-07-26 | 2002-07-22 | 무선 통신 장치의 시스템 소프트웨어 다운로드 관리시스템 및 방법 |
KR1020047000718A KR100913658B1 (ko) | 2001-07-26 | 2002-07-23 | 현장 업그레이드형 무선 통신 장치 소프트웨어 코드 섹션치밀화 시스템 및 방법 |
KR1020047000725A KR100918162B1 (ko) | 2001-07-26 | 2002-07-23 | 무선 통신 장치 시스템 소프트웨어의 현장 진단 시스템 및방법 |
KR1020047000726A KR100913659B1 (ko) | 2001-07-26 | 2002-07-23 | 무선 통신 장치의 지속성 데이터 업데이트 방법 및 시스템 |
KR1020047000716A KR100940179B1 (ko) | 2001-07-26 | 2002-07-23 | 무선 통신 장치 소프트웨어 코드 섹션의 현장 다운로드시스템 및 방법 |
KR1020047001087A KR100932058B1 (ko) | 2001-07-26 | 2002-07-25 | 피어 투 피어 핸드셋 통신 시스템 및 방법 |
KR1020047001088A KR100984895B1 (ko) | 2001-07-26 | 2002-07-25 | 핸드셋 리프로그래밍의 보안성 개선 시스템 및 방법 |
KR1020047001086A KR100817387B1 (ko) | 2001-07-26 | 2002-07-25 | 양방향 통신 및 동적 명령 세트 실행 시스템 및 방법 |
Family Applications After (9)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
KR1020047000721A KR100940180B1 (ko) | 2001-07-26 | 2002-07-22 | 무선 통신 장치의 업데이트 명령 실행 방법 및 시스템 |
KR1020047000723A KR100911604B1 (ko) | 2001-07-26 | 2002-07-22 | 무선 통신 장치의 시스템 소프트웨어 다운로드 관리시스템 및 방법 |
KR1020047000718A KR100913658B1 (ko) | 2001-07-26 | 2002-07-23 | 현장 업그레이드형 무선 통신 장치 소프트웨어 코드 섹션치밀화 시스템 및 방법 |
KR1020047000725A KR100918162B1 (ko) | 2001-07-26 | 2002-07-23 | 무선 통신 장치 시스템 소프트웨어의 현장 진단 시스템 및방법 |
KR1020047000726A KR100913659B1 (ko) | 2001-07-26 | 2002-07-23 | 무선 통신 장치의 지속성 데이터 업데이트 방법 및 시스템 |
KR1020047000716A KR100940179B1 (ko) | 2001-07-26 | 2002-07-23 | 무선 통신 장치 소프트웨어 코드 섹션의 현장 다운로드시스템 및 방법 |
KR1020047001087A KR100932058B1 (ko) | 2001-07-26 | 2002-07-25 | 피어 투 피어 핸드셋 통신 시스템 및 방법 |
KR1020047001088A KR100984895B1 (ko) | 2001-07-26 | 2002-07-25 | 핸드셋 리프로그래밍의 보안성 개선 시스템 및 방법 |
KR1020047001086A KR100817387B1 (ko) | 2001-07-26 | 2002-07-25 | 양방향 통신 및 동적 명령 세트 실행 시스템 및 방법 |
Country Status (9)
Country | Link |
---|---|
EP (12) | EP1410191A2 (ko) |
JP (11) | JP4104546B2 (ko) |
KR (10) | KR100940178B1 (ko) |
CN (10) | CN1288553C (ko) |
AT (9) | ATE387658T1 (ko) |
AU (9) | AU2002319572A1 (ko) |
DE (7) | DE60205755T2 (ko) |
ES (9) | ES2300454T3 (ko) |
WO (10) | WO2003010663A2 (ko) |
Families Citing this family (39)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US7143407B2 (en) * | 2001-07-26 | 2006-11-28 | Kyocera Wireless Corp. | System and method for executing wireless communications device dynamic instruction sets |
JP4417123B2 (ja) | 2003-02-19 | 2010-02-17 | パナソニック株式会社 | ソフトウェア更新方法及び無線通信装置 |
US7644404B2 (en) | 2003-06-04 | 2010-01-05 | Hewlett-Packard Development Company, L.P. | Network having customizable generators and electronic device having customizable updating software |
US7873956B2 (en) | 2003-09-25 | 2011-01-18 | Pantech & Curitel Communications, Inc. | Communication terminal and communication network for partially updating software, software update method, and software creation device and method therefor |
US7257583B2 (en) | 2004-01-09 | 2007-08-14 | Microsoft Corporation | System and method for updating an on-device application catalog in a mobile device receiving a push message from a catalog server indicating availability of an application for download |
KR100620729B1 (ko) * | 2004-03-31 | 2006-09-13 | 주식회사 팬택앤큐리텔 | 소프트웨어 이미지 생성 방법 |
KR100841510B1 (ko) * | 2004-05-18 | 2008-06-25 | 키오세라 와이어리스 코포레이션 | 무선 통신 장치를 위한 모듈식 데이터 구성요소 |
GB2416876B (en) * | 2004-08-03 | 2007-01-10 | Nec Technologies | Export file processing within a mobile radio communications device |
US7512939B2 (en) * | 2004-10-05 | 2009-03-31 | Neopost Technologies | System and method of secure updating of remote device software |
EP1659810B1 (en) * | 2004-11-17 | 2013-04-10 | TELEFONAKTIEBOLAGET LM ERICSSON (publ) | Updating configuration parameters in a mobile terminal |
US9148409B2 (en) | 2005-06-30 | 2015-09-29 | The Chamberlain Group, Inc. | Method and apparatus to facilitate message transmission and reception using different transmission characteristics |
US8422667B2 (en) | 2005-01-27 | 2013-04-16 | The Chamberlain Group, Inc. | Method and apparatus to facilitate transmission of an encrypted rolling code |
USRE48433E1 (en) | 2005-01-27 | 2021-02-09 | The Chamberlain Group, Inc. | Method and apparatus to facilitate transmission of an encrypted rolling code |
CA2577244A1 (en) * | 2005-04-18 | 2006-10-26 | Research In Motion Limited | Method and system for controlling software version updates |
CN100442708C (zh) * | 2005-06-17 | 2008-12-10 | 上海华为技术有限公司 | 一种主备备份的方法及系统 |
CN100476728C (zh) * | 2005-08-19 | 2009-04-08 | 光宝科技股份有限公司 | 应用程序更新方法及使用上述方法的移动通讯装置 |
CN100410893C (zh) * | 2005-09-28 | 2008-08-13 | 联想(北京)有限公司 | 自行修复嵌入式设备的主控应用程序的方法及设备 |
CN1980447B (zh) * | 2005-12-06 | 2010-06-16 | 中兴通讯股份有限公司 | 一种通信系统软件版本的平滑升级方法 |
CN101401072B (zh) * | 2006-03-10 | 2010-12-15 | 富士通株式会社 | 应用补丁筛选装置以及应用补丁筛选方法 |
US8209676B2 (en) | 2006-06-08 | 2012-06-26 | Hewlett-Packard Development Company, L.P. | Device management in a network |
EP2047420A4 (en) | 2006-07-27 | 2009-11-18 | Hewlett Packard Development Co | USER EXPERIENCE AND DEPENDENCE MANAGEMENT IN A MOBILE DEVICE |
CN100403263C (zh) * | 2006-08-16 | 2008-07-16 | 华为技术有限公司 | 按配置下载设备软件的方法 |
KR100924647B1 (ko) * | 2008-08-07 | 2009-11-02 | 주식회사 케이티 | 모바일 플랫폼 런타임 다이나믹 링킹 라이브러리 관리 방법및 시스템 |
KR20110135989A (ko) | 2009-04-07 | 2011-12-20 | 센션트 컬러스 엘엘씨 | 자가-분산 입자 및 그의 제조 및 사용 방법 |
CN101539885B (zh) * | 2009-04-23 | 2011-06-08 | 大唐微电子技术有限公司 | 一种无线通信模块软件自主空中升级的方法、装置及系统 |
US8402217B2 (en) * | 2009-09-15 | 2013-03-19 | Marvell International Ltd. | Implementing RAID in solid state memory |
CN102253847A (zh) * | 2010-05-19 | 2011-11-23 | 宏碁股份有限公司 | 制作系统软件的系统及系统软件的部署方法 |
US8756256B2 (en) * | 2010-05-26 | 2014-06-17 | Qualcomm Incorporated | Method and systems for the management of non volatile items and provisioning files for a communication device with multiple service accounts |
EP2917837B1 (en) * | 2012-11-09 | 2019-01-02 | Coherent Logix Incorporated | Real time analysis and control for a multiprocessor system |
US10064251B2 (en) * | 2013-03-15 | 2018-08-28 | Cree, Inc. | Updatable lighting fixtures and related components |
CN103345412B (zh) * | 2013-07-10 | 2016-08-24 | 华为技术有限公司 | 打补丁的方法及装置 |
US10652743B2 (en) | 2017-12-21 | 2020-05-12 | The Chamberlain Group, Inc. | Security system for a moveable barrier operator |
CA3139264A1 (en) * | 2018-05-04 | 2019-11-07 | Herdx, Inc. | Food supply tracking, verification, and feedback system |
US11074773B1 (en) | 2018-06-27 | 2021-07-27 | The Chamberlain Group, Inc. | Network-based control of movable barrier operators for autonomous vehicles |
WO2020028502A1 (en) | 2018-08-01 | 2020-02-06 | The Chamberlain Group, Inc. | Movable barrier operator and transmitter pairing over a network |
KR102176204B1 (ko) | 2018-10-15 | 2020-11-09 | 김용대 | 유명인 사용물품 기부 중개 서비스 방법 |
US10997810B2 (en) | 2019-05-16 | 2021-05-04 | The Chamberlain Group, Inc. | In-vehicle transmitter training |
JP7461755B2 (ja) * | 2020-02-21 | 2024-04-04 | 日立Astemo株式会社 | 情報処理装置、プログラム更新システム、及びプログラム更新方法 |
US11588924B2 (en) * | 2020-10-29 | 2023-02-21 | Hewlett Packard Enterprise Development Lp | Storage interface command packets over fibre channel with transport and network headers as payloads |
Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO1993000633A1 (en) * | 1991-06-21 | 1993-01-07 | Pure Software, Inc. | Method and apparatus for modifying relocatable object code files and monitoring programs |
DE19502728A1 (de) * | 1995-01-28 | 1996-08-01 | Philips Patentverwaltung | Telekommunikationsvorrichtung |
EP0889405A1 (en) * | 1997-06-19 | 1999-01-07 | Nec Corporation | Software debugging method |
GB2349485A (en) * | 1999-04-23 | 2000-11-01 | Ibm | Applying software patches across multi-platform systems |
Family Cites Families (29)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
GB8901932D0 (en) * | 1989-01-28 | 1989-03-15 | Int Computers Ltd | Data processing system |
FR2662891A1 (fr) * | 1990-05-30 | 1991-12-06 | Cit Alcatel | Dispositif de telechargement de logiciel pour un terminal de telecommunication. |
JPH07182178A (ja) * | 1993-02-19 | 1995-07-21 | Nec Corp | プリロードモジュール修正システム |
US5488648A (en) * | 1993-08-17 | 1996-01-30 | Telefonaktiebolaget L M Ericsson | Behavior monitoring and analyzing system for stored program controlled switching system |
US5845090A (en) * | 1994-02-14 | 1998-12-01 | Platinium Technology, Inc. | System for software distribution in a digital computer network |
JP3140906B2 (ja) * | 1994-04-12 | 2001-03-05 | 株式会社エヌ・ティ・ティ・データ | システムファイルの更新及び復元方法 |
US5734904A (en) * | 1994-11-14 | 1998-03-31 | Microsoft Corporation | Method and system for calling one of a set of routines designed for direct invocation by programs of a second type when invoked by a program of the first type |
JPH08166877A (ja) * | 1994-12-13 | 1996-06-25 | Olympus Optical Co Ltd | 修正プログラムの実行可能なワンチップマイクロコンピュータ及びrom修正可能なマイクロコンピュータ |
US5673317A (en) * | 1995-03-22 | 1997-09-30 | Ora Electronics, Inc. | System and method for preventing unauthorized programming of wireless network access devices |
US5699275A (en) * | 1995-04-12 | 1997-12-16 | Highwaymaster Communications, Inc. | System and method for remote patching of operating code located in a mobile unit |
DE19527808C2 (de) * | 1995-07-28 | 1999-04-01 | Siemens Ag | Verfahren zum Modifizieren der Softwareprozeduren eines Kommunikationssystems |
DE19543843C2 (de) * | 1995-11-24 | 2001-02-08 | Acer Peripherals Inc | Verfahren zur Aktualisierung der Software in einem mikrocomputergestützten Telefon |
WO1998009208A2 (en) * | 1996-08-28 | 1998-03-05 | Wind River Systems, Inc. | A tool for software diagnosis divided across multiple processors |
US6247065B1 (en) * | 1996-12-26 | 2001-06-12 | At&T Corp. | Messaging platform process |
US6023620A (en) * | 1997-02-26 | 2000-02-08 | Telefonaktiebolaget Lm Ecrisson | Method for downloading control software to a cellular telephone |
US5938766A (en) * | 1997-03-21 | 1999-08-17 | Apple Computer, Inc. | System for extending functionality of a digital ROM using RAM/ROM jump tables and patch manager for updating the tables |
SE512110C2 (sv) * | 1997-06-17 | 2000-01-24 | Ericsson Telefon Ab L M | System och förfarande för att kundanpassa trådlösa kommunikationsenheter |
US5974312A (en) * | 1997-07-10 | 1999-10-26 | Ericsson Inc. | System and method for updating a memory in an electronic device via wireless data transfer |
US6496979B1 (en) * | 1997-10-24 | 2002-12-17 | Microsoft Corporation | System and method for managing application installation for a mobile device |
JPH11141394A (ja) * | 1997-11-07 | 1999-05-25 | Nissan Motor Co Ltd | 車両制御用メモリ書き換え装置 |
JPH11146011A (ja) * | 1997-11-11 | 1999-05-28 | Nec Corp | 電子メールシステム及び電子メールサーバ及び通信端末 |
JP3337062B2 (ja) * | 1997-11-21 | 2002-10-21 | 日本電気株式会社 | 無線データ転送方法及びそのシステム |
US6275694B1 (en) * | 1997-12-19 | 2001-08-14 | Vlsi Technology, Inc. | Method for remotely updating software code for personal handy phone system equipment |
US6438711B2 (en) * | 1998-07-15 | 2002-08-20 | Intel Corporation | Method and apparatus for performing field diagnostics on a computer system |
US20020073398A1 (en) * | 1998-12-14 | 2002-06-13 | Jeffrey L. Tinker | Method and system for modifying executable code to add additional functionality |
SE516806C2 (sv) * | 1999-05-26 | 2002-03-05 | Ericsson Telefon Ab L M | Sätt för inladdning av programvara i en radioterminal, såsom en mobiltelefon, och tillhörande radioterminal |
US6282647B1 (en) * | 1999-06-02 | 2001-08-28 | Adaptec, Inc. | Method for flashing a read only memory (ROM) chip of a host adapter with updated option ROM bios code |
FR2800963B1 (fr) * | 1999-11-09 | 2001-12-07 | Wavecom Sa | Procede de mise a jour d'un programme principal execute par un module de radiocommunication et/ou de donnees associees a ce programme principal, et module de radiocommunication correspondant |
US7264532B2 (en) * | 2004-12-27 | 2007-09-04 | Tsan-Yao Chen | Cup structure |
-
2002
- 2002-07-22 EP EP02749161A patent/EP1410191A2/en not_active Withdrawn
- 2002-07-22 KR KR1020047000719A patent/KR100940178B1/ko not_active IP Right Cessation
- 2002-07-22 ES ES02749158T patent/ES2300454T3/es not_active Expired - Lifetime
- 2002-07-22 KR KR1020047000721A patent/KR100940180B1/ko not_active IP Right Cessation
- 2002-07-22 JP JP2003515966A patent/JP4104546B2/ja not_active Expired - Fee Related
- 2002-07-22 EP EP02749158A patent/EP1410189B1/en not_active Expired - Lifetime
- 2002-07-22 CN CNB028148320A patent/CN1288553C/zh not_active Expired - Fee Related
- 2002-07-22 EP EP02749157A patent/EP1410188A2/en not_active Withdrawn
- 2002-07-22 WO PCT/IB2002/002875 patent/WO2003010663A2/en not_active Application Discontinuation
- 2002-07-22 AT AT02749158T patent/ATE387658T1/de not_active IP Right Cessation
- 2002-07-22 KR KR1020047000723A patent/KR100911604B1/ko not_active IP Right Cessation
- 2002-07-22 JP JP2003515964A patent/JP2004537120A/ja not_active Withdrawn
- 2002-07-22 CN CNB028148312A patent/CN1275149C/zh not_active Expired - Fee Related
- 2002-07-22 WO PCT/IB2002/002866 patent/WO2003010656A2/en active Application Filing
- 2002-07-22 AU AU2002319572A patent/AU2002319572A1/en not_active Abandoned
- 2002-07-22 JP JP2003515971A patent/JP2005505813A/ja not_active Withdrawn
- 2002-07-22 AU AU2002319568A patent/AU2002319568A1/en not_active Abandoned
- 2002-07-22 CN CNB028148339A patent/CN1275150C/zh not_active Expired - Fee Related
- 2002-07-22 WO PCT/IB2002/002867 patent/WO2003010658A2/en active IP Right Grant
- 2002-07-22 AU AU2002319569A patent/AU2002319569A1/en not_active Abandoned
- 2002-07-23 AT AT02749159T patent/ATE302972T1/de not_active IP Right Cessation
- 2002-07-23 WO PCT/IB2002/002869 patent/WO2003010662A2/en active IP Right Grant
- 2002-07-23 JP JP2003515976A patent/JP4176634B2/ja not_active Expired - Fee Related
- 2002-07-23 CN CNB02814838XA patent/CN1288554C/zh not_active Expired - Fee Related
- 2002-07-23 EP EP05021081A patent/EP1610222B1/en not_active Expired - Lifetime
- 2002-07-23 DE DE60205755T patent/DE60205755T2/de not_active Expired - Lifetime
- 2002-07-23 KR KR1020047000718A patent/KR100913658B1/ko not_active IP Right Cessation
- 2002-07-23 WO PCT/IB2002/002890 patent/WO2003010664A2/en active IP Right Grant
- 2002-07-23 ES ES02749159T patent/ES2247355T3/es not_active Expired - Lifetime
- 2002-07-23 ES ES02749167T patent/ES2249602T3/es not_active Expired - Lifetime
- 2002-07-23 AT AT02749167T patent/ATE305632T1/de not_active IP Right Cessation
- 2002-07-23 CN CNB028148347A patent/CN1235137C/zh not_active Expired - Fee Related
- 2002-07-23 ES ES02749163T patent/ES2263796T3/es not_active Expired - Lifetime
- 2002-07-23 AU AU2002319577A patent/AU2002319577A1/en not_active Abandoned
- 2002-07-23 AT AT02749166T patent/ATE382159T1/de not_active IP Right Cessation
- 2002-07-23 WO PCT/IB2002/002889 patent/WO2003012639A2/en active IP Right Grant
- 2002-07-23 DE DE60211704T patent/DE60211704T2/de not_active Expired - Lifetime
- 2002-07-23 WO PCT/IB2002/002877 patent/WO2003010668A2/en active IP Right Grant
- 2002-07-23 DE DE60206389T patent/DE60206389T2/de not_active Expired - Lifetime
- 2002-07-23 JP JP2003517749A patent/JP4310186B2/ja not_active Expired - Fee Related
- 2002-07-23 JP JP2003515970A patent/JP4073399B2/ja not_active Expired - Fee Related
- 2002-07-23 CN CNB028148371A patent/CN1279447C/zh not_active Expired - Fee Related
- 2002-07-23 KR KR1020047000725A patent/KR100918162B1/ko not_active IP Right Cessation
- 2002-07-23 EP EP02749163A patent/EP1410209B1/en not_active Expired - Lifetime
- 2002-07-23 EP EP02749159A patent/EP1410190B1/en not_active Expired - Lifetime
- 2002-07-23 AT AT02749163T patent/ATE327536T1/de not_active IP Right Cessation
- 2002-07-23 AU AU2002319573A patent/AU2002319573A1/en not_active Abandoned
- 2002-07-23 KR KR1020047000726A patent/KR100913659B1/ko not_active IP Right Cessation
- 2002-07-23 ES ES02749166T patent/ES2299587T3/es not_active Expired - Lifetime
- 2002-07-23 AU AU2002319570A patent/AU2002319570A1/en not_active Abandoned
- 2002-07-23 KR KR1020047000716A patent/KR100940179B1/ko not_active IP Right Cessation
- 2002-07-23 EP EP02749166A patent/EP1410192B1/en not_active Expired - Lifetime
- 2002-07-23 CN CNB028148355A patent/CN1235138C/zh not_active Expired - Fee Related
- 2002-07-23 EP EP02749167A patent/EP1410193B1/en not_active Expired - Lifetime
- 2002-07-23 AU AU2002319576A patent/AU2002319576A1/en not_active Abandoned
- 2002-07-23 JP JP2003515972A patent/JP4278513B2/ja not_active Expired - Fee Related
- 2002-07-25 CN CNB028148401A patent/CN1310488C/zh not_active Expired - Fee Related
- 2002-07-25 ES ES02762622T patent/ES2253553T3/es not_active Expired - Lifetime
- 2002-07-25 ES ES05018919T patent/ES2284112T3/es not_active Expired - Lifetime
- 2002-07-25 AT AT02762622T patent/ATE310354T1/de not_active IP Right Cessation
- 2002-07-25 ES ES02751472T patent/ES2263799T3/es not_active Expired - Lifetime
- 2002-07-25 EP EP05018919A patent/EP1601217B1/en not_active Expired - Lifetime
- 2002-07-25 ES ES02741113T patent/ES2248568T3/es not_active Expired - Lifetime
- 2002-07-25 WO PCT/IB2002/002905 patent/WO2003010932A2/en active IP Right Grant
- 2002-07-25 AU AU2002328167A patent/AU2002328167A1/en not_active Abandoned
- 2002-07-25 CN CNB028148398A patent/CN100378661C/zh not_active Expired - Fee Related
- 2002-07-25 JP JP2003516189A patent/JP4077408B2/ja not_active Expired - Fee Related
- 2002-07-25 JP JP2003518153A patent/JP4101752B2/ja not_active Expired - Fee Related
- 2002-07-25 WO PCT/IB2002/002906 patent/WO2003010942A2/en active IP Right Grant
- 2002-07-25 KR KR1020047001087A patent/KR100932058B1/ko not_active IP Right Cessation
- 2002-07-25 AT AT02751472T patent/ATE327628T1/de not_active IP Right Cessation
- 2002-07-25 AT AT05018919T patent/ATE359681T1/de not_active IP Right Cessation
- 2002-07-25 EP EP02741113A patent/EP1410665B1/en not_active Expired - Lifetime
- 2002-07-25 DE DE60219536T patent/DE60219536T2/de not_active Expired - Lifetime
- 2002-07-25 AT AT02741113T patent/ATE304272T1/de not_active IP Right Cessation
- 2002-07-25 KR KR1020047001088A patent/KR100984895B1/ko not_active IP Right Cessation
- 2002-07-25 AU AU2002355308A patent/AU2002355308A1/en not_active Abandoned
- 2002-07-25 DE DE60206055T patent/DE60206055T2/de not_active Expired - Lifetime
- 2002-07-25 CN CNB02814841XA patent/CN1250035C/zh not_active Expired - Fee Related
- 2002-07-25 EP EP02762622A patent/EP1425894B1/en not_active Expired - Lifetime
- 2002-07-25 DE DE60211719T patent/DE60211719T2/de not_active Expired - Lifetime
- 2002-07-25 KR KR1020047001086A patent/KR100817387B1/ko not_active IP Right Cessation
- 2002-07-25 EP EP02751472A patent/EP1423959B1/en not_active Expired - Lifetime
- 2002-07-25 DE DE60207429T patent/DE60207429T2/de not_active Expired - Lifetime
- 2002-07-25 JP JP2003516197A patent/JP4106020B2/ja not_active Expired - Fee Related
- 2002-07-25 WO PCT/IB2002/002912 patent/WO2003013103A2/en active IP Right Grant
-
2007
- 2007-11-22 JP JP2007303740A patent/JP2008108268A/ja active Pending
Patent Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO1993000633A1 (en) * | 1991-06-21 | 1993-01-07 | Pure Software, Inc. | Method and apparatus for modifying relocatable object code files and monitoring programs |
DE19502728A1 (de) * | 1995-01-28 | 1996-08-01 | Philips Patentverwaltung | Telekommunikationsvorrichtung |
EP0889405A1 (en) * | 1997-06-19 | 1999-01-07 | Nec Corporation | Software debugging method |
GB2349485A (en) * | 1999-04-23 | 2000-11-01 | Ibm | Applying software patches across multi-platform systems |
Also Published As
Similar Documents
Publication | Publication Date | Title |
---|---|---|
KR100940178B1 (ko) | 무선 통신 장치의 현장 업그레이드형 소프트웨어 조직시스템 및 방법 | |
US7027806B2 (en) | System and method for field downloading a wireless communications device software code section | |
US7159214B2 (en) | System and method for compacting field upgradeable wireless communication device software code sections | |
US7143407B2 (en) | System and method for executing wireless communications device dynamic instruction sets | |
US7386846B2 (en) | System and method for the management of wireless communications device system software downloads in the field | |
US7328007B2 (en) | System and method for organizing wireless communication device system software | |
US9554268B2 (en) | System and method for updating persistent data in a wireless communications device |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
A201 | Request for examination | ||
E902 | Notification of reason for refusal | ||
E90F | Notification of reason for final refusal | ||
E701 | Decision to grant or registration of patent right | ||
GRNT | Written decision to grant | ||
FPAY | Annual fee payment |
Payment date: 20130109 Year of fee payment: 4 |
|
FPAY | Annual fee payment |
Payment date: 20131217 Year of fee payment: 5 |
|
FPAY | Annual fee payment |
Payment date: 20141212 Year of fee payment: 6 |
|
LAPS | Lapse due to unpaid annual fee |