KR20110004328A - 컴퓨터 시스템 하드웨어 디바이스들의 고전력 상태들의 선택적 승인에 의한 전력 관리 - Google Patents

컴퓨터 시스템 하드웨어 디바이스들의 고전력 상태들의 선택적 승인에 의한 전력 관리 Download PDF

Info

Publication number
KR20110004328A
KR20110004328A KR1020100065062A KR20100065062A KR20110004328A KR 20110004328 A KR20110004328 A KR 20110004328A KR 1020100065062 A KR1020100065062 A KR 1020100065062A KR 20100065062 A KR20100065062 A KR 20100065062A KR 20110004328 A KR20110004328 A KR 20110004328A
Authority
KR
South Korea
Prior art keywords
devices
power
high power
computer system
power state
Prior art date
Application number
KR1020100065062A
Other languages
English (en)
Inventor
저스틴 피. 반홀즈
윌리엄 지. 페이건
윌리엄 제이. 피아짜
Original Assignee
인터내셔널 비지네스 머신즈 코포레이션
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by 인터내셔널 비지네스 머신즈 코포레이션 filed Critical 인터내셔널 비지네스 머신즈 코포레이션
Publication of KR20110004328A publication Critical patent/KR20110004328A/ko

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F1/00Details not covered by groups G06F3/00 - G06F13/00 and G06F21/00
    • G06F1/26Power supply means, e.g. regulation thereof
    • G06F1/32Means for saving power
    • G06F1/3203Power management, i.e. event-based initiation of a power-saving mode

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Power Sources (AREA)

Abstract

컴퓨터 시스템내 전력은 디바이스에 의해 고전력 상태에서 작동하기 위한 요청들의 선택적 승인에 의해서 관리된다. 일 실시예는 고전력과 저전력 상태들간 상호 배타적이게 상호교환적으로(interchangeably) 작동가능한 복수의 하드웨어 디바이스들을 가지는 컴퓨터 프로그램 시스템을 제공한다. 저전력 상태들이 디폴드로 선택될 수 있고, 상기 디바이스들은 독립적으로 지정된 지속기간동안 상기 조전력 상태에서 적동하도록 요청한다. 전력 관리 디바이스, 예를 들어 베이스보드 관리 제어기(BMC)나 샤시 관리 모듈은 상기 디바이스들로부터, 상기 고전력 상태에서 상기 요청들을 수신하고 선택적으로 승인하도록 구성된다. 상기 전력 관리 디바이스는 차후에 시스템 전력 한도를 실시하기 위해 상기 고전력 상태에서 작동하기 위한 상기 디바이스들의 상기 승인을 취소한다.

Description

