2. 메모리 기술

2023. 6. 18. 12:02·컴퓨터 구조/Ch5. 메모리 계층구조
본 정리는 CS422-컴퓨터 구조 및 설계 : 하드웨어/소프트웨어 인터페이스. David A. Patterson, 존 헤네시 책을 바탕으로 하고 있음을 미리 알립니다

컴퓨터의 3대 구성 요소

컴퓨터의 3대 구성 요소이다.

 

우리는 지금껏 Processor가 어떻게 명령어를 처리하고, 제어하는지 알아왔다.

 

5장에서는 그러한 명령어들을 갖고 있는 프로그램을 저장하고 있는 메모리가 어떻게 처리되는지 알아본다.

 

 

메모리 계층 구조


 

사실 생각해보면, 그냥 작고 빠른 레지스터,캐시,램 등을 엄청나게 많이 사용하면 메모리의 성능은 가하 급수적으로 빨라질 것이다.

 

그러나 데이터 저장소의 불변하는 진리 중 하나는 '작을수록 빠르고 비싸며, 클수록 느리고 싸다' 는 것이다.

 

그렇다면 우리는 어떻게 메모리를 크고 싸고 빠르게 사용할 수 있을까?

이를 해결하는 방법이 바로 메모리 계층구조이다.

 

The Principle of Locality(지역성의 원칙) 덕에 메모리 계층 구조가 구현될 수 있다.

 

 

The Principle of Locality(지역성의 원칙)

  1. Temporal locality (시간적 지역성) - 한번 참조된 항목은 곧바로 다시 참조될 확률이 크다.
  2. spatial locality (공간적 지역성) - 한번 참조된 항목 근처에 있는 다른 항목들이 곧바로 참조될 가능성이 높다.

즉, 결국 사용되는 지역은 한정적이므로, 프로그램 전체가 메모리에 들어가 있을 필요가 없고, 지역성을 이용해 자주 사용되는 영역을 메모리에 올려두고 해당 부분만 사용하는 것이 메모리 계층 구조의 원리이다.

 

메모리 계층 구조에서 사용되는 언어

  • Block : 두 계층 간 정보의 최소 단위를 블록이라고 한다.
  • Hit Rate : 프로세서에서 필요한 데이터를 메모리에서 찾았을 때 메모리에서 데이터가 있을 확률
  • Miss Rate : Hit Rate의 역수이다. (1-Hit Rate )
  • Miss Penalty : 데이터를 찾지 못했을 때 데이터를 가져오는데 드는 시간

컴퓨터에서 RAM(Random Access Memory)의 중요성 - 메모리의 크기가 작아질수록 가지고 있을 수 있는 데이터가 작아지고, Miss Rate는 증가하여 점점 더 하위 계층의 느린 메모리에 접근하게 될 것이고, 컴퓨터의 성능이 느려지게 되므로 RAM이 커야 컴퓨터의 성능에 도움이 된다.

메모리 계층구조

메모리 계층 구조의 특징

  • 프로세서와 멀어질수록 메모리의 크기가 커진다.
  • 상위 계층에 있는 데이터는 하위 계층의 부분 집합이다. (결국 하위계층에서 가져온 데이터 이므로)
  • 보통 메모리 계층 구조는 프로세서 가장 근처에 캐시, 그 아래 레지스터, 그 아래 메인 메모리 그 아래 disk 로 구성된다.

 

메모리 계층 구조의 관리

  • 레지스터와 메모리 사이의 관리 - 컴파일러
  • 캐시와 메인 메모리 사이의 관리 - cache controller hardware
  • 메모리와 Disk 사이의 관리 - 운영체제

 

 

메모리 기술

  • Caches - SRAM(Static Random Access Memory)이 사용된다. 요즘엔 프로세서 칩에 캐시가 집적된다고 한다. 가장 빠르지만 매우 비싸다. 한번 쓰인 정보는 컴퓨터가 꺼지기 전까지 지워지지 않는다.(static)
  • Main memory - DRAM(Dynamic Random Access Memory)이 사용된다. 캐시에 비해 느리고 비싸다. 정보 계속 재갱신 되어야한다. (dynamic) 
  • Flash memory - 메인메모리에 비해 느리고 비싸지만 크기가 크다. 플래시 메모리에 한번 쓰면 비트가 마모된다. 즉, 수명이 있다. 마모 균등화 기법을 사용하여 수명이 다하는 거의 없다고 한다.
  • Disk - 가장 크고 싼 저장 장소. 섹터,트랙,실린더 등으로 이루어져있다.

 

