Guillermo Austin Kim

Sources

Posts

998 posts

[Arm프로세서] Armv8: 스페셜 레지스터

Guillermo Austin Kim|2022년 4월 28일

그런데 Armv8에서는 익셉션 레벨 별로 사용되는 레지스터가 있는데 이를 스페셜 레지스터라고 합니다. 그 목록은 다음 그림과 같습니다. 그림 2.4 Armv8(Aarch64) 아키텍처의 스페셜 레지스터 목록 Armv7 에서는 각 동작 모드 별로 r13_ /r14_ 와 같이 뱅크드된 레지스터가 있듯이, Armv8은 익셉션 레벨 별로 사용되는 레지스터가 있습니다. 이를 스페셜 레지스터라고 합니다. SP_ELx 레지스터 이 중에서 먼저 SP_EL0을 알아봅시다. SP_EL0은 EL0(익셉션 레벨 0)에서 실행되는 프로세스의 스택 Top 주소를 가리킵니다. 그렇다면 SP_EL1은 어느 익셉션 레벨에서 사용되는 레지스터일까요? SP_EL1은 EL1(익셉션 레벨 1)

[Arm프로세서] Armv8: 범용(General Purpose) 레지스터란

Guillermo Austin Kim|2022년 4월 25일

Armv8 아키텍처의 레지스터 Armv7에서 Armv8로 넘어 오면서 Armv7의 구조가 많이 변경됐습니다. CPU 아키텍처의 최신 기법을 Armv8 아키텍처에 적용하면서 아키텍처의 구조를 많이 개선했으므로 Armv7 대비 20% 이상의 성능 개선이 있었다고 합니다. 그렇다면 Armv8 아키텍처에서 가장 많이 바뀐 기능이 무엇일까요? 레지스터와 기존의 Arm 동작 모드를 개선한 익셉션 레벨이라고 할 수 있습니다. 앞으로 Armv8 아키텍처에서 정의된 다음과 같은 레지스터를 설명합니다. * 범용 레지스터 * 스페셜 레지스터 * 시스템 레지스터 먼저 범용 레지스터를 알아봅시다. Armv8 아키텍처의 범용 레지스터 Armv8 아키텍처에서 다양한 레지스터를 정의하는데 먼저 범용 레지스터가 무

[Arm프로세서] Armv7: 범용 레지스터에서 뱅크드 레지스터란

Guillermo Austin Kim|2022년 4월 18일

그림 2.1의 아랫 부분을 보면 r13_svc와 r14_svc 라는 레지스터가 보입니다. 오른쪽에는 r13_irq와 r14_irq 레지스터가 보입니다. 이런 종류의 레지스터의 정체는 무엇일까요? Arm 동작 모드에 뱅크드된 레지스터라고 합니다. 뱅크드 레지스터를 주로 기계적인 관점으로 설명해서 소프트웨어 개발자가 이해하기 어렵습니다. 이해를 돕기 위해 다음과 같은 명령어를 봅시다. sub, sp, sp, #4 sp 레지스터인 r13 레지스터의 값을 4만큼 빼는 명령어입니다. 여기서 sub은 뺄셈 연산 명령어입니다. 위와 같은 명령어를 실행하면 그림 2.1기준으로 어느 레지스터의 값이 업데이트될까요? r13의 종류는 r13_svc, r13_irq, r13_abt 이니, 이 중 하나입니다. ‘sub

[Arm프로세서] Armv7: 범용(General Purpose) 레지스터란

Guillermo Austin Kim|2022년 4월 14일

Armv7 아키텍처의 레지스터 CPU 아키텍처를 배울 때 가장 먼저 어셈블리 명령어와 레지스터의 용법을 파악합니다. 어셈블리 명령어는 레지스터로 구성돼 있어 어셈블리 명령어를 익히려면 레지스터의 용법을 알아야 합니다. 그렇다면 Arm 아키텍처는 같은 레지스터를 사용할까요? 그렇지 않습니다. Armv7와 Armv8 아키텍처 별로 각각 레지스터를 정의합니다. 이번 포스트에서 Armv7 아키텍처에서 정의된 레지스터를 다룹니다. 먼저 범용 레지스터를 설명하겠습니다. 범용 레지스터 레지스터란 무엇일까요? 레지스터는 메모리 계층 구조 관점으로 설명할 수 있습니다. Arm 코어가 사용하는 데이터를 저장하는 임시 저장 공간을 레지스터라고 합니다. 그런데 소프트웨어 관점으로는 Armv7 아키텍처에서 레지스터는 범용

[리눅스커널] Linux kernel v5.17 릴리즈(Release)

Guillermo Austin Kim|2022년 4월 12일

2022년 3월 20일에 Linux v5.17 릴리즈됐습니다. 주요 피쳐는 아래 링크에서 확인할 수 있습니다. • • • 아래와 같이 'kernelnewbies.org/Linux_5.17'에 있는 Prominent features는 한 번 리뷰가 필요하군요. 1 Support recursive id-mapped mounts2 BPF CO-RE support and other improvements3 New P-State driver for modern AMD cpus4 Random number generator improvements5 Rewrite of the networking caching backend for networking file systems6 New Real-Time Li