컴퓨터 시스템 하드웨어 디바이스들의 고전력 상태들의 선택적 승인에 의한 전력 관리{POWER MANAGEMENT BY SELECTIVE AUTHORIZATION OF ELEVATED POWER STATES OF COMPUTER SYSTEM HARDWARE DEVICES}
본 발명은 컴퓨터 시스템들에서의 전력 관리에 관한 것이다.
최신의 데이터 센터들은 상기 데이터 센터안의 각각의 랙에 공급되어질 잉여전력(surplus power)을 요구하는 규정들을 따라야 한다. 예를 들어, 보험업자 연구소(Underwriters Laboratories,UL)의 규정들은 현재 데이터 센터들이, 상기 랙안에 인스톨 된 각각의 서버에 대한 최대 라벨 전력(label power)의 합에 약 20%의 버퍼를 더한 것만큼, 각각의 랙에 충분한 전력을 공급할 것을 요구한다. 각각의 서버의 라벨 전력 등급(label power rating)은 가장 극한의 구성 및 워크로드 사용 시나리오에서 시스템이 끌어낼 수 있는 최대 가능전력으로부터 파생된다. 실제로 서버들은 일반적으로 그들의 라벨 전력등급하에서 그리고 때로는 최대 라벨 전력의 약 30%에서 70%의 범위내에서 잘 작동한다.
데이터 센터에 공급되나 사용되지 않는 과잉전력(excess power)은 일반적으로 "스트랜드 전력(stranded power)"이라고 호칭된다. 과잉전력이 실제로 전혀 소비되지 않았다 할지라도, 상기 과잉전력을 데이터 센터에 공급하는 것은 오버해드 비용을 증가시키기 때문에, 스트랜드 전력은 문제가 될 수 있다. 비록 데이터 센터들의 작동을 관리하는 규정들이 좋은 의도를 제공하지만, 실제 소비량을 초과하여 제공하는 결과는 전력 관리 관점에서는 이상적이 아니다.
본 발명의 일 실시예는 복수의 하드웨어 디바이스들을 가지는 컴퓨터 시스템을 제공한다. 각각의 하드웨어 디바이스는 고전력 상태(elevated power state)를 포함하는 복수의 서로 다른 전력 상태들에서 상호교환적으로(interchangeably) 작동할 수 있다. 각각의 하드웨어 디바이스는 지정된 지속기간(specified duration)동안 상기 고전력 상태에서 작동하기 위해 개별적으로 요청하도록 구성된다. 전력 관리 디바이스는 상기 하드웨어 디바이스들 모두와 전기적으로 통신한다. 상기 전력 관리 디바이스는 상기 디바이스들로부터 상기 지정된 지속기간동안 상기 고전력 상태들에서 작동하기 위한 상기 요청들을 수신하고 선택적으로 승인(authorizing)하도록 구성된다. 상기 전력 관리 디바이스는 또한 차후에 상기 지정된 지속기간이 만료되면 상기 고전력 상태에서 작동하기 위한 상기 디바이스들의 승인을 취소(revoking)하기 위해 구성된다.
본 발명의 다른 실시예는 컴퓨터 시스템에 대한 전력을 관리하는 방법을 제공한다. 상기 컴퓨터 시스템의 하나 또는 그 이상의 디바이스들이 고전력 상태를 포함하는 복수의 서로 다른 전력 상태들에 따라 작동가능하다. 각각의 디바이스는 지정된 지속기간동안 상기 고전력 상태에서 작동하기 위한 요청을 개별적으로 생성한다. 상기 디바이스들의 상기 요청들은 상기 지정된 지속기간들동안 상기 고전력 상태에서 작동하기 위해 수신되고 선택적으로 승인된다. 상기 고전력 상태들에서 작동하기 위한 상기 디바이스들의 상기 승인은 상기 지정된 지속기간들이 만료된 후 취소된다.
도 1은 본 발명의 하나 또는 그 이상의 실시예들에 따라 전력 관리될 수 있는 컴퓨터 시스템의 일반화된 도면이다.
도 2는 관리 디바이스가 컴퓨터 시스템을 1000W의 고전력보다 크지 않도록 제한하는 도 1의 상기 컴퓨터 시스템의 전력 관리 데이터의 일 예의 테이블이다.
도 3은 전력이 본 발명의 일 실시예에 따라 관리될 수 있는 다수의 클라이언트 블라이드들을 포함하는 랙-마운트가능 샤시의 투시도이다.
도 4는 도 3의 클라이언트 블레이드들이 본 발명의 일 실시예에 따라 전력 관리될 수 있도록 허용하는 아키텍쳐의 일 예를 제공하는 컴퓨터 시스템의 블럭도이다.
본 발명의 실시예들은 컴퓨터 시스템의 하드웨어 디바이스들의 기능이 고전력 상태들(elevated power states)에 들어가는 것을 제한함으로써, 컴퓨터 시스템의 최대 전력 이용을 감소하기 위한 시스템들 및 방법들을 포함한다. 예를 들어 일 실시예는 고전력 상태들에 들어가기 위한 요청들(requests)을 필요한 만큼 생성하도록 구성된 하드웨어 디바이스들을 가지는 컴퓨터 시스템을 제공한다. 각각의 고전력 상태 요청은 상기 하드웨어 디바이스를 현재(저전력) 전력상태에서 상기 요청된 고(높은)전력 상태로 바꾸기(shift) 위해 필요한, 연관된 전력 증가(associated power increase)를 포함한다. 고전력 상태 요청은 상기 다비이스가 상기 고전력 상태에서 작동하기 위해 요청하는 상기 전력 증가와 지속기간(duration) 둘 다를 지정할 수 있다. 상기 지속기간은 예를 들어 상기 하드웨어 디바이스가 상기 고전력 상태에서 작동하기 위해 요청하는 사이클들의 수로 지정될 수 있다. 상기 하드웨어 디바이스들은 예를 들어 프로세서, 하드 드라이브, 메모리 칩, PCI 카드, 비디오 카드, 광 드라이브, 팬, 네트워크 아답터, 파워 서플라이, 디스플레이 또는 입력 디바이스들을 포함할 수 있다.
시스템 관리 디바이스는 상기 컴퓨터 시스템에 대한 최대 전력 이용을 제한하는 방식으로 상기 고전력 요청들을 선택적으로 승인한다(authorize). 예를 들어, 상기 시스템 관리 디바이스가 고전력 상태에서 동시에 작동할 수 있는 하드웨어 디바이스들의 총 개수를 제한할 수 있다. 또는 상기 시스템 관리 디바이스가 선택된 전력 한도를 강제하는 방식으로, 상기 고전력 상태 요청들을 선택적으로 승인할 수 있다. 후자의 시나리오는 예를 들어 상기 고전력 상태 요청들을 승인함으로써 구현될 수 있는데, 그래서 디바이스들의 고전력 상태들을 달성하는데 필요한 전력 증가들의 총합이 언제라도 기정해진 한도를 넘지 않는다.
디바이스가 고전력 상태에서 요청된 사이클들 회수만큼 작동한 후에, 상기 시스템 관리 디바이스는 상기 승인을 취소(revoke)하고, 그리고 상기 하드웨어 디바이스는 저전력 상태로 돌아간다. 상기 하드웨어 디바이스가 저전력 상태로 돌아가는 것은 다른 고전력 상태 요청들을 승인하기 위해서 다음에 사용되어질 전력을 해제한다. 고전력 요청들의 제한은 컴퓨터 시스템의 최대 전력 등급을 감소시킨다. 컴퓨터 시스템의 최대 전력 등급의 감소는 컴퓨터 시스템에 공급되는데 필요한 과잉 전력(즉 스트랜드 전력)량을 감소시킬 수 있다. 이러한 실시예들 및 다른 실시예들이 첨부된 도면들과 함께 이하에서 보다 더 자세하게 설명된다.
도 1은 본 발명의 하나 또는 그 이상의 실시예들에 따라 전력이 관리될 수 있는 컴퓨터 시스템(10)의 일반화된 도면이다. 상기 컴퓨터 시스템(10)의 도면은 서로 다른 컴퓨터 시스템 구성들의 범위를 나타내기 위해 일반화하였고, 더욱 자세한 구성예들은 다음 도면들에서 제공될 것이다. 복수의 하드웨어 디바이스들(12)은 참고를 위해 디바이스1부터 디바이스6으로 각각 라벨된다. 파워 서플라이(20)는 여기서 파워 서플라이 버스(22)로 호칭되는 전기 경로(pathway)들을 따라 총괄하여 하드웨어 디바이스들(12)에 전력을 제공한다. 상기 파워 서플라이(20)는 각각의 디바이스(12)의 전력 상태에 상응하도록 각각의 디바이스(12)에 대한 전압을 제어하기 위한 전압 레귤레이션 모듈(voltage regulation module)을 포함할 수 있다. 하드웨어 디바이스들(12)은 전체적으로 여기서 통신 버스(26)로 호칭되는 전기 경로(pathways)를 따라 관리 디바이스(24)와 통신한다. 상기 하드웨어 디바이스들(12)은 상기 하드웨어 디바이스상의 현재 워크로드에 상응하게 상기 파워 서플라이(20)로부터 전력량을 끌어낸다.
각각의 하드웨어 디바이스(12)는 복수의 서로 다른 전력 상태들 중 하나에서 작동될 수 있다. 전력 상태들은 일반적으로 컴퓨터 산업 표준들에 따라 정의된다. 예를 들어 ACPI(Advanced Configuration and Power Interface) 표준은 프로세서들 및 다른 디바이스들에 대해서 "power-performance" 상태들 또는 간단하게 "P-states"라고 알려진 전력 상태들 중 하나의 세트를 지정한다. P-states들은 P1부터 Pn까지 표시될 수 있는데, P0가 가장 높은 성능 상태이고 P1에서 Pn으로 점점 낮은 성능 상태를 나타낸다. 상기 ACPI 표준은 또한 다른 상태들, 예를 들어 시스템 상태인 G0(작동중(working))부터 G3(기계 Off) 및 D0(완전-on)부터 D3(off)를 지정한다. 다른 실시예에서, 이러한 표준에 따라, "작동중" 상태는 "Off" 상태에 비해서 고전력 상태로 고려될 수 있다.
컴퓨터 시스템내 디바이스의 전력상태를 제어하기 위한 기법들은 서로 다른 다양한 상표 이름하에 종래 기술분야에서 널리 알려져있다. 예를 들어, 인텔 스피드스텝(SpeedStep)은 전압 레벨들과 성능 주파수간의 자동 변환을 가능케 하는 컴퓨터 하드웨어, 컴퓨터 소프트웨어, 컴퓨터 운영 시스템들 및 특정 집적회로 애플리케이션에 대한 등록상표이다. 유사하게, AMD PowerNow는 운영 주파수를 관리함에 의해 성능 상태들과 전압들간의 자동 변환을 가능케 하는 다른 기술에 대한 등록상표이다. 주파수 및/또는 전압을 관리하는 이러한 기법들은 본 발명의 일 실시예에 따라 요청되었고 선택적으로 승인되었던 전력상태를 강제하기 위해 사용될 수 있다.
상기 디바이스(12)는 파워 서플라이(20)로부터 현재 전력량(에 의해 제한된)에 적합한 전력량을 뽑아낸다. 에너지 효율을 이루기 위해서, 상기 디바이스들(12)은 정상 작동중에 저(감소된)전력 상태에서 작동하기 위해 구성될 수 있으며, 그리고 때때로 적절한 때(예를 들어 더 높은 워크로드에 대응하여)에 고전력 상태를 요청한다. 예를 들어, HDD는 루틴한 작업들에 적합한 낮은 스피드와 더 많은 워크로드 집중 작업들에 적합한 빠른 스피드를 포함하는, 다수의 스피드들(RPM들로 표시)을 가질 수 있다. 상기 더 빠른 스피드는 대응하는 전력증가를 가지는 고전력 상태를 필요로 할 수 있다. 다른 실시예에서는, 프로세서와 같은 디바이스는 루틴한 작업들 동안에는 저전력 상태(낮은 운영 주파수 및/또는 전압에 의해서 특정)에서 작동할 수 있고, 때때로 더 많은 워크로드 집중 작업들에 대해서 고전력 상태를 요청할 수 있다. 예를 들어, 전력관리되는 디바이스는 전력소비 범위의 최하단에 대응하는 상태로 최대한 조절된 디폴트에 의해 작동될 수 있다. 상기 디바이스가 더 높은 전력 상태를 요청하는 것에 응답하여, 상기 디바이스는 전력 소비의 더높은 레벨에 대응하는 덜-조절된(less-throttled) 상태 또는 전력 소비 범위의 최상단에 대응하는 최대전력 상태에 위치될 수 있다.
각각의 디바이스(12)는 예를 들어 특정 디바이스(12)상의 증가된 전력 요구에 응답하여, 때때로 저전력 상태에서(디폴트로 운영) 고전력 상태로 변경될 필요가 있다. 예를 들어, HDD가 비가동(idling)일 때 일반적으로 낮은 전력상태에 대응하는 낮은 스피드에서 운영하고, 부트업 프로시져나 다른 더 높은 워크로드 태스크동안에는 더 높은 RPM에 대응하는 고전력 상태를 요청한다. 다른 예에서, 데이터베이스 애플리케이션을 실행하는 CPU는 데이터 컴파일링 단계동안에는 일반적으로 낮은 전력상태에서 작동하고, 그리고 상기 컴파일된 데이터상에서 데이터베이스 쿼리를 실행하는 연산-집중 단계동안에는 고전력 상태에서의 작동을 요청한다.
또한 고전력 요청들은 상기 고전력 요청들을 우선순위화하는 것에 의해서 관리될 수 있다. 예를 들어, 고온 시나리오를 핸들링하기 위해서 팬이 고전력 상태에 들어갈 필요가 있을 수 있다. 이는 덜 긴급한 고전력 요청들보다 우선적으로 취해질 수 있다. 상기 우선순위화는 관리 디바이스에 알려진 정책세팅들의 일부로서, 상기 관리 디바이스에 의해 구현될 수 있다. 또한, 각각의 고전력 요청은 상기 고전력 요청의 다른 파라미터로 우선순위 레벨을 지정할 수 있다.
상기 디바이스(12)는 고전력 상태에 들어가기 위해서, 관리 디바이스(24)에 의한 승인을 필요로 한다. 고전력 상태에서 작동하기 위해서, 각각의 디바이스(12)는 상기 고전력 상태에서 작동하기 위한 전자 요청(electronic request)을 개별적으로 생성해야 한다. 각각의 디바이스(12)는, 상기 디바이스(12)가 상기 고전력 상태 요청을 개별적으로 생성하는 것을 허용하는 회로 및 프로그램 코드의 조합을 포함할 수 있는 로직 모듈(15)을 포함한다. 상기 디바이스들(12)에 의해 생성된 상기 고전력 상태 요청들은 상기 통신 버스(26)를 따라 상기 관리 디바이스(24)로 통신된다. 각각의 고전력 상태 요청은 고전력 증가(elevated power increment) 및 요청된 지속기간(request duration)을 포함할 수 있다. 상기 고전력 증가는 상기 요청 디바이스(12)가 상기 고전력 상태에서 작동되기 위해 얼마나 많은 추가전력(현재의 저전력 상태에서 필요로하는 전력에 비하여)이 또는 얼마나 많은 총전력이 필요할지를 나타낼 수 있다. 상기 요청된 지속기간은 예를 들어 상기 요청 디바이스(12)가 상기 고전력 상태에서 동작하기를 원하는 다수의 클락 사이클들이나 시간범위로서 표현될 수 있다. 상기 관리 디바이스(24)는 상기 컴퓨터 시스템(10)의 전력소비를 관리하기 위해서, 상기 고전력 상태 요청들을 수신하고, 상기 고전력 상태 요청들을 선택적으로 승인하고, 그리고 차후에 상기 고전력 상태 요청들을 취소한다.
도 1의 컴퓨터 시스템(10)의 일 시점을 도시하는데, 여기서 디바이스(2,5 및 6)는 현재 상기 관리 디바이스(24)의 승인하에 고전력 상태에서 작동중이다. 디바이스2, 디바이스5 및 디바이스6 위에 있는 타이머 아이콘(25)은 이러한 디바이스들(12) 각각에 대한 고전력 상태가 상기 각각의 디바이스들(12)에 의해 요청된 지속시간동안 승인되어 있음을 나타낸다. 상기 요청된 지속기간의 만료시에, 상기 관리 디바이스(24)는 상기 디바이스들(12)에 대한 상기 고전력 상태 요청에 대한 승인을 취소(revoke)할 것이다. 일단 상기 고전력 상태 요청이 취소되면, 상기 각각의 다비이스(12)는 저전력 상태로 돌아온다. 디폴트로, 상기 디바이스들(12) 중 임의의 디바이스는, 상기 디바이스(12)가 상기 고전력 요청의 승인 전에 작동되었었던 전력상태로 시프트(shift) 되거나 또는 다른 저전력 상태가 상기 디바이스(12)에 의해 요청될 수 있다.
도 2는 도 1의 상기 컴퓨터 시스템에 대한 전력 관리 테이터의 일 예의 테이블인데, 여기서 상기 관리 디바이스는 상기 컴퓨터 시스템이 언제라도 1000W의 고전력을 넘지 않도록 제한한다. 상기 전력 관리 데이터는 31열부터 36열에 디바이스1 내지 디바이스6에 의해 생성되는 고전력 요청들과 연관된 전력과 지속기간 값을 포함한다. 상기 요청된 고전력 증가(increment)들은 와트(W)들로 리스트되고, 상기 요청된 지속기간 값들은 클락 사이클들로 리스트된다. 상기 요청된 전력 및 지속기간 값들은 열41부터 열44내에 네개의 서로 다른 시간들 T1 부터 T4로 표시된다. 시간들 T1 부터 T4는 예로서 제공되며 시간 인터벌들이 균등한 간격으로 제공되는 것은 아니다. 시간T2는 시간T1 후 100 클럭 사이클들 발생할 수 있고, 시간T3는 시간T2 후 500 사이클들 발생할 수 있고, 시간T4는 시간T3 후 120 사이클들 발생할 수 있다. 아직 승인되지 않은 요청된 전력 및 지속기간 값들은 삽입구로서(parenthetically) 리스트된다; 승인된 요청된 전력 및 지속기간 값들은 삽입어구(parentheses) 없이 리스트된다.
상기 고전력 증가들은 여기서 고전력 상태에서 디바이스에 의해 소비되는 전력과 이전(낮은) 전력 상태에서 동일한 디바이스에 의해 소비되는 전력간의 차이로 표시된다. 예를 들어, 상기 테이블은 시간 T1에서, 디바이스1가 이전(낮은) 전력 상태보다 150W를 더 요청하고 있는 것을 나타낸다. 상기 고(높은)전력 및 저전력 상태들은 1250W의 고전력 상태와 110W의 저전력 상태, 또는 500W의 고전력 상태와 350W의 저전력상태와 같이, 150W 떨어진 임의의 두 개의 전력값들에 의해 분리될 수 있다.
도 2의 테이블은 가상으로 1000W의 전력제한을 강제하는 일 실시예를 제공한다. 상기 디바이스들에 대한 전력은 상기 관리 디바이스에 의해 현재 승인된 상기 고전력 증가들의 합계가 언제라도 1000W를 초과하지 않도록 하기 위해서, 관리된다. 예를 들어, 시간 T1에서, 디바이스들 2,5 및 6은 이전(낮은) 전력 상태들보다 위인 300W, 100W 및 550W의 고전력 상태들에서 현재 작동중이다. T1에서 상기 전력 증가들 합계 950W(37열에 도시)는 1000W의 시스템 전력 한도보다 50W가 적다. 시간 T1에서, 삽입구로 표시된 바와 같이, 고전력 상태 요청은 디바이스1 및 디바이스4 각각에서 펜딩중이다. 이는 디바이스1(31열)이 500사이클들 동안 디바이스1의 저전력 상태보다 150W의 고전력 상태에서 작동하도록 요청되었고, 디바이스4(34열)가 150사이클들 동안 200W의 고전력 상태에서 작동하도록 요청되었다는 것을 나타낸다. 고전력 상태 요청은 어느것도 시간 T1에서 상기 1000W의 한도를 초과하지 않으면서 승인될 수 없으며; 따라서, 상기 디바이스1 및 디바이스4의 고전력 상태 요청들은 시간 T1에서 펜딩으로 남아있는다.
디바이스 5에 대한 고전력 요청이 취소되면, 시간 T2는 시간 T1후에 100클락 사이클 존재한다. 상기 경우에 디바이스5의 고전력 상태 요청의 취소는 추가적인 100W를 해제하고, 이는, T1에서 이미 사용가능한 50W의 전력 여분에 더하여, 시간 T2전에 펜딩되었었던 디바이스1의 고전력 상태 요청을 승인하는데 충분한 전력(150W)을 제공한다. 따라서, 시간 T2(42행)에서, 디바이스1은 자신의 고전력 상태(150W의 전력 증가를 가짐)에서의 작동을 시작하고, 32 및 36열에 표시된 남아있는 사이클 수만큼, 1000W(150W+300W+550W)의 총 전력 증가에 대해서, 디바이스 2 및 디바이스6은 그들의 고전력 상태들(300W 및 550W 전력 증가들)에서의 작동을 유지한다. 시간 T2에서 추가적인 200W의 요청이 1000W 전력 한도의 초과없이 승인될 수 없기 때문에, 디바이스4의 고전력 상태 요청은 여전히 펜딩중이다.
디바이스1의 150W 고전력 상태 요청의 취소되면, 시간 T3는 시간 T2이후 500 사이클 존재한다. 디바이스2 및 6은 상기 1000W 전력 한도에 대해서 150W의 사용가능한 전력을 남겨두고서, 여전히 각각 300W 및 550W(총 850W)의 전력 증가들에서 작동중이다. 디바이스2는 현재 승인된 고전력 상태 요청이 650 사이클들이 남아있고, 디바이스6은 현재 승인된 고전력 상태 요청이 120 클락 사이클들이 남아있다. 200W 전력 증가가 여전히 상기 1000W 전력 한도를 초과함이 없이 승인될 수 없기 때문에, 디바이스4의 고전력 상태 요청은 여전히 펜딩중이다.
디바이스6의 550W 고전력 상태 요청이 취소되는 즉시, 시간 T4는 시간 T3이후 120 사이클 존재한다. 디바이스6의 550W 고전력 상태 요청의 취소는 상기 1000W 시스템 전력 한도에 대해서 디바이스4의 200W 고전력 상태 요청을 승인하는데 충분한 전력을 해제한다. 따라서, 디바이스2 및 디바이스4는 500W의 전체 고전력으로 그들의 고전력 상태에서 여전히 작동중이다. 다른 고전력 상태 요청들은 펜딩중이 아니고, 새로운 고전력 상태 요청들이 시간 T4에서 생성되지 않는다.
도 2의 테이블내 상기 전력 관리 데이터는 단지 시스템 전력 한도를 강제하기 위해 컴퓨터 시스템내에서 다양한 디바이스들에 의해 생성되는 고전력 요청들의 선택적인 승인을 도시하기 위한 일 예를 제공하는 것에 불과하다. 상기 테이블들이 4개의 시간들(T1부터 T4)과 6개의 디바이스들에 대한 전력 관리 데이터를 포함하나, 최신 컴퓨터 시스템들에서의 높은 클럭율로 인해 짧은 기간동안에 매우 큰 다수의 고전력 상태 요청들이 관리될 수 있다는 점이 인식되어야 한다.
컴퓨터 시스템들에서, 임의의 시점에 실행되어야 하는 프로세스들의 수는 프로세스들을 구동하는데 사용가능한 CPU들의 수를 쉽게 초과한다. 스케쥴링 기법들은 한정된 CPU들의 수에 구동하기 위해 프로세스들을 할당하는 기술분야에서 널리 알려져 있다. 예를 들어, 다양한 기법들이 한정된 수의 프로세서들이나 다른 디바이스들상에서 다수의 프로세스들의 동시 또는 연속 실행을 위한 기술분야에서 알려져 있다.
본 발명의 일 실시예는 디바이스들에 지정된 경과시간들동안 고전력상태로 있기 위해 타당하게 시간을 할당하기 위한 최신 태스크 스케쥴링 기법들을 포함하는 전력 관리 방법을 제공한다. 예를 들어, 스케쥴링 방법은 각각의 프로세스들을 구성하는 다양한 태스크들을 식별하고, 어느 태스크가 각각의 태스크의 실행에 관련된 CPU나 다른 디바이스의 고전력 상태의 인보크를 필요로 할지를 결정하는 단계를 포함할 수 있다. 상기 방법은 예를 들어 고전력 상태에서 작동하는 디바이스의 수를 제한 또는 고전력 상태들에서 디바이스들의 작동에 할당된 추가 전력의 제한과 같이, 고전력 상태를 필요로하는 이러한 태스크들을 선택적으로 승인하는 단계들을 포함할 수 있다. 스케쥴되는 태스크들은 하드웨어 디바이스에서 어느 태스크들이 고전력 상태 요청을 포함할지를 결정하기 위해 평가될 수 있다. 태스크 스케쥴러(예를 들어 소프트웨어 객체나 애플리케이션)는 시스템 전력 한도를 강제하거나 고전력 상태들에서 동시에 작동되는 디바이스들의 수를 제한하는 방법으로, 고전력 요청들을 포함하는 상기 태스크들의 실행이 스케쥴될 수 있다.
도 2의 전력 관리 데이터를 사용하는 상술한 예는 각각의 고전력 상태 요청이,일단 승인되면, 상기 요청된 기간동안 계속해서 인터럽트 되지 않게 허용되는 것으로 가정한다. 그러나, 상기 시스템 관리 디바이스가 적어도 임시로라도 고전력 상태 요청의 승인을 취소하는 경우가 일어날 수 있다. 수행되고 있는 특정 이벤트들이나 태스크들이 임의의 현재 프로세스들가 우선하는 것을 보장할 수 있고, 이에 승인이 상기 고전력 상태 요청내에 지정된 전체 지속기간전에 임시적으로 취소될 수 있다. 예를 들어, 시스템 상태의 비정상(예를 들어 위험하게 높은 온도)을 나타내는 시스템 알람은 특정 프로세스들을 유예되도록 할 수 있고, 이에 상기 알람 이벤트를 고치기 위한 조치가 취해질 수 있다. 상기 알람 이벤트가 지나가면, 상기 관리 디바이스는 상기 요청 기간의 나머지에 대해 임의의 고전력 상태 요청들을 재승인할 수 있다.
도 3은 다수의 블레이드들(212)를 포함하는 랙-마운트 샤시(210)의 투명도인데, 여기서 상기 블레이드들(212)에 대한 전력은 본 발명의 일 실시예에 따라 관리될 수 있다. 상기 샤시(210)는 예로서 14개의 블레이드들(212)을 받아들이는 14개의 베이들을 가진다. 상기 블레이드들(212)은 네트워크 서버 블레이드들, 워크스테이션 블레이드들 또는 다른 모듈 컴퓨터들이나 블레이드 형태의 요소를 가지는 컴포넌트들을 포함할 수 있다. 각각의 블레이드(212)는 네트워크 노드로서의 기능을 할 수 있다. 상기 블레이드들(212)은 상기 샤시(210)내 다양한 지원 모듈들에 의해 제공되는 시스템 리소스들(예를 들어 전력, 냉각 및 네트워크 연결)을 공유한다. 상기 지원 모듈들은 샤시 관리 모듈(215), 파워 서플라이 모듈(216), 팬 어셈블리(217) 및 네트워크 스위치 모듈(218)을 포함한다. 상기 샤시 관리 모듈(215)은 상기 샤시(210), 서버들(212) 및 상기 샤시안의 다른 모듈들을 관리한다. 상기 전력 모듈(216)은 서버들(212) 모두에게 전기 전력을 제공한다. 상기 팬 어셈블리(217)는 서버들(212)에 의해 생성된 열을 제거하고 모듈들을 지원하기 위해 상기 샤시(210)를 통해 공기흐름을 생성한다. 상기 스위치 모듈(218)은 상기 블레이드 서버 입/출력 및 네트워크간의 네트워크 연결을 제공한다. 상기 서버들(212) 및 지원 모듈들(215-218)은 전력 및 데이터 신호 통신을 제공하기 위해서 상기 샤시(210)안에서 상호 연결된다. 상기 서버들(212) 및 지원 모듈들은 예를 들어 상기 블레이드 서버들(212)을 도킹하고 모듈들을 지원하기 위해 리지드 커넥터들을 가지는 미드플레인(midplane)으로 알려진 내부 샤시 인터페이스에서 상호연결될 수 있다. 상기 미드플레인이 케이블 필요성을 감소하거나 제거할지라도, 케이블 연결 또한 상기 샤시(210)내에서 이루어질 수 있다.
도 4는 도 3의 상기 클라이언트 블레이드들(212)이 본 발명의 일 실시예에 따라 전력관리 되는것을 허용하는 아키텍쳐의 일 예를 제공하는 컴퓨터 시스템(232)의 블럭도이다. 상기 컴퓨터 시스템(232)은 샤시 관리 모듈(215), 선택 원격 관리 제어기(230), 운영 시스템(280)을 구동하는 클라이언트 블레이드들 중 하나(예를 들어 블레이드 서버 또는 워크스테이션 블레이드,212), 그리고 선택 원격 클라이언트(290)을 포함한다. 다수의 클라이언트 블레이드들에 대한 전력이 관리될 수 있으나, 설명의 목적상 오직 하나의 클라이언트 블레이드(212)가 도시되었다. 상기 원격 관리 제어기(230) 및 상기 샤시 관리 모듈(215)의 하나 또는 둘 다는 도 1의 일반화된 관리 디바이스(24)의 컴포넌트들로 기능할 수 있다. 상기 원격 관리 제어기(230)은 예를 들어 IBM POWEREXECUTIVE와 같은 전력 관리 모듈(236)을 포함하는, 예를 들어 IBM DIRECTOR 같은 시스템 관리 소프트웨어(SMS, 234)를 구동하는 독립형 컴퓨터 콘솔일 수 있다.(IBM, DIRECTOR 및 POWEREXECUTIVE는 뉴욕주 암몽크(Armonk)의 IBM사의 상표들이다.) 상기 원격 관리 제어기(230)는 상기 샤시(210)가 위치한 데이터센터안이나 외부에 위치될 수 있고, 이더넷 연결을 통해서 샤시(210)의 샤시 관리 모듈(215)(도 3을 참조)과 통신할 수 있다. 상기 샤시 관리 모듈(215)은 상기 시스템 관리 소프트웨어(234)와 인터페이싱하기 위한 관리 에이전트(244)를 포함하는 관리 모듈 프로그램(242)를 구동한다.
본 발명의 일 실시예에 따라, 전력 관리 방법은 상기 원격 관리 제어기(230), 샤시 관리 모듈(215), 기판 관리 제어기(260) 또는 이들의 조합들내의 소프트웨어 구동에 의해 구현될 수 있다. 필요하지는 않더라도, 상기 원격 관리 제어기(230)로부터 전력 소비를 관리하는 특징은 하나의 원격 위치에서 다수의 샤시에 대해서 전력을 관리할 수 있는 기능이다. 상기 원격 관리 제어기(230)가 상기 전력 관리 방법을 구현하는데 사용될 때, 상기 원격 관리 제어기(230)는 각각의 샤시내에 포함된 하드웨어 디바이스들이나 하드웨어 디바이스들의 그룹으로부터 상기 고전력 상태 요청들을 관리할 수 있다. 또는, 각각의 샤시내 상기 샤시 관리 모듈(215)은 상기 각각의 샤시내의 각각의 서버의 고전력 상태 요청들을 관리할 수 있거나 상기 고전력 상태 요청을 관리하는 법을 상기 베이스보드 관리 제어기(260)에 지시할 수 있다.
상기 샤시 관리 모듈(215)은 상기 샤시(210)안의 각각의 클라이언트 블레이드(212)와 통신한다. 상기 클라이언트 블레이드(212)는 CPU(251), 노스 브릿지(252), 사우스 브릿지(253), 그래픽카드(254), 비디오 출력(255), 램 메모리(256), PCI 버스(257), 및 BIOS(258)를 포함하는(한정은 아님) 하드웨어 구성을 포함한다. 다른 컴포넌트들 및 일반 클라이언트 블레이드의 상세한 사항들은 본 기술분야에서 통상의 기술을 가진 자라면 알고 있을 것이다.
상기 클라이언트 블레이드(212)는 또한 본 기술분야에서 일반적으로 지능형 플랫폼 관리(intelligent platform management)로 알려진 것을 포함한다. BMC(baseboard management controller,260)는 지능형 플랫폼 관리 뒤에서 정보를 제공하고, 시스템 관리 소프트웨어(234), 클라이언트 블레이드 하드웨어(251-58) 및 운영 시스템(280)사이에서 인터페이스를 관리한다. 상기 BMC(260)는 상기 샤시 관리 모듈(215)과 통신을 위한 지능형 플랫폼 관리 인터페이스(IPMB,262)와 운영 시스템(280)과 통신을 위한 시스템 메시지 인터페이스(SMI,264)를 포함한다. 상기 BMC의 메시지 핸들러(266)는 이러한 인터페이스들로부터 또는 이러한 인터페이스들로 IMPI 메시지들을 핸들링한다. 메시지 핸들러(266)는 또한 클라이언트 블레이드(212)안의 예를 들어 CPU 온도센서 및 전력 공급 게이지와 같은 다양한 센서들(268)과 통신할 수 있다. 상기 센서들(268)은 센서들을 발견하고, 구성하고 그리고 엑세스하기 위해 센서 디바이스(270)와 통신한다. 그리고나서 센서데이터(272)는 상기 센서 데이터 레코드들내에 로깅하는 메시지 핸들러(266)에 보고된다. 상기 시스템 관리 소프트웨어(234)나 샤시 관리 모듈(215)로부터 센서 데이터에 대한 요청이 수신되면, 상기 메시지 핸들러(266)가 상기 센서데이터를 리트리브하고 그리고 상기 IPMB 인터페이스(262)를 통해서 발송한다.
상기 운영 시스템(280)은 ACPI(Advanced Configuratin and Power Interface, 282)를 포함하는 전형적인 운영 시스템 컴포넌트들을 포함할 수 있다. 상기 ACPI(282)는 전력 이벤트 핸들러나 AML 메쏘드 구현을 위해 그들 자신의 ACPI 기계어(AML,284)를 사용한다. 상기 AML 메쏘드(284)는 상기 시스템 메시지 인터페이스(264) 및 슈퍼 I/O(274)의 범용 I/O 포트들을 통해서 상기 BMC(260)로부터 명령들을 수신한다. 상기 AML 메쏘드(284)는 상기 명령들에 부합되게 상기 CPU(251)의 상태를 변경하고 메시지들을 상기 CPU(251)의 새로운 ACPI 상태를 확인하는 BMC로 돌려보낼 수 있다.
도 4의 실시예에 따라, 상기 원격 관리 제어기(230) 및/또는 샤시 관리 모듈(215)를 포함하는 관리 디바이스가 상기 전력 관리 방법을 구현할 수 있는데, 상기 방법은 클라언트 블레이드내의 프로세서(들) 또는 다른 하드웨어 디바이스들의 ACPI 상태들을 제어하기 위해 운영 시스템을 지시하는 IPMI 메시지들을 전송하거나, 프로세서(들)의 스피드 단계를 제어하기 위해 운영 시스템을 지시하는 IPMI 메시지들을 전송함으로써 구현된다. 이러한 기능은 도1의 일반화된 시스템도 및 도 2의 테이블들을 관련하여 기술된 바와 같이, 원격 관리 제어기(230) 및/또는 샤시 관리 모듈(215)이 다양한 디바이스들에 의해 요청된 고전력 상태들을 선택적으로 승인하는 것을 허용한다. 고전력 상태 요청의 수신하고 승인되면, 상기 관리 엔티티는 그렇게 함으로써 승인된 디바이스의 전력상태의 증가를 승인할 수 있다. 예를 들어, 상기 관리 디바이스는 하나 또는 그 이상의 프로세서들을 슬립상태로부터 작업상태로 스위치할 수 있거나 또는 이미 작업중인 프로세서들을 더 높은 전력 상태로 스피드 단계를 증가한다.
클라이언트 블레이드(212)가 씬(thin) 클라이언트인 실시예들에서는, 상기 원격 클라이언트(290) 상기 클라이언트 블레이드(212)와 인터페이스를 하기 위한 유저 인터페이스를 개별 유저에게 제공할 수 있고, 상기 운영 시스템, 애플리케이션들, 데이터 저장장치, 및 프로세싱 기능이 상기 클라이언트 블레이드(212)상에 위치한다. 이런 경우, 상기 원격 클라이언트(290)는 이더넷 네트워크를 통해서 상기 클라이언트 블레이드(212)와 데이터를 전송하거나 수신할 수 있다. 상기 원격 클라이언트(290)은 또한 BMC 관리 유틸리티(292)를 포함할 수 있고 상기 BMC(260)와 랜 통신을 통해서 IPMI를 활용할 수 있다.
상기 시스템들내 다른 곳에서의 더 높은 전력 소비때문에 전력이 제한되는 디바이스들은 또한 예를 들어 클럭이나 전압 조절되거나, 대기 상태가 되거나, 전력 관리 레지서트들이 재구성되는 등에 의해서, 그들의 전력 소비가 감소될 수 있다. 다른 실시예들에서, 상기 BMC(260)가 디바이스가 사전 통지없이 더 높은 전력 소비 상태에 들어가고 있는 것을 감지할 수 있다(예를 들어, 개별 서브시스템들의 전력 소비를 모니터링함으로써). 이러한 더 높은 전력 소비의 감지에 대응하여, 상기 BMC(260)가 다른 서브시스템들을 고전력 모드들의 작업에 들어가는 것을 피하도록 지시할 수 있다.
본 기술분야에서 통상의 기술을 가진 자에 의해서 인식되는 바와 같이, 본 발명은 시스템, 방법 또는 컴퓨터 프로그램 제품으로서 포함될 수 있다. 따라서, 본 발명은 전체적으로 하드웨어 구현, 전체적으로 소프트웨어 구현(펌웨어, 레지던트 소프트웨어, 마이크로-코드 등을 포함하는), 또는 일반적으로 여기서 "회로", "모듈" 또는 "서브시스템"으로서 호칭되는 소프트웨어 및 하드웨어 형태들을 조합하는 구현의 형태를 취할 수 있다. 또한, 본 발명은 저장매체상에 저장된 컴퓨터 사용가능 프로그램 코드를 가지는 임의의 유형 저장매체내에 포함된 컴퓨터 프로그램 제품의 형태를 취할 수 있다.
하나 또는 그 이상의 컴퓨터 사용가능 또는 컴퓨터 판독가능 저장매체(들)의 어떤 조합들도 사용될 수 있다. 상기 컴퓨터-사용가능 또는 컴퓨터-판독가능 저장매체는 예를 들어(그러나 이에 한정은 아님) 전자, 자기, 전작, 또는 반도체 장치들이나 디바이스들 일 수 있다. 컴퓨터 판독가능 매체의 더 자세한 예들로는 (총 망라한 리스트가 아님) 휴대용 컴퓨터 디스켓, 하드 디스크, RAM, ROM, EPROM 또는 플래시 메모리, CD-ROM, 광 저장장치 디바이스 또는 자기 저장장치 디바이스를 포함한다. 상기 컴퓨터-사용가능 또는 컴퓨터-판독가능 저장매체는 심지어는 종이나 상기 프로그램이 프린트 될 수 있는 다른 적절한 매체도 될 수 있는데, 상기 프로그램이 예를 들어 상기 종이나 다른 매체의 광 스캐닝을 통해 전기적으로 캡쳐될 수 있고, 그리고 나서 컴파되고, 인터프리터되거나 또는 그렇지 않으면 적절한 방법으로 처리되고, 만약 필요하다면 그리고나서 컴퓨터 메모리내에 저장될 수 있기 때문이다. 이 문서의 구문에서, 컴퓨터-사용가능 또는 컴퓨터-판독가능 저장 매체는 컴퓨터에 의해서 사용을 위해 상기 프로그램을 포함하거나 저장할 수 있는 어떤 저장매체도 될 수 있다.
상기 컴퓨터-사용가능 저장장치 매체상에 포함된 컴퓨터 사용가능 프로그램 코드는 전파 데이터 신호에 의해서 베이스밴드내에서 또는 전송파의 일부로 통신될 수 있다. 상기 컴퓨터 사용가능 프로그램 코드는 무선, 유선, 광섬유 케이블, RF 등을 포함하는(그러나 이에 한정은 아님) 임의의 적절한 전송 매체를 이용해서 하나의 저장장치 매체로부터 다른 저장장치 매체로 전송될 수 있다.
본 발명의 작업들을 수행하기 위한 컴퓨터 프로그램 코드는 예를 들어 자바, 스몰토크, C++ 이나 기타 등등의 객체 지향 프로그래밍 언어 및 예를 들어 "C" 프로그래밍 언어나 유사한 프로그래밍 언어들과 같은 종래 절차 프로그래밍 언어들을 포함하는 하나 또는 그 이상의 컴퓨터 프로그래밍 언어들의 임의의 조합으로 기록될 수 있다. 상기 프로그램 코드는 독립형 소트프웨어 패키지로서 전체적으로 유저의 컴퓨터상에서, 부분적으로 유저의 컴퓨터상에서, 부분적으로 상기 유저의 컴퓨터에서 그리고 부분적으로 원격 컴퓨터상에서 또는 전체적으로 상기 원격 컴퓨터나 서버상에서 실행될 수 있다. 후자의 경우에는, 상기 원격 컴퓨터는 LAN이나 WAN을 포함하는 임의의 네트워크 타입을 통해서 상기 유저의 컴퓨터에 연결될 수 있거나, 또는 상기 연결은 외부 컴퓨터(예를 들어, 인터넷 서비스 제공자(ISP)를 이용하여 인터넷을 통해서)로 이루어질 수 있다.
본 발명의 실시예들에 따른 방법들, 장치들(시스템들) 및 컴퓨터 프로그램 제품들의 흐름도들 및/또는 블럭도들을 참고하여, 본 발명이 기술되었다. 상기 흐름도들 및/또는 블럭도들의 각각의 블럭, 그리고 상기 흐름도들 및/또는 블럭도들의 블럭들의 조합들은 컴퓨터 프로그램 명령들에 의해 구현될 수 있다는 점을 유념해야 한다. 이러한 컴퓨터 프로그램 제품들은, 컴퓨터나 다른 프로그램가능 데이터 처리 장치의 프로세서를 통해 실행되는 상기 명령들이 흐름도 및/또는 블럭도의 블럭 또는 블럭들에 지정된 상기 함수들/작업들을 구현하기 위한 수단을 제공하도록, 범용 컴퓨터, 전용 컴퓨터 또는 머신을 제공하기 위한 다른 프로그램가능 데이터 처리 장치들의 프로세서들에 제공될 수 있다.
이러한 컴퓨터나 다른 프로그램가능 데이터 처리 장치들에 특정 방법의 함수로 지시할 수 있는 컴퓨터 프로그램 명령들은 또한 컴퓨터 판독가능 저장매체내에 저장될 수 있는데, 이를 통해 상기 컴퓨터-판독가능 저장매체내에 저장된 명령들은 상기 흐름도 및/또는 블럭도의 블럭 또는 블럭들에 지정된 상기 함수들/작업들을 구현하는 명령 수단을 포함하는 제품을 제공한다.
상기 컴퓨터 프로그램 제품들은 또한 컴퓨터 구현 프로세스를 제공하기 위해 컴퓨터나 다른 프로그램가능 장치들상에서 수행되어야 하는 동작 단계들의 시르즈를 유발하기 위해, 컴퓨터나 다른 프로그램가능 데이터 처리 장치들에 로드될 수 있으며, 이를 통해서 상기 컴퓨터 또는 다른 프로그램가능 장치들상에서 실행된 명령들이 흐름도 및/또는 블럭도내 블럭이나 블럭들에 지정된 함수들/작업들을 구현하기 위한 프로세스들을 제공한다.
도면들내 흐름도 및 블럭도들은 본 발명의 다양한 실시예들에 따라 시스템들, 방법들 및 컴퓨터 프로그램 제품들의 가능한 구현들의 아케텍쳐, 기능들 및 작동들을 도시한다. 이러한 관점에서, 흐름도 또는 블럭도들내 각각의 블럭은 모듈, 세그먼트, 또는 코드의 일부, 하나 또는 그 이상의 실행가능한 명령들을 나타낼 수 있는데, 이들은 상기 지정된 논리 함수(들)을 구현하기 위한 하나 또는 그 이상의 실행가능한 명령들을 포함한다. 일부 다른 실시예들에서, 상기 블럭내에 표시된 상기 함수들은 도면들내에 노트된 순서와 다르게 발생할 수 있다. 예를 들어, 연속적으로 도시된 두 개의 블럭들이 구현시에는, 포함된 기능에 따라서, 실질적으로 동시에 실행될 수 있으며 또는 상기 블럭들은 때로는 반대 순서로 실행될 수도 있다. 블럭도들 및/또는 흐름도의 각각의 블럭이나 상기 블럭도들 및/또는 흐름도의 블럭들의 조합은 지정된 함수들 또는 동작들을 수행하는 전용 하드웨어기반 시스템들 또는 전용 하드웨어 및 컴퓨터 명령들의 조합에 의해 구현될 수 있다.
여기서 사용된 용어는 특정 실시예들을 기술하기 위한 목적이며 본 발명을 한정하려는 목적은 아니다. 여기에 사용된 바와 같이, 상기 단수 표현들 "하나", "한" 및 "상기"는 구체적으로 따로 기재되어 있지 않은 한, 다수 표현들도 또한 포함하려는 의도이다. 상기 용어들 "포함하는" 및/또는 "포함하다"는 본 상세한 설명에서 사용될 때, 표시된 특징들, 상수들, 단계들, 작동들, 요소들, 컴포넌트들 및/또는 그룹들의 존재를 지정하는 것이고 하나 또는 그 이상의 다른 특징들, 상수들, 단계들, 작업들, 요소들, 컴포넌트들 및/또는 그들의 그룹들의 존재나 추가를 제한하는 것은 아니라는 점이 이해되어져야 한다. 상기 용어들 "바람직하게", "바람직한", "더 좋은", "선택적으로", "할 수 있는" 및 유사한 용어들은 본 발명의 선택적(필수적이 아님) 특징을 언급하는 아이템, 조건이나 단계를 나타내는데 사용된다.
이하의 청구항들내의 대응 구조들, 물질들, 행동들 및 모든 기능적 청구항들의 균등물들은 명확하게 청구된바와 같이 다른 청구된 요소들과 함께 상기 기능들을 수행하기 위한 임의의 구조, 물질 또는 동작들도 포함하려는 의도이다. 본 발명의 상세한 설명은 기술 및 설명의 목적으로 표시되었으며, 표시된 형태로 본 발명을 총망라하거나 한정하려는 의도는 아니다. 많은 변경 및 변형들이 본 발명의 권리범위에서 벗어남이 없이 본 기술분야에서 통상의 기술을 가진자에 의해서 용이하게 이루어질 수 있다. 상기 실시예는 본 발명의 원리 및 구현 애플리케이션을 가장 잘 설명하고, 본 기술분야에서 통상의 기술을 가진 자가 특정 사용 방법에 적합한 다양한 변경이 된 다양한 실시예들에 대해서 본 발명을 이해할 수 있도록 하기 위해서, 선택되고 기술되었다.