참고 : 캐시로 데이터를 옮기기 위한 메모리 시스템


 

1. One-word-wide bank memory organization

 

한번에 하나의 word 씩 cache로 보내는 메모리 시스템이다.

 

예를 들어, 하나의 블럭이 4word로 이루어져있다고 가정하자.

 

주소를 보내는데 1 bus cycle

각 메모리로부터 word를 가져오는데 1 bus cycle

처음 메모리에 접근하는데 15 cycle 

 

이라고 가정하자.

 

그렇다면, 이 메모리 시스템의 경우엔, 한블럭을 가져오는데 주소를 한번 보내고 4word를 각각 메모리에 한번씩 접근하여 가져오므로,

한블럭을 가져오는데 1 + 4 x (15 + 1) = 65cycle 이 걸리게 될 것이다.

 

 

2. Wide-memory bank

 

한번에 여러 word를 보낼 수 있는 메모리 시스템이다.

 

위와 똑같이, 가정하고 2 word-wide 메모리 시스템이라고 가정하자.

 

주소를 한번 보내고, 한번에 2word씩 가져올 수 있으므로 4word를 가져오기 위해선 2번만 메모리에 접근하면 된다.

 

한블럭을 가져오는데 1 + 2 x (15 + 1) = 33cycle 이 걸리게 될 것이다.

 

 

3. Interleave-memory bank

 

메모리에 한번만 접근해도 bank를 사용하여 word를 각 bank로부터 받아올 수 있는 메모리 시스템이다.

 

주소를 한번 보내고, 메모리에 한번 접근한 후 각 bank로부터 1 word 씩 가져오면 되므로

 

한블럭을 가져오는데 1 + 1 x 15 + 4 x 1 = 20 cycle이 걸리게 될 것이다.

저작자표시

'컴퓨터 구조 > Ch5. 메모리 계층구조' 카테고리의 다른 글

4. 캐시 성능의 측정 및 향상  (0) 2023.06.18
3. 캐시의 기본  (0) 2023.06.18
'컴퓨터 구조/Ch5. 메모리 계층구조' 카테고리의 다른 글
  • 4. 캐시 성능의 측정 및 향상
  • 3. 캐시의 기본
