KR100231692B1 - Chill 디버깅 정보 생성방법 - Google Patents

Chill 디버깅 정보 생성방법 Download PDF

Info

Publication number
KR100231692B1
KR100231692B1 KR1019960062357A KR19960062357A KR100231692B1 KR 100231692 B1 KR100231692 B1 KR 100231692B1 KR 1019960062357 A KR1019960062357 A KR 1019960062357A KR 19960062357 A KR19960062357 A KR 19960062357A KR 100231692 B1 KR100231692 B1 KR 100231692B1
Authority
KR
South Korea
Prior art keywords
information
chill
debugging
debugging information
file
Prior art date
Application number
KR1019960062357A
Other languages
English (en)
Other versions
KR19980044290A (ko
Inventor
변영준
정영식
이병선
Original Assignee
이계철
한국전기통신공사
정선종
한국전자통신연구원
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by 이계철, 한국전기통신공사, 정선종, 한국전자통신연구원 filed Critical 이계철
Priority to KR1019960062357A priority Critical patent/KR100231692B1/ko
Publication of KR19980044290A publication Critical patent/KR19980044290A/ko
Application granted granted Critical
Publication of KR100231692B1 publication Critical patent/KR100231692B1/ko

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/36Preventing errors by testing or debugging software
    • G06F11/362Software debugging
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/36Preventing errors by testing or debugging software
    • G06F11/3664Environments for testing or debugging software

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Computer Hardware Design (AREA)
  • Quality & Reliability (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Debugging And Monitoring (AREA)

Abstract

본 발명은 CHILL 디버거를 이용하여 CHILL 원시화일을 디버깅하기 위해 필요한 CHILL 디버깅 정보를 생성하는 방법에 관한 것으로, 메인 메모리부, 중앙처리장치부, 보조기억 장치부, 입출력 장치부, 유닉스(UNIX) 운영체제부 및 시스템 버스를 포함하는 장치에 적용되는 CHILL 디버깅 정보 생성방법에 있어서, CHILL 컴파일러의 전위 처리기에서 컴파일 시간 디버깅 정보를 추출하여(S11) 메모리 내에서의 심벌의 주소와 프로그램 구조의 범위(영역) 등과 같은 목적화일과 관련된 디버깅 정보를 제외한 부분 디버깅 정보를 생성하는 단계(S12)와, 부분 디버깅 정보 생성단계(S11,S12) 수행 후 CHILL 컴파일러에 의해 컴파일된 목적화일로부터 상기 메모리 내에서의 심벌의 주소와 프로그램 구조의 범위(영역)등의 목적화일 정보를 추출하는 단계(S2)와, 상기 부분 디버깅 정보 생성단계(S11,S12)에서 생성된 부분 디버깅 정보와 상기 목적화일 정보 추출단계(S2)에서 생성된 목적화일 정보를 결합하여(S31) 완전한 디버깅 정보를 생성하는 단계(S32)를 포함하여 구성함으로써, CHILL 프로그램 에러의 발견 및 수정을 용이하게 할 수 있으므로, 소프트웨어의 생산성을 대폭적으로 높일 수 있다.

Description

CHILL 디버깅 정보 생성방법(a generation method of CHILLdebugging information)
본 발명은 CHILL 디버깅 정보 생성방법에 관한 것으로, 특히, CHILL 디버거를 이용하여 CHILL 원시화일을 디버깅하기 위해 필요한 CHILL 디버깅 정보를 생성하는 방법에 관한 것이다.
일반적으로, 디버거(debugger)는 프로그램을 실행하고, 그 상태를 조사 및 변경하며, 중단점(break-point)을 설정하도록 하여, 프로그램애 내재된 에러의 발견 및 수정을 가능하게 하는 도구이다.
이와 같은 디버거를 이용한 프로그램의 디버깅은, 크게 프로그램의 오류 인지, 오류의 위치 발견, 오류의 원인 발견, 오류의 수정과 같은 4단계로 구성되며, 이를 위하여 디버거는 프로그램 실행, 프로그램 추적, 중단점 설정, 변수 시험, 변수 변경, 현재위치 보고 등의 기본적인 기능을 제공한다.
위와 같이 디버거가 원하는 기능을 수행하기 위하여, 컴파일러는 디버깅할 원시화일을 디버거에게 기술하기 위한 디버깅 정보를 생성한다.
상기한 디버깅 정보는 크게 프로그램의 구조를 나타내는 정보와, 프로그램 내부의 심벌에 대한 정보로 나눌 수 있는데 이중에서, 프로그램 구조에 대한 정보로는 원시화일 라인 정보, 모듈의 이름, 모듈의 범위, 원시화일의 이름과 경로, 블럭 정보, 프로시져 이름 및 타입, 또한 프로그램 내부의 심벌에 대한 정보로는 심벌의 모드, 각 모드의 정보, 심벌의 주소 등이 있다.
한편, CHILL 언어는 범용 프로그래밍 언어로서, 교환기 소프트웨어와 같은 대용량 통신용 소프트웨어의 제작에 주로 이용되는 언어이다.
이와 같이 CHILL로 작성된 소프트웨어의 에러를 쉽고 빠른 시간에 발견 및 수정하기 위한 도구로 CHILL 디버거가 필요하며, 이에 따라, CHILL 디버거에게 원시화일을 기술하기 위하여 CHILL 디버깅 정보를 생성하여야 한다.
그러나, 현재까지, 상기한 CHILL 디버거를 이용하여 CHILL 프로그램 에러의 발견 및 수정을 용이하게 하기 위해 필수적으로 요구되는 CHILL 디버깅 정보를 생성하는 방법에 대한 개발은 전무한 실정이다.
결국, 본 발명의 목적은, CHILL 디비거를 이용하여 CHILL 프로그램 에러의 발견 및 수정을 용이하게 하기 위해 필수적으로 요구되는 CHILL 디버깅 정보를 효과적으로 생성하는 방법을 제공함에 있다.
제1도는 본 발명이 적용되는 하드웨어의 블럭 구성도.
제2도는 본 발명의 바람직한 실시예에 따른 CHILL 디버깅 정보 생성과정을 나타낸 흐름도.
제3도는 본 발명의 바람직한 실시예에 따른 CHILL 디버깅 정보 생성과정에 대한 상세 처리 흐름도.
* 도면의 주요부분에 대한 부호의 설명
101 : 메인 메모리부 102 : 중앙처리 장치부
103 : 유닉스 운영체제부 104 : 보조기억 장치부
105 : 입출력 장치부 106 : 시스템 버스
201 : CHILL 원시파일 202 : CHILL 전원 처리기
203 : CHILL 후위 처리기 204 : 어셈블러
205 : 목적파일
상기한 목적을 달성하기 위한 본 발명에 따른 CHILL 디버깅 정보 생성방법은, 메인 메모리부, 중앙처리 장치부, 보조기억 장치부, 입출력 장치부, 유닉스 (UNIX) 운영체제부 및 시스템 버스를 포함하는 장치에 적용되는 CHILL 디버깅 정보 생성방법에 있어서, 메인 메모리부, 중앙처리 장치부, 보조기억 장치부, 입출력 장치부, 유닉스 운영체제부 및 시스템 버스를 포함하는 장치에 적용되는 CHILL 디버깅 정보 생성방법에 있어서, CHILL 컴파일러의 전위 처리기에서 컴파일 시간 디버깅 정보를 추출하여 메모리 내에서의 심벌의 주소와 프로그램 구조의 범위(영역) 등과 같은 목적 화일과 관련된 디버깅 정보를 제외한 부분 디버깅 정보를 생성하는 단계와, 상기 디버깅 정보 생성단계 수행후, CHILL 컴파일러에 의해 컴파일된 목적화일로부터 상기 메모리 내에서의 심벌의 주소와 프로그램 구조의 범위(영역) 등의 목적화일 정보를 추출하는 단계와, 상기 디버깅 정보 생성단계에서 생성된 부분 디버깅 정보와 상기 목적화일 정보 추출단계에서 생성된 목적화일 정보를 결합하여 완전한 디버깅 정보를 생성하는 단계를 포함하는 것을 특징으로 한다.
이하, 본 발명의 바람직한 실시예에 따른 CHILL 디버깅 정보 생성방법을 첨부도면을 참조하여 보다 상세히 설명한다.
제1도는 본 발명이 적용되는 하드웨어의 블럭 구성도로서, 제1도에 있어서, 메인 메모리부(101)는 CHILL 디버깅 정보생성기 및 관련 화일들이 탑재되는 부분이고, 중앙처리 장치부(102)는 상기한 메인 메모리부(101)에 탑재된 화일을 수행시키는 부분이다.
또한, 보조기억 장치부(104)는 파일, 테이터 등을 저장하는 부분으로, 메인 메모리부(101)에 탑재되지 않는 화일과 도구들이 저장된다.
아울러, 입출력 장치부(105)는 CHILL 디버깅 정보 생성기를 수행하기 위하여 필요한 화일 및 데이터와, 수행 중에 발생하는 모든 오류 메시지를 입출력하는 부분이다.
또한, 유닉스 운영체제부(103)는 상기한 각 부분 및 장치를 제어하는 역할을 수행하며, 상기한 각 부분 및 장치 간에 주고받는 메시지는 시스템 버스(106)를 통해 전달된다.
제2도는 본 발명의 바람직한 실시예에 따른 CHILL 디버깅 정보 생성과정을 나타낸 흐름도이다.
제2도에 도시된 바와 같이, CHILL 원시화일(201)을 컴파일하여 실행 가능한 화일을 생성하기 위하여, CHILL 컴파일 시스템은 크게 기계 독립적인 CHILL 전위처리기(202)와 기계 종속적인 CHILL 후위 처리기(203) 및 어셈블러(204)로 구성된다.
여기에서, 완전한 CHILL 디버깅 정보를 생성하기 위하여, CHILL 전위처리기(202)는 CHILL 원시화일(201)을 입력으로 하여 메모리 내에서의 심벌의 주소와 프로그램 구조의 범위(영역)등과 같은 목적화일과 관련된 디버깅 정보를 제외한 부분 디버깅 정보를 생성한다(S1).
그후, CHILL 컴파일러에 의해 컴파일된 목적화일(205)에서 추출한 메모리 내에서의 심벌의 주소와 프로그램 구조의 범위(영역) 등과 같은 목적화일 정보를 추출하고(S2), 상기한 부분 디버깅 정보를 목적화일 정보와 결합하여(S31) 완전한 디버깅 정보를 생성한다(S32).
제3도는 본 발명의 바람직한 실시예에 따른 CHILL 디버깅 정보 생성과정에 대한 상세 처리 흐름도로서, 상기한 CHILL 디버깅 정보 생성과정을 제3도를 참조하여 더욱 상세히 설명하면 다음과 같다.
CHILL 디버깅 정보를 생성하기 위하여, 먼저, CHILL 전위처리기(202)에서는 CHILL 원시화일(201)을 받아들여(S01) 전위처리기(202)를 수행하며, 이때, 전위처리기(202)는 전위처리기(202)에서 생성 가능한 원시화일(201) 라인 정보의 일부, 모듈의 이름, 원시 화일(201)의 이름과 경로, 블럭 정보의 일부, 프로시져 이름과 타입, 심벌의 모드, 모드 정보 등과 같은 컴파일 시간 디버깅 정보를 추출하여 (S11), 부분 디버깅 정보를 생성한다(S12).
그후, CHILL 후위 처리기(203)와 어셈블러(204)를 수행하여 목적화일(205)이 생성되며(S02), 이와 같이 생성된 목적화일(205)로부터 원시화일(201) 라인의 주소정보, 모듈의 범위, 블럭의 영역 정보, 심벌의 주소 등과 같은 목적화일 정보를 추출하며(S2), 상기한 단게 S12에서 생성된 부분 디버깅 정보에 상기한 단계 S2에서 생성된 목적화일 정보를 결합함으로써(S31), 완전한 디버깅 정보를 생성한다(S32).
이상에서 상세히 설명한 바와 같이, 본 발명에 따르면, CHILL 디버깅 정보를 효과적으로 생성할 수 있으며, 이와 같은 CHILL 디버깅 정보를 CHILL 디버거가 이용하게 함으로써, CHILL 프로그램 에러의 발견 및 수정을 용이하게 할 수 있으므로, 소프트웨어의 생산성을 한층 높일 수 있다.

Claims (3)

  1. 메인 메모리부, 중앙처리 장치부, 보조기억 장치부, 입출력 장치부, 유닉스 운영체제부 및 시스템 버스를 포함하는 장치에 적용되는 CHILL 디버깅 정보 생성방법에 있어서, CHILL 컴파일러의 전위 처리기에서 컴파일 시간 디버깅 정보를 추출하여 메모리 내에서의 심벌의 주소와 프로그램 구조의 범위(영역) 등과 같은 목적화일과 관련된 디버깅 정보를 제외한 부분 디버깅 정보를 생성하는 단계와, 상기 디버깅 정보 생성단계 수행 후, CHILL 컴파일러에 의해 컴파일된 목적 화일로부터 상기 메모리 내에서의 심벌의 주소와 프로그램 구조의 범위(영역)등의 목적화일 정보를 추출하는 단계, 상기 부분 디버깅 정보 생성단계에서 생성된 부분 디버깅 정보와 상기 목적 화일 정보 추출단계에서 생성된 목적화일 정보를 결합하여 완전한 디버깅 정보를 생성하는 단계를 포함하는 것을 특징으로 하는 CHILL 디버깅 생성방법.
  2. 제1항에 있어서, 상기 컴파일 시간 디버깅 정보는, 원시화일 라인 정보의 일부, 모듈의 이름, 원시화일의 이름과 경로, 블럭 정보의 일부, 프로시져 이름과 타입, 심벌의 모드 및 정보, 시그널 처리 프로세스 처리와 같은 통신을 위한 명령어 처리 기능이 강화된 정보를 포함하는 것을 특징으로 하는 CHILL 디버깅 정보 생성방법.
  3. 제1항에 있어서, 상기 목적 화일 정보는, CHILL 컴파일러에 의해 컴파일된 목적화일에서 추출한 메모리 내에서의 심벌의 주소, 프로그램 구조의 범위(영역), 원시화일 라인의 주소 정보, 모듈의 범위, 블럭의 영역 정보를 포함하는 것을 특징으로 하는 CHILL 정보 생성방법.
KR1019960062357A 1996-12-06 1996-12-06 Chill 디버깅 정보 생성방법 KR100231692B1 (ko)

Priority Applications (1)

Application Number Priority Date Filing Date Title
KR1019960062357A KR100231692B1 (ko) 1996-12-06 1996-12-06 Chill 디버깅 정보 생성방법

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
KR1019960062357A KR100231692B1 (ko) 1996-12-06 1996-12-06 Chill 디버깅 정보 생성방법

Publications (2)

Publication Number Publication Date
KR19980044290A KR19980044290A (ko) 1998-09-05
KR100231692B1 true KR100231692B1 (ko) 1999-11-15

Family

ID=19486158

Family Applications (1)

Application Number Title Priority Date Filing Date
KR1019960062357A KR100231692B1 (ko) 1996-12-06 1996-12-06 Chill 디버깅 정보 생성방법

Country Status (1)

Country Link
KR (1) KR100231692B1 (ko)

Also Published As

Publication number Publication date
KR19980044290A (ko) 1998-09-05

Similar Documents

Publication Publication Date Title
EP0709773B1 (en) System and method for generating target language code utilizing an object oriented code generator
US5926639A (en) Embedded flow information for binary manipulation
US6314557B1 (en) Hybrid computer programming environment
CN113342654A (zh) 脚本语言代码调试方法及装置、可读存储介质及电子设备
US6381736B1 (en) Method for compile-time type-checking of arguments for externally-specified format strings
KR100231692B1 (ko) Chill 디버깅 정보 생성방법
US6178547B1 (en) Method and apparatus for generating non-redundant symbolic debug information in computer programs
JP2010287101A (ja) ソフトウエアデバッグ装置及び方法
JP2812302B2 (ja) プログラム開発装置
RU2390821C1 (ru) Способ динамической инструментации
JPH0461380B2 (ko)
JPS63205740A (ja) プログラム実行トレ−ス処理方式
JPH06242943A (ja) ソースコードレベルデバッグ装置
KR19990042077A (ko) 호스트 시스템에서 전자교환용 고수준언어 프로그램 시험 방법
JPH07191873A (ja) デバッガにおける変数の値の推移出力方式
JP2005141406A (ja) コンパイラ検査システムおよび同プログラム
KR0175469B1 (ko) 칠프로그램 변수의 가시성 제어방법
JPH06242942A (ja) ソースコードレベルデバッグ装置
van den Brand et al. TIDE—A Generic Debugging Framework
JP2005301415A (ja) コンパイル方式、シミュレータ、エミュレータおよびプログラム開発支援システム
JPH05204699A (ja) デバッグ時識別子探索方式
JP2001147832A (ja) ソースプログラム対応表示方式
JPS63153648A (ja) プログラムメンテナンス装置
KR950015127A (ko) 칠(chill) 분리 컴파일 방법
JPH02244341A (ja) 実行サブルーチンデバツグ情報出力トレース方式

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: 20040730

Year of fee payment: 6

LAPS Lapse due to unpaid annual fee