KR970016947A - 레지스터 제어 장치 - Google Patents

레지스터 제어 장치 Download PDF

Info

Publication number
KR970016947A
KR970016947A KR1019950031429A KR19950031429A KR970016947A KR 970016947 A KR970016947 A KR 970016947A KR 1019950031429 A KR1019950031429 A KR 1019950031429A KR 19950031429 A KR19950031429 A KR 19950031429A KR 970016947 A KR970016947 A KR 970016947A
Authority
KR
South Korea
Prior art keywords
register
routine
local
local register
pointer
Prior art date
Application number
KR1019950031429A
Other languages
English (en)
Other versions
KR0179840B1 (ko
Inventor
박성휘
Original Assignee
문정환
Lg 반도체 주식회사
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 문정환, Lg 반도체 주식회사 filed Critical 문정환
Priority to KR1019950031429A priority Critical patent/KR0179840B1/ko
Priority to TW085111466A priority patent/TW305034B/zh
Priority to JP08251823A priority patent/JP3125184B2/ja
Publication of KR970016947A publication Critical patent/KR970016947A/ko
Application granted granted Critical
Publication of KR0179840B1 publication Critical patent/KR0179840B1/ko
Priority to US09/770,450 priority patent/US6421825B2/en

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/30Arrangements for executing machine instructions, e.g. instruction decode
    • G06F9/30098Register arrangements
    • G06F9/3012Organisation of register space, e.g. banked or distributed register file
    • G06F9/30134Register stacks; shift registers
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/30Arrangements for executing machine instructions, e.g. instruction decode
    • G06F9/30181Instruction operation extension or modification
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/30Arrangements for executing machine instructions, e.g. instruction decode
    • G06F9/38Concurrent instruction execution, e.g. pipeline, look ahead
    • G06F9/3836Instruction issuing, e.g. dynamic instruction scheduling or out of order instruction execution
    • G06F9/3838Dependency mechanisms, e.g. register scoreboarding
    • G06F9/384Register renaming
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/44Arrangements for executing specific programs
    • G06F9/448Execution paradigms, e.g. implementations of programming paradigms
    • G06F9/4482Procedural
    • G06F9/4484Executing subprograms
    • G06F9/4486Formation of subprogram jump address

Abstract

본 발명은 레지스터 제어 장치에 관한 것으로, 종래에는 일 실시예의 경우 각 루틴의 레지스터 사용 영역을 미리 설정함에 의해 프로그램 작성이 어려울 뿐아니라 각 루틴별 레지스터 할당에 의해 레지스터의 사용 효율이 낮아지는 문제점이 있으며 또한, 다른 실시예의 경우 전체 레지스터를 일정 갯수씩 분할하여 레지스터 뱅크를 형성하므로 루틴에 따라 레지스터가 부족하거나 남을 수 있고 임의의 루틴에서 다른 루틴의 변수(레지스터)를 엑세스하기 곤란하여 레지스터의 활용 효율이 저하되는 문제점이 있었다. 이러한 종래의 문제점을 개선하기 위하여 본 발명은 각 루틴의 실행시 마다 해당 루틴에 대한 레지스터 사용 영역을 설정하고 상위 루틴으로 복귀하면 그 설정된 레지스터 사용 영역을 해제하여 복귀된 루틴을 수행하며, 임의의 루틴에서 다른 루틴의 레지스터를 엑세스하려는 경우 레지스터 논리 주소로 직접 그 루틴의 레지스터를 지정하도록 창안한 것으로, 본 발명은 각 루틴마다 설정된 레지스터를 사용한 후 그 레지스터 영역이 설정이 해제되므로 계속적인 서로 루틴 콜의 경우에도 처리할 수 있어 레지스터의 활용 효율을 향상시킬 수 있다.

Description

레지스터 제어 장치
본 내용은 요부공개 건이므로 전문내용을 수록하지 않았음
제5도는 본 발명의 레지스터 제어 장치의 블럭도.
제6도는 제5도에서 레지스터 제어부의 블럭도.
제7도는 본 발명의 프로그램 수행에 따른 영역 설정의 예시도.
제8도는 본 발명의 프로그램 수행 순서를 보인 흐름도.

Claims (5)

  1. 중앙 처리 장치(CPU)의 제어에 의해 레지스터 제어부(220)가 메모리(230)의 저장 영역에 대한 실제 주소(RR)를 생성하고 억세스 동작을 제어하는 반도체 장치에 있어서, 상기 레지스터 제어부(220)는 현재 수행중인 루틴에서 사용하는 레지스터 영역의 시작 부분 주소를 지정하는 로컬 레지스터 포인터(223)와, 현재 루틴에서 사용하는 레지스터의 갯수를 저장하는 로컬 레지스터 카운터(224)와, 제어 신호(CTL1)에 따라 상기 중앙 처리 장치(210)의 레지스터 논리 주소(RL)와 상기 로컬 레지스터 포인터(223)의 값을 합산하여 레지스터 물리 주소(RR)를 출력하는 가산기(222)와, 상기 중앙 처리 장치(210)의 제어 신호(MCTL)에 따라 상기 가산기(222)에 제어 신호(CTL1)를 출력함과 아울러 상기 로컬 레지스터 포인터(223)과 로컬 레지스터 카운터(224)에 제어 신호(CTL2)를 출력하는 제어 회로(221)로 구성한 것을 특징으로 하는 레지스터 제어 장치.
  2. 제1항에 있어서, 가산기(222)는 제어 회로(221)의 제어 신호(CTL1)에 따라 중앙 처리 장치(210)의 레지스터 논리 주소(RL)를 직접 레지스터 물리 주소(RR)로 출력하거나, 상기 중앙 처리 장치(210)의 레지스터 논리 주소(RL)에 로컬 레지스터 카운터(223)의 값을 합산하여 레지스터 물리 주소(RR)로 출력하는 것을 특징으로 하는 레지스터 제어 장치.
  3. 제1항에 있어서, 로컬 레지스터 포인터(223)는 현재 수행중인 프로그램 루틴에서 다른 서브 루틴을 콜할때 현재의 로컬 레지스터 포인터(223)의 값과 로컬 레지스터 카운터(224)의 값을 합산한 가산기(222)의 출력(RR)을 상기 서브 루틴의 사용 영역의 시작 주소로 저장하는 것을 특징으로 하는 레지스터 제어 장치.
  4. 제1항에 있어서, 로컬 레지스터 카운터(224)는 현재의 루틴에서 서브 루틴 콜(call)이 행해질 때마다 중앙 처리 장치(210)으로부터의 해당 서브 루틴이 사용할 레지스터 갯수를 저장하는 것을 특징으로 하는 레지스터 제어 장치.
  5. 제1항에 있어서, 서브 루틴에서 상위 루틴으로 복귀할 때 메모리(330)에 저장되었던 로컬 레지스터 포인터의 값과 로컬 레지스터 카운터의 값을 로컬 레지스터 포인터(223)와 로컬 레지스터 카운터(224)에 각기 저장하여 복귀된 루틴이 계속적으로 수행되도록 하는 것을 특징으로 하는 레지스터 제어 장치.
    ※ 참고사항 : 최초출원 내용에 의하여 공개하는 것임.
KR1019950031429A 1995-09-22 1995-09-22 레지스터 제어장치 KR0179840B1 (ko)

Priority Applications (4)

Application Number Priority Date Filing Date Title
KR1019950031429A KR0179840B1 (ko) 1995-09-22 1995-09-22 레지스터 제어장치
TW085111466A TW305034B (ko) 1995-09-22 1996-09-19
JP08251823A JP3125184B2 (ja) 1995-09-22 1996-09-24 レジスタ制御装置
US09/770,450 US6421825B2 (en) 1995-09-22 2001-01-29 Register control apparatus and method thereof for allocating memory based on a count value

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
KR1019950031429A KR0179840B1 (ko) 1995-09-22 1995-09-22 레지스터 제어장치

Publications (2)

Publication Number Publication Date
KR970016947A true KR970016947A (ko) 1997-04-28
KR0179840B1 KR0179840B1 (ko) 1999-05-15

Family

ID=19427611

Family Applications (1)

Application Number Title Priority Date Filing Date
KR1019950031429A KR0179840B1 (ko) 1995-09-22 1995-09-22 레지스터 제어장치

Country Status (4)

Country Link
US (1) US6421825B2 (ko)
JP (1) JP3125184B2 (ko)
KR (1) KR0179840B1 (ko)
TW (1) TW305034B (ko)

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO2008057834A2 (en) * 2006-11-03 2008-05-15 Intel Corporation Technique for increasing control and status signal density in a fixed register address space

Families Citing this family (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP3763518B2 (ja) * 2001-05-29 2006-04-05 インターナショナル・ビジネス・マシーンズ・コーポレーション コンパイラ、そのコンパイル方法およびプログラム
US20040030963A1 (en) * 2002-08-12 2004-02-12 Sun Microsystems, Inc., A Delaware Corporation Method and apparatus for debugging computer program
US11966328B2 (en) 2020-12-18 2024-04-23 Advanced Micro Devices, Inc. Near-memory determination of registers

Family Cites Families (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5043870A (en) * 1982-02-24 1991-08-27 At&T Bell Laboratories Computer with automatic mapping of memory contents into machine registers during program execution
JP3034873B2 (ja) * 1988-07-01 2000-04-17 株式会社日立製作所 情報処理装置
JPH07114498A (ja) * 1993-10-15 1995-05-02 Toshiba Corp マイクロプロセッサ
EP0676691A3 (en) * 1994-04-06 1996-12-11 Hewlett Packard Co Device for saving and restoring registers in a digital computer.
US5655132A (en) * 1994-08-08 1997-08-05 Rockwell International Corporation Register file with multi-tasking support

Cited By (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO2008057834A2 (en) * 2006-11-03 2008-05-15 Intel Corporation Technique for increasing control and status signal density in a fixed register address space
WO2008057834A3 (en) * 2006-11-03 2008-06-26 Intel Corp Technique for increasing control and status signal density in a fixed register address space
US8185671B2 (en) 2006-11-03 2012-05-22 Intel Corporation Technique for increasing control and status signal density in a fixed register address space

Also Published As

Publication number Publication date
JP3125184B2 (ja) 2001-01-15
US20010004758A1 (en) 2001-06-21
US6421825B2 (en) 2002-07-16
JPH09114661A (ja) 1997-05-02
TW305034B (ko) 1997-05-11
KR0179840B1 (ko) 1999-05-15

Similar Documents

Publication Publication Date Title
US4954942A (en) Software debugging system for writing a logical address conversion data into a trace memory of an emulator
US5812868A (en) Method and apparatus for selecting a register file in a data processing system
KR950033823A (ko) 컴퓨터 시스템내에서 교차 영역 호출을 검출 및 실행하는 방법 및 장치
KR890004236A (ko) 스택 제어(stack control)
KR900000795A (ko) 데이타 처리 시스템
KR940000992A (ko) 디지탈데이타프로세서작동방법
KR970016947A (ko) 레지스터 제어 장치
KR980003942A (ko) 매트릭스 보간 방법
KR940004440A (ko) 데이타처리장치
KR960706130A (ko) 페이지 주소 모드를 구비한 마이크로컨트롤러(Microcontroller having a page address mode)
KR940006829B1 (ko) 인터럽트 변경이 가능한 구조를 갖는 디지탈신호 프로세서
KR910014812A (ko) 내부 메모리 맵 레지스터를 관측하는 방법 및 장치
KR100207335B1 (ko) 마이크로컴퓨터와 어드레스 발생 방법
KR920010479B1 (ko) 메모리 확장회로 및 방법
KR100199477B1 (ko) 절약된 메모리를 갖는 전자제어 시스템 및 메모리 절약 방법
KR960018958A (ko) 다중 프로세서 시스템에서 아토믹 명령어 수행시 데이타 버퍼를 사용한 메인 메모리 액세스 장치
KR100599944B1 (ko) 최적의 액세스 전략을 결정하는 방법
KR0164930B1 (ko) 에뮬레이터의 프로그램 정지 방법
JPS63269237A (ja) マイクロコンピユ−タの開発装置
KR19990037240U (ko) 인터럽트 서비스 루틴 실행 장치
SU523457A1 (ru) Устройство дл защиты пам ти
JPH03208132A (ja) シングルチツプマイクロコンピユータ
KR0164725B1 (ko) 캐쉬 메모리의 영역 분할방법 및 회로
KR20010082982A (ko) 확장된 인터럽트 벡터를 사용하는 인터럽트 제어 시스템및 인터럽트 제어 방법
KR0159720B1 (ko) 마이크로 컴퓨터의 프로그램영역 크기 확장회로

Legal Events

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

Payment date: 20051021

Year of fee payment: 8

LAPS Lapse due to unpaid annual fee