태그>arm(총 451개의 글)
'arm' 관련 최근글
-
- [Arm프로세서] 캐시의 검색 방법: 캐시 룩업(Ca..
-
Arm Linux Kernel Hacks by AustinKim|2022/05/19 08:16
캐시를 검색하는 방법을 설명하기 전에 재미있는 상상을 해봅시다. 4G 크기의 메인 메모리를 사용하는 32비트 시스템에서 4G를 모두 처리할 수 있는 캐시가 있다고 가정합시다. 메모리 주소 공간은 범위가 0x~0xffff..
- [Arm프로세서] 캐시의 검색 방법: 캐시 룩업(Ca..
-
- [Arm프로세서] 캐시 알고리즘: 알고리즘 지역성(algorithm locality)
-
Arm Linux Kernel Hacks by AustinKim|2022/05/17 12:18
프로그램은 함수의 호출과 자료 구조로 구성돼 있습니다. 코드를 유심히 분석하면 자주 사용하는 자료 구조나 알고리즘이 어느 정도 정해져 있습니다. 예를 들어 링크드 리스트나 스택과 같은 데이터 구조나 알고리즘을 사용해 데이터를 관리하는 패턴을 볼 수 있습니다. 그런데 데이..
- [Arm프로세서] 캐시 알고리즘: 알고리즘 지역성(algorithm locality)
-
- [Arm프로세서] 캐시 알고리즘: 공간 지역성(Spatial Locality)
-
Arm Linux Kernel Hacks by AustinKim|2022/05/16 06:36
자주 가는 카페에 갔다면 그 카페만 갈까요? 항상 그렇지는 않습니다. 자주 가는 카페 옆에 있는 다른 카페에 갈 가능성도 있습니다. 이렇듯 프로그램이 어떤 데이터를 사용하면 그 데이터와 인접한 데이터에 접근할 확률이 높습니다. 이런 패턴을 공간 지역성(Spatial Locality)..
- [Arm프로세서] 캐시 알고리즘: 공간 지역성(Spatial Locality)
-
- [Arm프로세서] 캐시 알고리즘: 시간적 지역성(temporal locality)
-
Arm Linux Kernel Hacks by AustinKim|2022/05/13 09:47
캐시는 CPU 근처에 있는 용량이 작지만 동작 속도는 빠른 임시 저장 공간입니다. CPU는 접근 속도가 오래 걸리는 메인 메모리보다 캐시에 먼저 접근해 찾으려는 데이터가 있는지 체크합니다. 만약 캐시에 데이터가 있으면 캐시에 존재하는 데이터를 가져옵니다. CPU가 접근하려는..
- [Arm프로세서] 캐시 알고리즘: 시간적 지역성(temporal locality)
-
- [Arm프로세서] L1 캐시와 L2 캐시란
-
Arm Linux Kernel Hacks by AustinKim|2022/05/12 13:39
이전 포스트에서는 한 개 캐시로 구성된 프로세서를 기준으로 캐시의 기본 개념을 설명했습니다. 대부분 시스템은 멀티 레벨로 캐시가 구성돼 있습니다. 다음 그림을 보면서 멀티 레벨 캐시에 대해 알아봅시다. ..
- [Arm프로세서] L1 캐시와 L2 캐시란
-
- [Arm프로세서] 메모리 아키텍처에서 캐시(Cac..
-
Arm Linux Kernel Hacks by AustinKim|2022/05/12 13:38
컴퓨터가 발명된 후 초장기 시점에 컴퓨터는 어떤 모습일까요? 컴퓨터의 크기는 방 하나 정도였습니다. 그 당시에 CPU와 메인 메모리만 존재했습니다. CPU가 어떤 명령어를 실행하거나 데이터를 가져오려면 메..
- [Arm프로세서] 메모리 아키텍처에서 캐시(Cac..
-
- [Arm프로세서] 캐시(Cache)란
-
Arm Linux Kernel Hacks by AustinKim|2022/05/09 16:40
캐시는 CPU 코어가 자주 사용하는 데이터를 저장하는 임시 저장 공간으로 시스템 성능에 지대한 영향을 끼칩니다. 먼저 캐시가 생겨난 배경을 설명하고 캐시를 구성하는 주요 기능을 설명합니다. 캐시란 CPU 캐시의 동작 원리를 다루기 앞서 일반적으로 캐시가 무엇인지 알아 봅시다..
- [Arm프로세서] 캐시(Cache)란
-
- [Arm프로세서] Armv8: 시스템 레지스터
-
Arm Linux Kernel Hacks by AustinKim|2022/05/03 05:19
Armv8 아키텍처는 범용 레지스터 뿐만 아니라 시스템의 세부 속성을 설정할 수 있는 시스템 레지스터를 정의합니다. 이 중에 자주 사용되는 시스템 레지스터는 잘 익혀둘 필요가 있는데요. 이어서 Arm 스팩 문서..
- [Arm프로세서] Armv8: 시스템 레지스터
-
- [Arm프로세서] Armv8: SPSR_ELx - SPSR(Saved Program Status..
-
Arm Linux Kernel Hacks by AustinKim|2022/05/02 09:19
SPSR_ELx SPSR 레지스터는 Saved Program Status Register의 약자로 PSTATE 정보를 백업하는 용도로 사용됩니다. 따라서 SPSR 레지스터의 비트 맵은 PSTATE와 같습니다. 그렇다면 PSTATE는 SPSR 레지스터로 언제 백업될까요? "바로 익셉션이 유발될 ..
- [Arm프로세서] Armv8: SPSR_ELx - SPSR(Saved Program Status..
-
- [Arm프로세서] Armv8: 스페셜 레지스터
-
Arm Linux Kernel Hacks by AustinKim|2022/04/28 09:36
그런데 Armv8에서는 익셉션 레벨 별로 사용되는 레지스터가 있는데 이를 스페셜 레지스터라고 합니다. 그 목록은 다음 그림과 같습니다. 그림 2.4 Armv8(Aarch64) 아키텍처의 스페셜 레지스터 목록 Armv7 에서..
- [Arm프로세서] Armv8: 스페셜 레지스터
-
- [Arm프로세서] Armv8: 범용(General Purpos..
-
Arm Linux Kernel Hacks by AustinKim|2022/04/26 06:05
Armv8 아키텍처의 레지스터 Armv7에서 Armv8로 넘어 오면서 Armv7의 구조가 많이 변경됐습니다. CPU 아키텍처의 최신 기법을 Armv8 아키텍처에 적용하면서 아키텍처의 구조를 많이 개선했으므로 Armv7 대비 20..
- [Arm프로세서] Armv8: 범용(General Purpos..
-
- [Arm프로세서] Armv7: SPSR(Saved Program Status Register) ..
-
Arm Linux Kernel Hacks by AustinKim|2022/04/21 05:34
SPSR는 Saved Program Status Registers의 약자로 CPSR을 백업하는 용도로 사용되는 레지스터입니다. 이어서 Arm 스팩 문서를 보면서 SPSR을 배워봅시다. The Saved Program Status Registers (SPSRs)The purpose of an SPSR is to record the pre-e..
- [Arm프로세서] Armv7: SPSR(Saved Program Status Register) ..
-
- [Arm프로세서] Armv7: CPSR(Current Program..
-
Arm Linux Kernel Hacks by AustinKim|2022/04/21 05:33
Armv7에서는 프로세서의 상태 정보를 저장하는 CPSR, SPSR 레지스터를 제공합니다. 먼저 CPSR 레지스터를 설명하고 CPSR 레지스터를 백업하는 용도로 설계된 SPSR 레지스터에 대해서 알아봅시다. CPS..
- [Arm프로세서] Armv7: CPSR(Current Program..
-
- [Arm프로세서] Armv7: 범용 레지스터에서 뱅크드..
-
Arm Linux Kernel Hacks by AustinKim|2022/04/19 06:45
그림 2.1의 아랫 부분을 보면 r13_svc와 r14_svc 라는 레지스터가 보입니다. 오른쪽에는 r13_irq와 r14_irq 레지스터가 보입니다. 이런 종류의 레지스터의 정체는 무엇일까요? Arm 동작 모드에 뱅크드된 레지스터라..
- [Arm프로세서] Armv7: 범용 레지스터에서 뱅크드..
-
- [Arm프로세서] Armv7: 범용(General Purpos..
-
Arm Linux Kernel Hacks by AustinKim|2022/04/14 10:40
Armv7 아키텍처의 레지스터 CPU 아키텍처를 배울 때 가장 먼저 어셈블리 명령어와 레지스터의 용법을 파악합니다. 어셈블리 명령어는 레지스터로 구성돼 있어 어셈블리 명령어를 익히려면 레지스터의 용법을 ..
- [Arm프로세서] Armv7: 범용(General Purpos..