smile blog
smile blog
건국대 첨단바이오공학부 & 컴퓨터공학부 BT & IT 기술로 희망을 꿈 꿉니당
  • smile blog
    스마일 블로그
    smile blog
  • 전체
    오늘
    어제
    • 분류 전체보기 (816)
      • 일상 생각들 (2)
      • 학과에 대해 (4)
        • 첨단바이오공학부 (4)
        • 컴퓨터공학부 (0)
      • -------- 프로젝트 -------- (0)
      • [DS] 토이 프로젝트 (1)
      • [Web, Game, XR] 토이 프로젝트 (11)
      • 경진대회 (1)
      • -------- 진로 -------- (0)
      • 생물정보학자 (18)
        • 데이터 과학이란? (0)
        • 되는 방법 (8)
        • 책 추천 (2)
        • 인강 (1)
        • 대학 (2)
        • 회사 (1)
        • 학원 (2)
        • 학회 (2)
      • 디지털 헬스케어 (72)
        • 방법 (8)
        • 생각들 (10)
        • 공부법 (4)
        • 책 추천 (2)
        • 학원 (2)
        • 참고 (2)
        • 대학 (3)
        • 회사 (3)
        • 인강 (2)
        • 게임 엔진들 (1)
        • 게임 프로그래머 개론 (2)
        • 게임 프로그래머 취업 전략 가이드 (7)
        • 취업 서류 (1)
        • 애정하는 게임들 (4)
        • XR 테크니컬 아티스트 (9)
        • 영화, 애니메이션 테크니컬 디렉터 (12)
      • -------- 기초 학문 -------- (0)
      • 생명과학 이야기 (2)
        • 대학 강의 (2)
      • 화학 이야기 (0)
      • 컴퓨터과학 이야기 (0)
      • 통계학 이야기 (0)
      • 수학 이야기 (1)
        • 공학 수학 (1)
      • 영어 이야기 (1)
      • 심리학 이야기 (7)
        • 현대인과 정신건강 (7)
      • -------- 컴퓨터 언어 -------- (0)
      • Python (3)
        • 나도코딩의 파이썬 입문 (1)
        • 파이썬 관련 정보 (1)
      • SQL (0)
      • C 언어 (32)
        • 혼자 공부하는 C언어 요약 (1)
        • [책 정리] 혼자 공부하는 C언어 (31)
      • C++ (33)
        • 명품 C++ 프로그래밍 요약 (1)
        • [책 정리] 명품 C++ 프로그래밍 (27)
        • C++ STL (0)
        • 뇌를 자극하는 C++ STL (5)
      • -------- 생명과학 -------- (0)
      • 생화학 (5)
        • 대학 강의 (5)
      • 분자세포생물학 (3)
        • 대학 강의 (3)
      • 유전자치료공학 (2)
        • 대학 강의 (2)
      • 생명정보학 (5)
        • 대학 강의 (5)
      • 약리학 (2)
        • 대학 강의 (2)
      • -------- 컴퓨터과학 -------- (0)
      • 자료구조와 알고리즘 (8)
        • 자료구조와 알고리즘의 정의 (3)
        • [책 정리] C언어로 쉽게 풀어쓴 자료구조 요약 (1)
        • [인강] 자료구조와 알고리즘 (2)
        • 코딩 테스트 대비하기! (1)
      • 컴퓨터 회로 (0)
      • 컴퓨터 구조 (43)
        • 컴퓨터 구조와 운영체제 요약 (1)
        • ---------------------------------------- (0)
        • [전공 책 정리] 컴퓨터 구조 및 설계 (1)
        • Ch1. 컴퓨터 추상화 및 관련 기술 (8)
        • Ch2. 명령어 : 컴퓨터 언어 (11)
        • Ch3. 컴퓨터 연산 (8)
        • Ch4. 프로세서 (11)
        • Ch5. 메모리 계층구조 (3)
        • Ch6. 병렬 프로세서 : 클라이언트에서 클라우드까지 (0)
      • 시스템 프로그래밍 (15)
        • [책 정리] 시스템 프로그래밍 유닉스 & 리눅스 (0)
        • [인강] 리눅스 시스템 프로그래밍 (2)
        • 리눅스에서 코딩이란? (8)
        • 대학교 강의 정리 (5)
      • 운영체제 (0)
      • 컴퓨터 네트워크 (37)
        • 모두의 네트워크 요약 (1)
        • [책 정리] 모두의 네트워크 (10)
        • ---------------------------------------- (0)
        • [전공 책 정리] 컴퓨터 네트워킹 하향식 접근 8판 (1)
        • Ch1. 컴퓨터 네트워크와 인터넷 (7)
        • Ch2. 애플리케이션 계층 (7)
        • Ch3. 트랜스포트 계층 (8)
        • Ch4. 네트워크 계층 : 데이터 평면 (3)
        • Ch5. 네트워크 계층 : 제어 평면 (0)
        • Ch6. 링크 계층과 근거리 네트워크 (0)
        • Ch7. 무선 및 이동 네트워크 (0)
        • Ch8. 컴퓨터 네트워크 보안 (0)
      • 데이터베이스 (1)
      • -------- 데이터과학 -------- (0)
      • 데이터 사이언스 (8)
        • 인강 (8)
      • 데이터 분석 (2)
        • 인강 (2)
      • 머신러닝 (2)
        • 대학 수업 (2)
      • 인공지능 (11)
        • 대학교 강의 정리 (10)
        • 인공지능 관련 정보 (1)
      • -------- +a -------- (0)
      • Visual Studio Community (7)
        • 설치법 (1)
        • 단축키 (1)
        • 오류 (5)
      • Visual Studio Code (0)
      • 노션 (1)
      • 깃허브 (7)
        • 깃허브 사용법 (5)
        • 유니티, 언리얼 & 깃허브 (1)
        • 깃허브 주의사항 (1)
      • 챗GPT 활용법 (0)
      • 기타 feat. 프로그래밍 (7)
        • 프로그래머로 살아남기 (5)
        • 코딩 vs 프로그래밍 (1)
        • 애플 비전 프로 (1)
      • 메타버스 (5)
      • -------- 예술 -------- (0)
      • 음악 (1)
      • 미술 (0)
      • -------- XR -------- (0)
      • 유니티 이야기 (23)
        • 레트로의 유니티 게임 프로그래밍 에센스 요약 (4)
        • 유니티 관련 정보 (1)
        • 유니티 디버깅 (13)
        • 유니티 인강 (3)
        • 대학교 게임 프로그래밍 강의 (2)
      • 언리얼 이야기 (0)
        • 인생 언리얼 교과서 요약 (0)
      • 컴퓨터 그래픽스 (6)
        • OpenGL (6)
      • 가상현실 & 증강현실 (4)
        • 유니티 vr (4)
      • HCI 와 UI UX (7)
        • [책 정리] HCI 개론 (6)
      • -------- Design -------- (0)
      • 캐릭터 (1)
        • 모델링 (0)
        • 리깅 (1)
      • 포토샵 (3)
      • 3ds Max (7)
      • Maya (9)
        • 블로그 (1)
        • 인강 (6)
        • 대학교 (2)
      • Blender (14)
        • 책 (1)
        • 인강 (7)
        • 기타 (3)
        • 대학교 (3)
      • 아트 작업물들 (2)
      • 에셋 사이트 (1)
      • -------- 건강관리 -------- (0)
      • 건강관리 ft. 정현 (12)
        • 목 디스크 (2)
        • 눈 관리 (2)
        • 일상생활 습관 (6)
        • 일상생활 꿀팁 (2)
        • 사무직 꿀팁 (0)
      • 헬스의 정석 ft. 정현 (28)
        • 헬스와 건강 (8)
        • 헬스 구체화 정보 (6)
        • 헬스 유튜버 (1)
        • 헬스 서적 (1)
        • 도전 바디프로필! (11)
        • 헬스장 패션 (1)
      • -------- etc -------- (0)
      • 진로 관련 잡다한 글들 (34)
        • 진도율 (9)
        • 진로 관련 글들 (15)
        • 학교 강의 관련 글들 (10)
      • 인생 꿀 Tip (23)
        • 컴퓨터 초기 설정 (9)
        • 원격 데스크톱 (1)
        • 노트북 발열 (1)
        • 전자기기 (2)
        • 중고기기 팔기 (1)
        • 아이패드 필기 어플 (1)
        • 에어팟 (1)
        • 커피 (1)
        • 맥북 (1)
        • lg 그램 (1)
        • 검색엔진에서 내 티스토리 검색 (1)
        • hELLO 다크 모드 없애기 (1)
        • 인터넷 연결 문제 (1)
        • 키보드 문제 해결 (1)
      • 유튜브 (3)
      • 청춘 그리고 추억 (1)
      • 인생 계획표 (2)
        • 2024년 2학기 (1)
        • 2024년 여름방학 (0)
        • 2024년 1학기 (0)
        • 2023년 겨울방학 (1)
      • 다양한 글들 (98)
        • C++ STL (6)
        • Win32 API (24)
        • PushPush 게임 (13)
        • 컴퓨터구조 (1)
        • 자료구조와 알고리즘 (50)
        • 게임의 정의 (3)
        • 영상 회사 (1)
  • 블로그 메뉴

    • 홈
    • 태그
    • 방명록
  • 링크

  • 공지사항

    • Dream
    • 코딩을 시작한 이유
    • 나를 소개합니다!
    • 블로그 공부법
    • IT & 가치 있는 일들
  • 인기 글

  • 태그

    심리학
    배열
    명령어
    C++
    건국대
    생명공학
    리눅스 터미널
    인공지능
    컴퓨터구조
    C언어
    데이터과학
    알고리즘
    unity
    의생명공학과
    함수
    C++ STL
    포인터
    생물정보학
    연산자
    컴퓨터 네트워크
    스택
    AI
    첨단바이오공학부
    블렌더
    자료구조
    코드잇
    리눅스
    유니티
    의생명공학
    데이터사이언스
  • 최근 댓글

  • hELLO· Designed By정상우.v4.10.3
smile blog
2. 메모리 기술
상단으로

티스토리툴바