KR100390645B1 - 이동통신단말기 시스템에서 소모전류를 줄이기 위한 방법 - Google Patents
이동통신단말기 시스템에서 소모전류를 줄이기 위한 방법 Download PDFInfo
- Publication number
- KR100390645B1 KR100390645B1 KR10-2001-0045449A KR20010045449A KR100390645B1 KR 100390645 B1 KR100390645 B1 KR 100390645B1 KR 20010045449 A KR20010045449 A KR 20010045449A KR 100390645 B1 KR100390645 B1 KR 100390645B1
- Authority
- KR
- South Korea
- Prior art keywords
- idle
- task
- value
- valid
- program
- Prior art date
Links
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F1/00—Details not covered by groups G06F3/00 - G06F13/00 and G06F21/00
- G06F1/26—Power supply means, e.g. regulation thereof
- G06F1/32—Means for saving power
- G06F1/3203—Power management, i.e. event-based initiation of a power-saving mode
- G06F1/3234—Power saving characterised by the action undertaken
- G06F1/324—Power saving characterised by the action undertaken by lowering clock frequency
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04B—TRANSMISSION
- H04B1/00—Details of transmission systems, not covered by a single one of groups H04B3/00 - H04B13/00; Details of transmission systems not characterised by the medium used for transmission
- H04B1/38—Transceivers, i.e. devices in which transmitter and receiver form a structural unit and in which at least one part is used for functions of transmitting and receiving
- H04B1/40—Circuits
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F1/00—Details not covered by groups G06F3/00 - G06F13/00 and G06F21/00
- G06F1/26—Power supply means, e.g. regulation thereof
- G06F1/32—Means for saving power
- G06F1/3203—Power management, i.e. event-based initiation of a power-saving mode
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F1/00—Details not covered by groups G06F3/00 - G06F13/00 and G06F21/00
- G06F1/26—Power supply means, e.g. regulation thereof
- G06F1/32—Means for saving power
- G06F1/3203—Power management, i.e. event-based initiation of a power-saving mode
- G06F1/3234—Power saving characterised by the action undertaken
- G06F1/329—Power saving characterised by the action undertaken by task scheduling
-
- Y—GENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
- Y02—TECHNOLOGIES OR APPLICATIONS FOR MITIGATION OR ADAPTATION AGAINST CLIMATE CHANGE
- Y02D—CLIMATE CHANGE MITIGATION TECHNOLOGIES IN INFORMATION AND COMMUNICATION TECHNOLOGIES [ICT], I.E. INFORMATION AND COMMUNICATION TECHNOLOGIES AIMING AT THE REDUCTION OF THEIR OWN ENERGY USE
- Y02D10/00—Energy efficient computing, e.g. low power processors, power management or thermal management
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Computer Networks & Wireless Communication (AREA)
- Signal Processing (AREA)
- Telephone Function (AREA)
- Mobile Radio Communication Systems (AREA)
Abstract
본 발명은 시스템에서 불필요하게 소모되는 전류를 줄이기 위한 방법에 관한 기술로서, 타이머와, 클록 속도를 가변할 수 있는 피엘엘(PLL)을 구비한 이동통신단말기 시스템에서, 상기 시스템의 프로그램이 수행하는 모든 유효한 태스크가 블록킹된 상태에서의 단순무한 루프를 수행하는 태스크를 상기 시스템의 아이들 태스크로 설정하여, 상기 타이머에 의해 일정시간마다 발생하는 타이머 인터럽트에 따라 일정시간동안 상기 아이들 태스크의 전역변수 값을 카운트하여 상기 아이들 태스크의 전역변수 값을 상기 시스템의 프로그램의 아이들 테스크의 기준값으로 저장하고, 상기 시스템의 프로그램이 유효한 태스크를 수행하면, 상기 타이머에 의해 일정시간마다 발생하는 타이머 인터럽트에 따라, 일정시간동안 상기 유효한 태스크가 상기 아이들 태스크를 점유하는 상기 아이들 태스크의 전역변수 값을 카운트하고, 상기 아이들 태스크의 전역변수 값을 상기 유효한 태스크의 아이들 값으로 저장함으로써, 상기 아이들 테스크의 기준값으로 상기 측정된 유효한 태스크의 아이들 값을 나누어 상기 시스템의 프로그램 아이들 률을 산출하여 상기 시스템의 프로그램 아이들 률에 따라 피엘엘 값을 변경하여 상기 CPU의 메인 클록 주파수를 가변시켜 시스템에서 불필요하게 소모되는 전류를 줄이는 방법을 제공한다.
Description
본 발명은 전자기기 시스템에서 소모전류를 줄이기 위한 방법에 관한 것으로, 특히 이동통신단말기, PDA(Personal Digital Assistant), 노트북(Note Book) 시스템에서 소모전류를 줄이기 위한 방법에 관한 것이다.
통상적으로 이동통신단말기 시스템의 동작모드를 크게 구분하면, 사용중인 모드(Busy 또는 Traffic mode)와 사용중이지 않은 대기모드로 구분할 수 있다. 그리고 상기 대기모드도 사용자의 키입력에 대응하여 통화를 수행하도록 할 수 있는 통화대기중 모드(Idle mode)와, 소정의 시간 이상동안 사용되지 않을 경우 전력의 소모를 최소화하기 위한 수신대기중 모드(Sleep mode)의 두 가지로 분류할 수 있다.
상기 통화대기중 모드인 아이들 모드의 경우에 전원은 이동통신단말기의 각부에 전원이 인가되고 있는 상태이며, 수신대기중 모드인 슬립 모드의 경우는 가장 기본적인 표시부, CPU, 메모리 등에 전원이 인가되며, 주기적으로 수신부에 전원이 인가되는 상태이다.
이러한 기존의 방식에서는 시스템의 전류소모를 줄이기 위한 방법으로 슬립용 클록발생기를 따로 구비하여, 트래픽 모드에서는 CPU의 메인 클록을 높은 주파수에 고정시켜 사용하다가 슬립 모드에서는 슬립용 클록발생기로부터 출력되는 낮은 주파수의 클록을 CPU의 메인 클록으로 사용하고 있다.
그런데 이러한 기존의 이동통신단말기 시스템의 동작모드에서 사용되는 CPU 메인 클록의 관점에서 볼 때, 통화(Traffic)상태나 아이들(Idle)상태는 모두 사용중인 모드의 범주에 속하며, 이에 따라 상기 통화(Traffic)상태나 아이들(Idle)상태에서의 시스템은 모두 동일하게 높은 주파수를 갖는 CPU 클록으로 동작하게 된다. 이는 시스템이 상기 각 상태의 동작을 위해 필요한 클록 주파수 이상의 최대 클록 주파수로 동작함을 의미하는 것으로서, 시스템이 아이들 태스크 등을 수행함에 있어 시스템 전체적으로 불필요하게 많은 전류를 소모하게 되는 문제점이 있다. 이는 또한 이동통신단말기의 수신 대기시간을 감소시키는 결과를 초래하게 된다.
따라서 본 발명의 목적은 시스템의 동작상태에 따라 CPU 메인 클록의 주파수를 가변하여 이동통신단말기 시스템의 소모전류를 줄이기 위한 방법을 제공함에 있다.
본 발명의 다른 목적은 이동통신단말기 시스템에서 수신대기 시간을 늘일 수 있는 방법을 제공함에 있다.
상기한 목적들을 달성하기 위한 본 발명의 이동통신단말기 시스템에서 소모전류를 줄이기 위한 방법은, 타이머와, 클록 속도를 가변할 수 있는 피엘엘을 구비한 이동통신단말기 시스템에서, 상기 시스템의 프로그램이 수행하는 모든 유효한 태스크가 블록킹된 상태에서의 단순무한 루프를 수행하는 태스크를 상기 시스템의 아이들 태스크로 설정하는 과정과, 상기 타이머에 의해 일정시간마다 발생하는 타이머 인터럽트에 따라 일정시간동안 상기 아이들 태스크의 전역변수 값을 카운트하여 상기 아이들 태스크의 전역변수 값을 상기 시스템의 프로그램의 아이들 테스크의 기준값으로 저장하는 과정과, 상기 카운트 값을 리셋시키는 과정과, 상기 시스템의 프로그램이 유효한 태스크를 수행하면, 상기 타이머에 의해 일정시간마다 발생하는 타이머 인터럽트에 따라, 일정시간동안 상기 유효한 태스크가 상기 아이들 태스크를 점유하는 상기 아이들 태스크의 전역변수 값을 카운트하고, 상기 아이들 태스크의 전역변수 값을 상기 유효한 태스크의 아이들 값으로 저장하는 과정과, 상기 아이들 테스크의 기준값으로 상기 측정된 유효한 태스크의 아이들 값을 나누어 상기 시스템의 프로그램 아이들 률을 산출하여 저장하는 과정과, 상기 시스템의 프로그램 아이들 률에 따라 피엘엘 값을 변경하여 상기 이동통신단말기 시스템의 중앙처리장치의 메인 클록 주파수를 가변시키는 과정으로 이루어짐을 특징으로 한다.
도 1은 본 발명의 실시 예에 따른 이동통신단말기 시스템의 블록 구성도,
도 2는 본 발명의 실시 예에 따른 이동통신단말기 시스템에서 프로그램 아이들 률을 산출하기 위한 제어흐름도,
도 3은 본 발명의 실시 예에 따른 가변 CPU 클록을 적용한 프로그램 아이들 률과, 고정 CPU 클록에 따른 프로그램 아이들 률을 비교하여 도시한 그래프,
도 4는 도 3의 프로그램 아이들 률을 프로세싱 량으로 도시한 그래프,
도 5는 본 발명의 실시 예에 따른 CPU의 동작 주파수를 결정하기 위한 제어흐름도,
도 6은 본 발명의 실시 예에 따른 CPU의 메인 클록 주파수를 결정하기 위한 변화 가능한 주파수들과, 아이들 태스크의 기준값들과, 유효한 태스크의 적정 아이들 목표값들을 대응하여 보인 표.
이하 본 발명의 바람직한 실시 예를 첨부한 도면을 참조하여 상세히 설명한다. 하기 설명 및 첨부 도면에서 본 발명의 요지를 불필요하게 흐릴 수 있는 공지 기능 및 구성에 대한 상세한 설명은 생략한다. 본 발명의 설명에서는 이동통신단말기 시스템을 일 실시 예로 하여 설명하고 있으나, 이는 본 발명의 설명을 구체적인 실시 예로서 설명한 것이며, 여러 가지 변형이 본 발명의 범위에서 벗어나지 않고 실시할 수 있다. 특히, 이동통신단말기뿐만 아니라 PDA(Personal Digital Assistant), 노트북(Note Book) 등 사용중인 모드와 사용중이지 않은 대기모드로 구분하여 소모전류를 줄이고자 하는 시스템에 적용할 수 있다.
이하 첨부된 도면을 참조하여 본 발명을 상세히 설명한다.
도 1은 본 발명의 실시 예에 따른 이동통신단말기 시스템의 블록 구성도이다. CPU(10)는 이동통신단말기의 전반적인 동작을 제어하며, 특히 본 발명에 따라 소모전류를 줄이기 위한 전반적인 제어를 수행한다. CPU(10)는 이동통신단말기의 전반적인 동작을 수행하기 위한 OS(Operating System)프로그램을 운용하며, OS프로그램 및 OS프로그램에 의해 운용되는 응용프로그램에 의해 아이들 태스크(Idle Task)(100) 및 태스크1(102) 내지 태스크n(104)을 수행한다. 여기서 아이들 태스크는 시스템의 OS프로그램이 어떠한 유효한 태스크도 동작하지 않는 경우, 즉 모든 태스크가 블로킹(Blocking)된 상태에서 수행되는 단순한 무한 루프(Loop)를 수행하는 태스크에 약간의 기능을 넣은 것으로서, 본 발명의 실시 예에 따른 아이들 태스크(100)는 시스템의 소모전류를 줄이기 위해 시스템의 유휴작업이 얼마나 동작되고 있는지를 산출하기 위해 태스크들(100, 102, 104)의 아이들 값을 카운트한다.
타이머(Timer)(14)는 일정시간마다 타이머 인터럽트(Interrupt)를 발생시켜, 인터럽트 서비스 루틴(Interrupt Service Routine)(106)을 호출한다. 인터럽트 서비스 루틴(106)은 일정시간동안 카운트한 태스크들(100, 102, 104)의 카운트한 전역변수 값을 읽어들이고 이를 리셋시키도록 한다. 이때 CPU(10)는 읽어들인 태스크들(100, 102, 104)의 아이들 값을 메모리(미도시함)에 기 저장된 CPU(10)의 메인 클록 주파수에서의 적정 아이들 목표값과 비교하여 이에 따라 CPU(10)의 메인 클록 주파수를 가변할지를 결정한다. PLL(Phase Locked Loop)(12)은 CPU(10)의 클럭 제어 명령(108)에 따라 CPU(10)의 메인 클록 주파수를 가변시킨다.
도 2는 본 발명의 실시 예에 따른 이동통신단말기 시스템에서 프로그램 아이들 률을 산출하기 위한 제어흐름도이다. 이하 도 1 내지 도 2를 참조하여 소모전류를 줄이기 위한 본 발명을 상세히 설명한다.
도 1의 CPU(10)는 도 2의 200단계에서 동작되어야 할 유효한 태스크가 없는지를 판단한다. 그리고 CPU(10)는 동작되어야 할 유효한 태스크가 없으면, 204단계로 진행하여 아이들 태스크를 수행한다. 이때 200단계의 판단 및 203단계에서 수행되는 아이들 태스크는 최소 우선순위 '0'을 가지며, 이동통신단말기 시스템이 사용 대기중 모드(Idle Mode)로 동작하고 있는 상태를 말한다. 즉, 이동통신단말기가 동작되면, 각각의 기능을 가진 다수의 태스크들이 CPU(10)를 점유하게 되는데, 처리해야 할 유효한 태스크가 없는 대기모드에서는 특별한 기능을 가지지 않고 수행되는 아이들 태스크가 CPU(10)를 점유하게 된다. 따라서 아이들 태스크가 수행되는 시간을 측정함으로써 프로그램의 아이들 률을 측정할 수 있다.
프로그램 아이들 률을 구하기 위해 CPU(10)는 아이들 태스크가 CPU(10)를 얼마나 점유하고 있는지를 계산하기 위하여 206단계에서 아이들 태스크를 강제종료하고, 208단계에서 전역변수 값을 카운트하는 기능을 구비한 새로운 아이들 태스크를 생성한다. 새로운 아이들 태스크는 시스템의 프로그램이 수행하는 모든 유효한 태스크가 블록킹된 상태에서의 단순무한 루프를 수행하는 태스크에 전역변수 값 카운트 기능을 구비하며, 사용자가 줄 수 있는 최소 우선순위인 '1'을 할당받는다.
그리고 CPU(10)는 아이들 태스크가 일정시간동안 얼마나 동작되고 있는지를 측정하기 위해 210단계에서 새로운 아이들 태스크를 실행시키고, 일정시간동안 새로운 아이들 태스크의 전역변수 값을 카운트한다. 그리고 CPU(10)는 212단계에서도 1의 타이머(14)에 의한 타이머 인터럽트 발생으로 실행되는 타이머 인터럽트 서비스 루틴(106)에 의하여 전역변수의 변화량을 새로운 아이들 태스크의 아이들 값으로 설정한다. 이때 타이머 인터럽트 서비스 루틴(106)은 전역변수의 변화량을 읽어 들임과 동시에 카운트를 리셋(Reset)시킨다. 212단계에서 설정된 아이들 값은 214단계에서 CPU(10)에 의해 시스템의 프로그램의 아이들 테스크의 기준값으로 저장된다.
CPU(10)는 아이들 태스크의 기준값을 설정하여 저장한 후, 216단계에서 수행될 유효한 태스크를 감지하면, 218단계로 진행하여 유효한 태스크가 일정시간동안 아이들 테스크를 얼마나 점유하고 있는지를 측정하기 위해, 일정시간동안 새로운 아이들 태스크의 전역변수의 변화량을 측정하여 유효한 태스크의 아이들 값(측정값)으로 저장한다.
그리고 220단계에서 CPU(10)는, 218단계에서 측정된 유효한 태스크의 아이들 값을, 214단계에서 저장된 시스템의 프로그램의 아이들 태스크의 기준값으로 나누어 시스템의 프로그램 아이들 률을 계산하고, 이를 저장한다.
즉, 이동통신단말기 시스템의 초기화 수행 후, 유효한 태스크가 동작하지 않고 아이들 태스크만 동작하는 아이들 상태에서, 아이들 태스크가 계속적으로 증가시키는 전역변수의 일정시간동안의 변화량을 아이들 태스크의 기준값으로 하고, 유효한 태스크 수행중에 측정한 아이들 태스크의 측정값을 비교하여 그 비율에 따라서 현재 수행되는 프로그램의 아이들 률을 알 수 있게 된다.
상기한 바와 같이 본 발명에 따른 방법은, 현재 프로그램이 CPU(10)를 얼마나 점유하여 동작하고 있는지를 판단하기 위해 프로그램의 아이들 률을 구하고, 이를 일정하게 유지하도록 PLL(12)을 제어하여 CPU(10)의 클록을 조절함으로써 전체적인 이동통신단말기 시스템의 전류소모를 줄일 수 있다.
본 발명에 따른 이동통신단말기 시스템에서 소모전류를 줄이는 방법에 있어서, 프로그램 아이들 률을 일정하게 유지하도록 CPU(10)의 클록을 가변함에 따른 이점을 도 3 및 도 4를 참조하여 설명한다.
도 3은 본 발명의 실시 예에 따른 가변 CPU 클록을 적용한 프로그램 아이들 률과, 고정 CPU 클록에 따른 프로그램 아이들 률을 비교하여 도시한 그래프이고, 도 4는 도 3의 프로그램 아이들 률을 프로세싱 량으로 도시한 그래프이다.
도 3에 보인 바와 같이 이동통신단말기 시스템은 전체 아이들 률(300)을 1로 하였을 때, 기존의 고정 CPU 클럭(302)을 사용하는 경우에 파워 온(Power On)상태, 아이들 상태 및 트래픽 상태에 따라 프로그램 아이들 률이 가변적임을 알 수 있다. 종래기술은 파워 온 직후 수행하는 태스크가 많은 경우나 트래픽 상태, 그리고 비교적 수행하는 태스크가 적은 아이들 상태에서 모두 동일한 고정 CPU 클록(302)으로 동작한다. 이를 다시 도 4에 보인 바와 같이 수행되는 프로세싱 량으로 도시해보면, 기존의 고정 CPU 클럭(302)을 사용하는 경우에 이동통신단말기 시스템의 상태와 무관하게 각 상태에서 최대 클록으로 태스크를 수행함으로써, 도 4의 낭비되는 CPU 클록(400)이 발생하게 된다. 일반적인 디지털 논리회로(Digital Logic Circuit)에 있어서 대부분의 전류소모는 신호가 스위칭(Switching)될 때, 즉 논리가 '0'에서 '1'로, 또는 그 반대로 변할 때 발생하게 된다. 따라서 의미있는 프로그램 및 유효한 태스크를 수행하고 남는 대다수의 시간을 차지하는 아이들 태스크도 최대 클록으로 수행함으로써, 이동통신단말기 시스템 전체적으로 전류를 필요이상으로 더 많이 소모하게 되는 것이다.
도 3 및 도 4를 참조하여 본 발명에 따른 가변 CPU 클럭(304)을 사용한 경우에 아이들 률 및 프로세싱 량을 종래의 고정 CPU 클럭(302)을 사용한 경우와 비교해 보면, CPU(10)는 처리해야 할 프로그램의 양에 반비례하여 아이들 률을 가진다. 따라서 고정 CPU 클록(302)를 사용하는 시스템에서는 불필요하게 낭비되는 CPU(10) 클록이 발생하고, 이는 결과적으로 시스템 전체에서 전류의 낭비를 가져온다. 반면에, 본 발명에 따른 가변 CPU(10) 클록을 사용하는 경우에는 CPU(10)가 수행하는 태스크의 상태에 따라 불필요하게 높은 주파수로 동작하지 않게 되므로, 도 4에 보인 고정 CPU 클록(302)를 사용하는 경우에 낭비되는 CPU 클록(400)을 방지할 수 있게 된다.
도 2에서 산출한 프로그램 아이들 률을 적정한 수준으로 유지시키지 위해 프로그램 아이들 률에 따라 PLL(12) 값을 변경하여 CPU(10)의 메인 클록 주파수를 가변시킨다. 이때 프로그램 아이들 률로부터 가변되어야 할 CPU(10)의 클록 주파수를 산출하고, 이에 따라 PLL(12) 값을 변경하는 과정은 시간이 비교적 많이 걸리므로, 아이들 태스크의 기준값에 일정하게 목표로 하는 프로그램 아이들 률을 곱한 값과 측정값을 비교하여 CPU(10)의 클록을 조정할 것인가를 결정할 수 있다.
또한, 본 발명에 따라 CPU(10)의 클록을 변경한 경우, 변경된 프로그램 아이들 률을 계산하기 위해서 CPU(10)의 메인 클록에 대하여 변화 가능한 주파수들을설정하고, 이에 대응하여 아이들 태스크에서의 기준값들을 미리 측정하여, 아이들 태스크들의 기준값들 각각에 적정한 율을 곱하여 유효한 태스크의 적정 아이들 목표값들을 계산한다. 그리고, 변화 가능한 CPU 메인 클록의 주파수들과, 아이들 태스크의 기준값들과, 유효한 태스크의 적정 아이들 목표값들을 대응하여 저장하고, 측정된 유효한 태스크의 아이들 값을 상기 대응하여 저장된 유효한 태스크의 적정 아이들 목표값과 비교하여, CPU(10)의 메인 클록 주파수로 조정한다.
이를 도 5 및 도 6을 참조하여 설명하면, 도 5는 본 발명의 실시 예에 따른 CPU의 동작 주파수를 결정하기 위한 제어흐름도이며, 도 6은 본 발명의 실시 예에 따른 CPU의 메인 클록 주파수를 결정하기 위한 변화 가능한 주파수들과, 아이들 태스크의 기준값들과, 유효한 태스크의 적정 아이들 목표값들을 대응하여 보인 표이다.
우선 CPU(10)는 도 5의 500단계에서 초기값을 설정하고, 502단계에서 CPU(10)의 메인 클록 주파수를 결정하기 위한 적정 아이들 목표값을 아이들 태스크의 기준값에 적정한 비율을 곱하여 산출하여 도 6에 도시된 바와 같이 저장한다. 그리고 CPU(10)는 504단계에서 도 6에 도시된 바와 같이 저장된 적정 아이들 목표값에 대응하여 상기 CPU(10)의 메인 클록 주파수를 결정한다.
CPU(10)는 504단계에서 측정된 유효한 태스크의 아이들 값이 상기 유효한 태스크의 적정 아이들 목표값보다 크면 CPU(10)의 메인 클록 주파수를 PLL(12)의 최소가변주파수 만큼 증가시키고, 측정된 유효한 태스크의 아이들 값이 유효한 태스크의 적정 아이들 목표값보다 작으면 CPU(10)의 메인 클록 주파수를 PLL(12)의 최소가변주파수 만큼 감소시켜 측정값보다 큰 목표값에 대응하는 CPU(10)의 메인 클록 주파수로 조정한다.
상술한 바와 같이 이동통신단말기 시스템에서 소모전류를 줄이기 위한 방법에 있어서, 프로그램 아이들 률을 일정하게 유지하도록 이동통신단말기 시스템의 상태에 따라 CPU의 메인 클록 주파수를 가변함으로써 이동통신단말기 시스템의 소모전류를 줄일 수 있는 이점이 있다. 또한, 이동통신단말기 시스템의 상태에 따라 CPU의 메인 클록 주파수를 가변함으로써 이동통신단말기 시스템의 수신대기 시간을 늘일 수 있는 이점이 있다.
Claims (9)
- 타이머와, 클록 속도를 가변할 수 있는 피엘엘을 구비한 이동통신단말기 시스템의 소모전류를 줄이기 위한 방법에 있어서,상기 시스템의 프로그램이 수행하는 모든 유효한 태스크가 블록킹된 상태에서의 단순무한 루프를 수행하는 태스크를 상기 시스템의 아이들 태스크로 설정하는 과정과,상기 타이머에 의해 일정시간마다 발생하는 타이머 인터럽트에 따라 일정시간동안 상기 아이들 태스크의 전역변수 값을 카운트하여 상기 아이들 태스크의 전역변수 값을 상기 시스템의 프로그램의 아이들 테스크의 기준값으로 저장하는 과정과,상기 카운트 값을 리셋시키는 과정과,상기 시스템의 프로그램이 유효한 태스크를 수행하면, 상기 타이머에 의해 일정시간마다 발생하는 타이머 인터럽트에 따라, 일정시간동안 상기 유효한 태스크가 상기 아이들 태스크를 점유하는 상기 아이들 태스크의 전역변수 값을 카운트하고, 상기 아이들 태스크의 전역변수 값을 상기 유효한 태스크의 아이들 값으로 저장하는 과정과,상기 아이들 테스크의 기준값으로 상기 측정된 유효한 태스크의 아이들 값을 나누어 상기 시스템의 프로그램 아이들 률을 산출하여 저장하는 과정과,상기 시스템의 프로그램 아이들 률에 따라 피엘엘 값을 변경하여 상기 이동통신단말기 시스템의 중앙처리장치의 메인 클록 주파수를 가변시키는 과정으로 이루어짐을 특징으로 하는 이동통신단말기 시스템에서 소모전류를 줄이기 위한 방법.
- 제1항에 있어서, 상기 프로그램 아이들 률의 산출 및 저장과정은,상기 시스템의 정상적인 동작 시 생성되는 모든 태스크들 각각에 대하여 프로그램 아이들 률을 각각 산출하여 저장함을 특징으로 하는 이동통신단말기 시스템에서 소모전류를 줄이기 위한 방법.
- 제1항에 있어서, 상기 메인 클록 주파수 가변과정은,상기 유효한 태스크의 프로그램 아이들 률이 적정값으로 일정하게 유지되도록 상기 유효한 태스크의 아이들 값을 산출하여 저장하는 단계와,상기 아이들 테스크의 기준값으로 상기 측정된 유효한 태스크의 아이들 값을 나누어 상기 시스템의 프로그램 아이들 률을 산출하여 저장하는 단계와,상기 시스템의 프로그램 아이들 률에 따라 피엘엘 값을 변경하여 상기 중앙처리장치의 메인 클록 주파수를 가변시키는 과정을 반복하여 수행하는 단계로 이루어짐을 특징으로 하는 이동통신단말기 시스템에서 소모전류를 줄이기 위한 방법.
- 타이머와, 클록 속도를 가변할 수 있는 피엘엘을 구비한 이동통신단말기 시스템의 소모전류를 줄이기 위한 방법에 있어서,상기 시스템의 프로그램이 수행하는 모든 유효한 태스크가 동작되지 않는 상태에서 수행되는 상기 시스템의 아이들 태스크를 강제종료하는 과정과,상기 시스템의 프로그램이 수행하는 모든 유효한 태스크가 블록킹된 상태에서의 단순무한 루프를 수행하는 태스크에 전역변수 값 카운트 기능을 구비시켜, 상기 시스템의 새로운 아이들 태스크로 설정하는 과정과,상기 새로운 아이들 태스크의 아이들 값을 설정하는 과정과,상기 새로운 아이들 태스크의 아이들 값을 상기 시스템의 프로그램의 아이들 테스크의 기준값으로하여, 상기 시스템의 프로그램이 유효한 태스크를 수행하면 상기 유효한 태스크의 아이들 값을 측정하여 저장하는 과정과,상기 시스템의 프로그램의 아이들 테스크의 기준값으로 상기 측정된 유효한 태스크의 아이들 값을 나누어 상기 시스템의 프로그램 아이들 률을 계산하여 저장하는 과정과,상기 시스템의 프로그램의 아이들 태스크의 기준값에 적정한 비율을 곱하여 상기 유효한 태스크의 적정 아이들 목표값을 산출하여 저장하는 과정과,상기 저장된 적정 아이들 목표값에 대응하여 상기 중앙처리장치의 메인 클록 주파수를 결정하는 과정과,상기 결정된 중앙처리장치의 메인 클록 주파수에 따라 피엘엘 값을 변경하여 상기 메인 클록 주파수를 조정하는 과정으로 이루어짐을 특징으로 하는 이동통신단말기 시스템에서 소모전류를 줄이기 위한 방법.
- 제4항에 있어서, 상기 새로운 아이들 태스크의 아이들 값 설정과정은,상기 새로운 아이들 태스크가 일정시간동안 얼마나 동작되고 있는지를 측정하기 위해 상기 새로운 아이들 태스크를 실행시키는 단계와,상기 일정시간동안 상기 새로운 아이들 태스크의 전역변수 값을 카운트하여, 상기 전역변수의 변화량을 상기 새로운 아이들 태스크의 아이들 값으로 설정하는 단계로 이루어짐을 특징으로 하는 이동통신단말기 시스템에서 소모전류를 줄이기 위한 방법.
- 제4항에 있어서, 상기 새로운 아이들 태스크는,사용자가 할당할 수 있는 최소 우선순위로 할당됨 특징으로 하는 이동통신단말기 시스템에서 소모전류를 줄이기 위한 방법.
- 제4항에 있어서, 상기 중앙처리장치의 메인 클록 주파수 결정과정은,상기 중앙처리장치의 메인 클록에 대하여 변화 가능한 주파수들을 설정하는 단계와,상기 설정된 변화 가능한 주파수들에 대응하여 상기 아이들 태스크에서의 기준값들을 측정하는 단계와,상기 측정된 상기 아이들 태스크들의 기준값들 각각에 적정한 율을 곱하여 상기 유효한 태스크의 적정 아이들 목표값들을 계산하는 단계와,상기 변화 가능한 주파수들과, 상기 아이들 태스크의 기준값들과, 상기 유효한 태스크의 적정 아이들 목표값들을 대응하여 저장하는 단계와,상기 유효한 태스크 수행 시, 상기 유효한 태스크의 아이들 값을 측정하고, 상기 중앙처리장치의 메인 클록에 대하여 변화 가능한 주파수들 중 상기 유효한 태스크의 아이들 값에 대응하여 저장된 상기 유효한 태스크의 적정 아이들 목표값에 대응하는 주파수를 상기 중앙처리장치의 메인 클록 주파수로 결정하는 단계로 이루어짐을 특징으로 하는 이동통신단말기 시스템에서 소모전류를 줄이기 위한 방법.
- 제7항에 있어서, 상기 메인 클록 주파수 결정과정은,상기 측정된 유효한 태스크의 아이들 값이 상기 유효한 태스크의 적정 아이들 목표값보다 크면 상기 중앙처리장치의 메인 클록 주파수를 피엘엘의 최소가변주파수 만큼 증가시키고, 상기 측정된 유효한 태스크의 아이들 값이 상기 유효한 태스크의 적정 아이들 목표값보다 작으면 상기 중앙처리장치의 메인 클록 주파수를 피엘엘의 최소가변주파수 만큼 감소시켜 상기 메인 클록 주파수를 결정함을 특징으로 하는 이동통신단말기 시스템에서 소모전류를 줄이기 위한 방법.
- 제4항에 있어서, 상기 중앙처리장치의 메인 클록 주파수 조정과정은,상기 측정된 유효한 태스크의 아이들 값이 상기 유효한 태스크의 적정 아이들 목표값과 비교하여 일정회수 이상 연속하여 동일한 비교값을 가지면 피엘엘의 최소가변주파수에 따라 상기 중앙처리장치의 메인 클록 주파수를 가변함을 특징으로 하는 이동통신단말기 시스템에서 소모전류를 줄이기 위한 방법.
Priority Applications (3)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
KR10-2001-0045449A KR100390645B1 (ko) | 2001-07-27 | 2001-07-27 | 이동통신단말기 시스템에서 소모전류를 줄이기 위한 방법 |
CNB021498717A CN1190988C (zh) | 2001-07-27 | 2002-07-27 | 减少移动通信终端的电流消耗的方法 |
US10/207,696 US6973584B2 (en) | 2001-07-27 | 2002-07-29 | Method for reducing current consumption in a mobile communication terminal |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
KR10-2001-0045449A KR100390645B1 (ko) | 2001-07-27 | 2001-07-27 | 이동통신단말기 시스템에서 소모전류를 줄이기 위한 방법 |
Publications (2)
Publication Number | Publication Date |
---|---|
KR20030010408A KR20030010408A (ko) | 2003-02-05 |
KR100390645B1 true KR100390645B1 (ko) | 2003-07-07 |
Family
ID=19712613
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
KR10-2001-0045449A KR100390645B1 (ko) | 2001-07-27 | 2001-07-27 | 이동통신단말기 시스템에서 소모전류를 줄이기 위한 방법 |
Country Status (3)
Country | Link |
---|---|
US (1) | US6973584B2 (ko) |
KR (1) | KR100390645B1 (ko) |
CN (1) | CN1190988C (ko) |
Families Citing this family (17)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US7307317B2 (en) | 2003-04-04 | 2007-12-11 | Semiconductor Energy Laboratory Co., Ltd. | Semiconductor device, CPU, image processing circuit and electronic device, and driving method of semiconductor device |
JP3958720B2 (ja) * | 2003-07-22 | 2007-08-15 | 沖電気工業株式会社 | クロック制御回路とクロック制御方法 |
CN1324477C (zh) * | 2004-03-04 | 2007-07-04 | 中兴通讯股份有限公司 | 一种检测实时操作系统cpu占用率的方法 |
KR100716730B1 (ko) | 2004-06-11 | 2007-05-14 | 삼성전자주식회사 | 중앙 처리 장치의 아이들 상태에서의 시스템 전력 소모절감을 위한 방법 및 그 방법을 적용한 모바일 장치 |
JP2006101041A (ja) * | 2004-09-28 | 2006-04-13 | Fujitsu Ltd | 携帯電話機 |
US7739685B2 (en) * | 2005-01-06 | 2010-06-15 | International Business Machines Corporation | Decoupling a central processing unit from its tasks |
TW200638267A (en) * | 2005-04-22 | 2006-11-01 | Chi Mei Comm Systems Inc | Method for adjusting CPU speed of an electronic appliance |
CN100449457C (zh) * | 2005-05-10 | 2009-01-07 | 奇美通讯股份有限公司 | 调整电子装置的中央处理器运算速度的方法 |
EP1724661A1 (en) * | 2005-05-17 | 2006-11-22 | Chi Mei Communication Systems, Inc. | Method of adjusting CPU clock speed of an electronic appliance |
JP4867921B2 (ja) * | 2006-02-08 | 2012-02-01 | 日本電気株式会社 | 携帯通信端末、及び通信方法 |
CN101237656B (zh) * | 2008-03-10 | 2012-06-13 | 北京天碁科技有限公司 | 提高终端业务持续时间的方法及使用该方法的装置 |
CN101963946B (zh) * | 2010-10-11 | 2015-12-16 | 中兴通讯股份有限公司 | 一台计算机支持多部移动终端下载软件版本的方法及装置 |
KR101744356B1 (ko) * | 2011-03-17 | 2017-06-08 | 삼성전자주식회사 | 휴대단말기의 전류소모 감소장치 및 방법 |
JP5318139B2 (ja) * | 2011-03-24 | 2013-10-16 | 株式会社東芝 | 制御装置およびプログラム |
DE102012108810A1 (de) * | 2011-09-20 | 2013-03-21 | Beijing Lenovo Software Ltd. | Elektronische einrichtung und zustands-steuerverfahren |
KR102375925B1 (ko) * | 2015-08-31 | 2022-03-17 | 삼성전자주식회사 | Cpu의 작동 방법과 상기 cpu를 포함하는 시스템의 작동 방법 |
CN113157408B (zh) * | 2021-03-25 | 2024-05-17 | 上海科世达-华阳汽车电器有限公司 | 一种嵌入式软件计数定时方法、装置、电子设备和介质 |
Family Cites Families (7)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5926053A (en) * | 1995-12-15 | 1999-07-20 | National Semiconductor Corporation | Selectable clock generation mode |
US5774704A (en) * | 1996-07-29 | 1998-06-30 | Silicon Graphics, Inc. | Apparatus and method for dynamic central processing unit clock adjustment |
US5845074A (en) * | 1996-11-22 | 1998-12-01 | E-Parcel, Llc | Smart internet information delivery system having a server automatically detects and schedules data transmission based on status of clients CPU |
US6069882A (en) * | 1997-07-30 | 2000-05-30 | Bellsouth Intellectual Property Corporation | System and method for providing data services using idle cell resources |
JP3573957B2 (ja) * | 1998-05-20 | 2004-10-06 | インターナショナル・ビジネス・マシーンズ・コーポレーション | コンピュータ内のプロセッサの動作速度制御方法及びコンピュータ |
US6564328B1 (en) * | 1999-12-23 | 2003-05-13 | Intel Corporation | Microprocessor with digital power throttle |
US6704876B1 (en) * | 2000-09-26 | 2004-03-09 | Sun Microsystems, Inc. | Microprocessor speed control mechanism using power dissipation estimation based on the instruction data path |
-
2001
- 2001-07-27 KR KR10-2001-0045449A patent/KR100390645B1/ko not_active IP Right Cessation
-
2002
- 2002-07-27 CN CNB021498717A patent/CN1190988C/zh not_active Expired - Fee Related
- 2002-07-29 US US10/207,696 patent/US6973584B2/en not_active Expired - Fee Related
Also Published As
Publication number | Publication date |
---|---|
CN1406096A (zh) | 2003-03-26 |
CN1190988C (zh) | 2005-02-23 |
US20030023890A1 (en) | 2003-01-30 |
US6973584B2 (en) | 2005-12-06 |
KR20030010408A (ko) | 2003-02-05 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
KR100390645B1 (ko) | 이동통신단말기 시스템에서 소모전류를 줄이기 위한 방법 | |
USRE48819E1 (en) | Performance and power optimization via block oriented performance measurement and control | |
KR100960163B1 (ko) | 프로세서 부하에 기반한 동적 클록 주파수 조정 | |
US8122269B2 (en) | Regulating power consumption in a multi-core processor by dynamically distributing power and processing requests by a managing core to a configuration of processing cores | |
US6889332B2 (en) | Variable maximum die temperature based on performance state | |
US8286013B2 (en) | Portable communication device with multi-tiered power save operation | |
KR101740338B1 (ko) | 디지털 시스템에서 동적 클럭 제어 장치 및 방법 | |
JP4808108B2 (ja) | プロセッサシステム | |
CN109906421B (zh) | 基于线程重要性的处理器核划分 | |
US8326375B2 (en) | Method and apparatus for reducing standby power consumption of a handheld communication system | |
US20090049314A1 (en) | Method and System for Dynamic Voltage and Frequency Scaling (DVFS) | |
US20110078477A1 (en) | Power management method for electronic device | |
US20140068303A1 (en) | Circuit arrangement and method for low power mode management | |
JP2005190483A (ja) | 遊休モードでの電力消費が減少したプロセッサシステムおよびその方法 | |
KR20180138351A (ko) | 씨피유 전력 제어 장치 및 방법 | |
JPH10341199A (ja) | 無線携帯端末 | |
EP2596411B1 (en) | Electronic device with a clock circuit and method for providing an electronic device with a clock signal | |
JP2000222061A (ja) | クロック制御方法および制御回路 | |
US11086690B2 (en) | Semiconductor device and processor control method | |
US20080186083A1 (en) | Apparatus and Method for Controlling Voltage and Frequency Using Multiple Reference Circuits | |
JP3000965B2 (ja) | データ処理装置 | |
KR100451213B1 (ko) | 휴대 단말기 전원 관리 방법 | |
JPH11345129A (ja) | インターバルタイマ回路 | |
KR20060033126A (ko) | 시스템온칩의 절전을 위한 효율적인 하드웨어적 제어방법 | |
CN116149458A (zh) | 时钟频率调整方法、装置、设备及存储介质 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
A201 | Request for examination | ||
E701 | Decision to grant or registration of patent right | ||
GRNT | Written decision to grant | ||
FPAY | Annual fee payment |
Payment date: 20080513 Year of fee payment: 6 |
|
LAPS | Lapse due to unpaid annual fee |