Claims (15)

  1. 컴퓨터 시스템에 있어서,
    복수의 하드웨어 디바이스들; 및
    상기 하드웨어 디바이스들 모두와 전기적으로 통신하는 전력 관리 디바이스를 포함하되,
    각각의 하드웨어 디바이스는 고전력 상태(elevated power state)를 포함하는 복수의 서로 다른 전력 상태들에서 상호교환적으로(interchangeably) 작동가능하며, 지정된 지속기간(specified duration)동안 상기 고전력 상태에서 작동하는 것을 개별적으로 요청하도록 구성되고,
    상기 전력 관리 디바이스는 상기 지정된 지속기간동안 상기 고전력 상태들에서 작동하도록, 상기 디바이스들로부터 상기 요청들을 수신하고 선택적으로 승인하고(authorizing), 상기 지정된 지속기간이 만료된 후 상기 고전력 상태에서 작동하는 상기 디바이스들의 승인을 취소(revoking)하도록 구성된
    컴퓨터 시스템.
  2. 제 1항에 있어서,
    상기 전력 관리 디바이스는
    상기 고전력 상태들에서 동시에 작동될 수 있는 디바이스들의 수를 상기 복수의 디바이스들 모두보다 적게 제한하도록 구성된
    컴퓨터 시스템.
  3. 제 1항에 있어서,
    상기 전력 관리 디바이스는
    상기 디바이스들의 고전력 상태들을 달성하기 위해 필요한 추가 전력이 기정해진 한도를 초과하지 않도록, 상기 고전력 상태 요청들을 승인하도록 구성된
    컴퓨터 시스템.
  4. 제 1항에 있어서,
    마더보드(motherboard)를 더 포함하되,
    상기 하드웨어 디바이스들은 상기 마더보드의 컴포넌트들을 포함하고,
    상기 전력 관리 디바이스는 상기 마더보드에 포함된 베이스보드(baseboard) 관리 제어기를 포함하고 상기 마더보드의 상기 복수의 컴포넌트들과 전기적으로 통신하는
    컴퓨터 시스템.
  5. 제 1항에 있어서,
    상기 하드웨어 디바이스들은
    프로세서, 하드 드라이브, 메모리 칩, PCI 카드, 비디오 카드, 광 드라이브, 팬, 네트워크 아답터, 파워 서플라이, 디스플레이 및 입력 디바이스로 이루어진 하나 또는 그 이상의 그룹을 포함하는
    컴퓨터 시스템.
  6. 제 1항에 있어서,
    복수의 베이(bay)들을 가지는 멀티-블레이드 샤시 및
    복수의 클라이언트 블레이드들을 포함하되,
    각각의 클라이언트 블레이드는 상기 베이들 중 하나내에 받아들여지고, 각각의 클라이언트 블레이드는 상기 하드웨어 디바이스들 중 하나 또는 그 이상을 포함하며, 상기 전력 관리 디바이스는 상기 복수의 클라이언트 블레이드들로의 전력을 관리하기 위해서 상기 샤시내 샤시 관리 모듈을 포함하는
    컴퓨터 시스템.
  7. 제 1항에 있어서,
    상기 샤시 관리 모듈과 통신하는 전압 레귤레이션 모듈(VRM)을 더 포함하고,
    상기 전압 레귤레이션 모듈은 상기 디바이스들의 전력 상태들에 따라 상기 디바이스들에 대한 전압을 변경하기(vary) 위해 구성된
    컴퓨터 시스템.
  8. 컴퓨터 시스템에서 전력을 관리하는 방법에 있어서,
    상기 컴퓨터 시스템의 하나 또는 그 이상의 디바이스들이 작동되는 단계-각각의 디바이스들은 고전력 상태를 포함하는 복수의 서로 다른 전력 상태들을 가짐-;
    각각의 디바이스에 의해, 지정된 지속기간동안 상기 고전력 상태에서 작동하도록 요청을 개별적으로 생성하는 단계;
    상기 지정된 지속기간들동안 상기 고전력 상태에서 작동하도록 상기 디바이스들로부터 요청들을 수신하고 선택적으로 승인하는 단계; 및
    상기 지정된 지속기간들이 만료된 후, 상기 고전력 상태들에서 작동하기 위한 상기 디바이스들의 상기 승인을 취소하는 단계를 포함하는
    컴퓨터 시스템에서 전력을 관리하는 방법.
  9. 제 8항에 있어서,
    상기 고전력 상태들에서 동시에 작동할 수 있는 디바이스들의 수를 상기 디바이스들 모두보다 적게 제한하는 단계를 더 포함하는
    컴퓨터 시스템에서 전력을 관리하는 방법.
  10. 제 9항에 있어서,
    상기 디바이스들의 상기 고전력 상태들을 달성하기 위해서 필요한 추가 전력이 기정해진 한도를 초과하지 않도록, 상기 고전력 상태 요청들을 승인하는 단계를 더 포함하는
    컴퓨터 시스템에서 전력을 관리하는 방법.
  11. 제 9항에 있어서,
    상기 디바이스의 운영 주파수 및 전압 중 하나 또는 둘 다를 증가하여 상기 디바이스의 전력상태를 증가하는 단계를 더 포함하는
    컴퓨터 시스템에서 전력을 관리하는 방법.
  12. 컴퓨터 시스템에 대한 전력을 관리하기 위해 컴퓨터 사용가능 매체상에 포함된 컴퓨터 사용가능 프로그램 코드를 포함하는 컴퓨터 프로그램 제품에 있어서,
    상기 컴퓨터 시스템의 하나 또는 그 이상의 디바이스들을 작동하기 위한 컴퓨터 사용가능 코드 -각각의 디바이스는 고전력 상태를 포함하는 복수의 서로 다른 전력상태들을 가짐-;
    각각의 디바이스에 의해서, 지정된 지속기간동안 상기 고전력 상태에서 작동하도록 요청을 개별적으로 생성하기 위한 컴퓨터 사용가능 코드;
    상기 디바이스들로부터, 상기 지정된 지속기간들동안 상기 고전력 상태에서 작동하도록 요청들을 수신하고 선택적으로 승인하기 위한 컴퓨터 사용가능 코드; 및
    상기 지정된 지속기간들이 만료면 후, 상기 고전력 상태들에서 작동하기 위한 상기 디바이스들의 상기 승인을 취소하기 위한 컴퓨터 사용가능 코드를 포함하는
    컴퓨터 프로그램 제품.
  13. 제 12항에 있어서,
    상기 고전력 상태들에서 동시에 작동할 수 있는 디바이스들의 수를 상기 디바이스들 모두보다 적게 제한하기 위한 컴퓨터 사용가능 코드를 포함하는
    컴퓨터 프로그램 제품.
  14. 제 12항에 있어서,
    상기 디바이스들의 상기 고전력 상태들을 달성하기 위해 필요한 추가 전력이 기정해진 한도를 초과하지 않도록, 상기 고전력 상태 요청들을 승인하기 위한
    컴퓨터 프로그램 제품.
  15. 제 12항에 있어서,
    상기 디바이스의 운영 주파수 및 전압 중 하나 또는 둘 다를 증가함으로써, 디바이스의 전력 상태를 증가하기 위한
    컴퓨터 프로그램 제품.
KR1020100065062A 2009-07-07 2010-07-06 컴퓨터 시스템 하드웨어 디바이스들의 고전력 상태들의 선택적 승인에 의한 전력 관리 KR20110004328A (ko)

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US12/498,386 2009-07-07
US12/498,386 US20110010566A1 (en) 2009-07-07 2009-07-07 Power management by selective authorization of elevated power states of computer system hardware devices

Publications (1)

Publication Number Publication Date
KR20110004328A true KR20110004328A (ko) 2011-01-13

Family

ID=43428363

Family Applications (1)

Application Number Title Priority Date Filing Date
KR1020100065062A KR20110004328A (ko) 2009-07-07 2010-07-06 컴퓨터 시스템 하드웨어 디바이스들의 고전력 상태들의 선택적 승인에 의한 전력 관리

Country Status (2)

Country Link
US (1) US20110010566A1 (ko)
KR (1) KR20110004328A (ko)

Cited By (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US9324444B2 (en) 2013-08-19 2016-04-26 SK Hynix Inc. Data storage device
KR20200059433A (ko) * 2018-11-21 2020-05-29 전자부품연구원 Bmc 환경에서의 사용자 특화 운용 메커니즘에 의한 서버 관리 방법, 기록매체, 및 서버

Families Citing this family (16)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
EP2293192B1 (en) * 2008-01-27 2021-03-31 Citrix Systems, Inc. Methods and systems for remoting three dimensional graphics
US8448001B1 (en) 2009-03-02 2013-05-21 Marvell International Ltd. System having a first device and second device in which the main power management module is configured to selectively supply a power and clock signal to change the power state of each device independently of the other device
US8751844B2 (en) * 2009-09-24 2014-06-10 Citrix Systems, Inc. Systems and methods for attributing an amount of power consumption to a workload
US8694810B2 (en) * 2010-09-22 2014-04-08 International Business Machines Corporation Server power management with automatically-expiring server power allocations
CN102467217A (zh) * 2010-11-19 2012-05-23 鸿富锦精密工业(深圳)有限公司 电源状态同步获取方法
TW201222226A (en) * 2010-11-23 2012-06-01 Hon Hai Prec Ind Co Ltd Remote motherboard controller and method for controlling a remote motherboard
US9182874B2 (en) * 2011-01-31 2015-11-10 Dell Products, Lp System and method for out-of-band communication between a remote user and a local user of a server
US9063733B2 (en) 2011-10-31 2015-06-23 Lenovo Enterprise Solutions (Singapore) Pte. Ltd. Managing power modes of a computing system
GB2502316A (en) * 2012-05-24 2013-11-27 Ibm Blade enclosure with interfaces for computer blades and conventional computers
US9529583B2 (en) 2013-01-15 2016-12-27 Intel Corporation Single microcontroller based management of multiple compute nodes
US9395788B2 (en) * 2014-03-28 2016-07-19 Intel Corporation Power state transition analysis
US10048738B2 (en) * 2016-03-03 2018-08-14 Intel Corporation Hierarchical autonomous capacitance management
US20190064913A1 (en) * 2017-08-29 2019-02-28 Walmart Apollo, Llc System and method for collaborative computing power
US11099629B2 (en) 2019-10-08 2021-08-24 Dell Products L.P. Device-dependent peak power throttling for battery-operated systems
CN113708986B (zh) * 2020-05-21 2023-02-03 富联精密电子(天津)有限公司 服务器监控装置、方法及计算机可读存储介质
US11934286B2 (en) * 2021-04-29 2024-03-19 Dell Products L.P. Subsystem power range configuration based on workload profile

Family Cites Families (18)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5560022A (en) * 1994-07-19 1996-09-24 Intel Corporation Power management coordinator system and interface
US6189106B1 (en) * 1998-05-08 2001-02-13 Gateway, Inc. Method and apparatus for operating an electronic device at an optimal power mode based upon a scheduled event
US6865450B2 (en) * 2001-05-10 2005-03-08 Siemens Westinghouse Power Corporation Schedule-based load estimator and method for electric power and other utilities and resources
US7171570B2 (en) * 2001-11-16 2007-01-30 Apple Computer, Inc. Method and apparatus for selectively increasing the operating speed of an electronic circuit
US7085704B2 (en) * 2002-05-07 2006-08-01 Zarlink Semicorporation V.N. Inc. Time-indexed multiplexing as an efficient method of scheduling in hardware
US7007183B2 (en) * 2002-12-09 2006-02-28 International Business Machines Corporation Power conservation by turning off power supply to unallocated resources in partitioned data processing systems
US7100062B2 (en) * 2003-01-28 2006-08-29 Hewlett-Packard Development Company, L.P. Power management controller and method
US7210048B2 (en) * 2003-02-14 2007-04-24 Intel Corporation Enterprise power and thermal management
US7240225B2 (en) * 2003-11-10 2007-07-03 Dell Products L.P. System and method for throttling power in one or more information handling systems
US7383451B2 (en) * 2005-02-18 2008-06-03 Lenovo (Singapore) Pte. Ltd. Controlling power usage of computing device components in holistic manner
US7444526B2 (en) * 2005-06-16 2008-10-28 International Business Machines Corporation Performance conserving method for reducing power consumption in a server system
US7539881B2 (en) * 2006-04-15 2009-05-26 Hewlett-Packard Development Company, L.P. System and method for dynamically adjusting power caps for electronic components based on power consumption
US7587621B2 (en) * 2006-11-08 2009-09-08 International Business Machines Corporation Computer system management and throughput maximization in the presence of power constraints
US7818592B2 (en) * 2007-04-18 2010-10-19 Globalfoundries Inc. Token based power control mechanism
US7908495B2 (en) * 2007-10-11 2011-03-15 Broadcom Corporation System and method for implementing fairness in the powering of computing devices in a power over ethernet application
US8046600B2 (en) * 2007-10-29 2011-10-25 Microsoft Corporation Collaborative power sharing between computing devices
US20090164810A1 (en) * 2007-12-21 2009-06-25 Nokia Corporation Methods, apparatuses, and computer program products for managing power usage in mobile devices
US9032223B2 (en) * 2008-09-05 2015-05-12 Intel Corporation Techniques to manage operational parameters for a processor

Cited By (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US9324444B2 (en) 2013-08-19 2016-04-26 SK Hynix Inc. Data storage device
KR20200059433A (ko) * 2018-11-21 2020-05-29 전자부품연구원 Bmc 환경에서의 사용자 특화 운용 메커니즘에 의한 서버 관리 방법, 기록매체, 및 서버

Also Published As

Publication number Publication date
US20110010566A1 (en) 2011-01-13

Similar Documents

Publication Publication Date Title
KR20110004328A (ko) 컴퓨터 시스템 하드웨어 디바이스들의 고전력 상태들의 선택적 승인에 의한 전력 관리
TWI621068B (zh) 伺服器機架電力管理
US8694810B2 (en) Server power management with automatically-expiring server power allocations
US8656003B2 (en) Method for controlling rack system using RMC to determine type of node based on FRU's message when status of chassis is changed
US8006112B2 (en) System and method for managing blades after a power supply unit failure
US8832348B2 (en) Methods and systems for an interposer board
US20120017074A1 (en) Dynamic system mode switching
US10466729B2 (en) Power supply system, power management, apparatus, power management method, and power management program
Filani et al. Dynamic data center power management: Trends, issues, and solutions.
US9819532B2 (en) Multi-service node management system, device and method
WO2008148719A1 (en) System for unified management of power, performance, and thermals in computer systems
US9870037B2 (en) Method and apparatus for collaborative power and thermal control of fan run time average power limiting
US8677160B2 (en) Managing power consumption of a computer
US8539271B2 (en) Determining a power saving mode based on a hardware resource utilization trend
US8103884B2 (en) Managing power consumption of a computer
US20090187783A1 (en) Adjusting Cap Settings of Electronic Devices According to Measured Workloads
US10025369B2 (en) Management apparatus and method of controlling information processing system
US10429909B2 (en) Managing power in a high performance computing system for resiliency and cooling
CN104503932A (zh) 多主板服务器主基板管理控制器仲裁方法及系统
US8151122B1 (en) Power budget managing method and system
EP3295275B1 (en) Managing power in a high performance computing system for resiliency and cooling
US11733762B2 (en) Method to allow for higher usable power capacity in a redundant power configuration
US20160073543A1 (en) Zoneable power regulation
Ali et al. Automating CPU dynamic thermal control for high performance computing
TW201312333A (zh) 電腦耗電之監控管理系統及方法

Legal Events

Date Code Title Description
WITN Application deemed withdrawn, e.g. because no request for examination was filed or no examination fee was paid