기본 콘텐츠로 건너뛰기

Linux kernel v3.9 ARM에서 KVM 지원

Overview

  • 2013년 4월 29일 Linux kernel 3.9 버전이 릴리즈 됨 - change log 참고
  • ARM 프로세서에서 KVM 가상화 지원 기능이 추가 됨 
  • 이 글에서는 KVM과 관련된 CPU 가상화 지원에 대한 정보들을 간추려 보고자 한다

KVM 이란

  • KVM (Kernel-based Virtual Machine)은 VMware와 같은 가상화를 Linux 커널 모듈에서 제공
  • Intel VT나 AMD-V와 같은 가상화 H/W 지원하는 x86 CPU에서만 동작했으나
  • 3.9 커널 부터는 ARM CPU에서도 동작 가능
  • 그렇다면 ARM CPU도 Intel VT와 같은 가상화 지원을 제공한다는 의미?

Intel VT란

  • Intel VT (Virtualization Technology)는 가상화를 지원하기 위한 VMX (Virtual Machine Extensions)라는 명령어를 제공한다.
    • VMXON - enter VMX operation
    • VMXOFF - leave VMX operation
    • VMREAD - read field from Virtual Machine control structure
    • VMWRITE - write field to Virtual Machine control structure
    • VMPTRLD - load pointer from Virtual Machine control structure
    • VMPTRST - store pointer to Virtual Machine control structure
    • VMLAUNCH - Launch Virtual Machine
    • VMRESUME - Resume Virtual Machine
    • VMCALL - Call to VM Monitor
  • 이 명령어를 이용하여 VMM (Virtual Machine Monitor) S/W는 더 빠른 성능의 가상화 솔루션을 구현할 수 있다. 
  • Intel CPU는 가상화 지원을 위해 EPT (Extended Page Table)도 제공한다.  Extending KVM with new Intel Virtualization technology 자료 참고.
  • 단, 모든 Intel CPU가 VT 및 EPT를 지원하는 것은 아니다. 지원 모델에 대해서는 다음 인텔 페이지를 참고.

ARM processor에서 virtualization 지원


KVM이 ARM 프로세서를 지원하기 위해서는 Intel VT와 비슷한 H/W 기능이 있어야 할 듯. 이에 대해 살펴보자.
  • ARM에서 KVM 지원에 대한 kernel 소스 commit을 보면 현재 지원하는 CPU는 Coretex-A15 뿐이다.
  • ARM Coretex-A15 CPU는 Virtualization Extension과 LPAE (Large Page Addressing Extension)을 지원한다.
  • 자세한 내용은 ARM 프리젠테이션 문서를 참고.
즉, ARM CPU에서도 Intel VT와 유사한 CPU에서의 가상화 지원이 있고 Linux kernel 3.9 버전의 KVM은 아마도 이를 이용하여 ARM에서의 가상화를 지원하는 것으로 보인다. 소스 코드 레벨로 살펴본 것은 아니므로 관련 자료에 근거한 추측이다.

참고

댓글

이 블로그의 인기 게시물

Wireless: HotSpot 2.0 이란?

스마트폰 사용자가 HotSpot 2.0을 지원하는 Wi-Fi 망을 사용하는 경우라면 기존 Wi-Fi 망과 달리 이동통신 망에서 Wi-Fi 망으로의 네트워크 연결 전환이 자연스럽게 이루어진다. 예를 들면, 3G 네트워크를 이용하여 영화를 보고 있다가 HotSpot 2.0 네트워크에 연결이 가능하게 되면 영화 시청 중단 없이 Wi-Fi 망으로 자연스럽게 네트워크 연결이 이동하여 3G 망의 부하도 줄이고 사용자의 네트워크 비용도 절약할 수 있다. 시스코에서 제공한 White Paper 를 참고.

Apple M1 Mac Mini에서 이더리움 (Ethereum) 채굴하기

 돈을 벌 목적은 아니고 이더리움 기술에 대한 호기심에 직접 채굴(마이닝)에 나서 보기로 했다. 머신은 Apple M1 Mac Mini. 스팩을 살펴보니 8 Core GPU에 16GB 메모리를 공유하고 있어 가능은 해보인다. 큰 흐름은 다음과 같다. 채굴한 이더리움을 저장할 지갑을 만든다 만든 지갑의 정보를 잘 보관해둔다 (Secret Recovery Phrase, 지갑의 주소 값) Apple M1용 채굴 프로그램 설치 내 지갑 정보를 이용해서 채굴 프로그램 실행 일단, 채굴한 이더리움을 저장할 지갑(wallet)을 만들어야 한다.  크롬 브라우저 익스텐션 설치로 비교적 간단하게 지갑을 만들 수 있는  https://metamask.io/ 를 이용하기로 했다. 크롬 익스텐션을 설치 후 기존에 만든 지갑이 없으므로 "Create a Wallet"을 선택한다. 패스워드 입력하고 등등의 절차를 거치면 아래와 같은 Secret Recovery Phrase가 나온다. 이 값을 잘 보관해두기 바란다. 나중에 지갑을 복구할 때 필요한 값이다. 이 값이 유출되면 지갑에 모아둔 이더리움을 다 털릴 수 있으므로 안전한 곳에 보관한다. Confirm Your Secret Phrase에서 확인 과정을 거친다. 직접 입력하는 것이 아니라 단어 별 버튼을 일일이 클릭해서 확인해주어야 한다. (좀 번거롭지만 그만큼 Secret Recovery Phrase가 중요함을 인지시키기 위한 과정이다.) 이제 지갑은 준비 완료. 생성된 Account 화면에서 지갑의 주소갑을 얻을 수 있다.  Apple M1용 채굴 프로그램을 설치해보자. Ethminer M1 Github 프로젝트 에서 미리 컴파일된 바이너리를 다운로드 받는다. (Assets를 펼치고 ethminer-m1을 클릭해서 다운 받으면 된다) 원하는 폴더에 파일을 옮겨 놓고 Terminal에서 chmod +x로 실행가능하게 만든다. % mv ~/Downloads/ethminer-m1 .             %   % c

Java: Java for Game? Java가 Game 개발에 어울릴까?

Java가 기업용 서버 소프트웨어 개발에 활발하게 쓰이는 것과 달리 일반 응용프로그램 분야에서는 별로 대접을 받지 못하는 현실을 개선하려면 어떤 분야부터 손보면 좋을까? 로딩타임, 성능, 사용자 인터페이스 등 Java를 이용한 클라이언트 프로그램을 개발하지 않는 이유들은 개발자 별로 서로 다를 것이다. 하지만, 이런 단점에도 불구하고 점점 복잡해지는 소프트웨어를 더 쉽게 다양한 환경에서 동작하도록 만들기 위해서는 Java만큼 이미 성숙한 해결책도 없지 않은가? 클라이언트 개발을 활성화하기 위해 Java를 게임 개발에 활용할 수 있도록 지원하면 어떨까? 역시, 사용자가 직접 쓰는 응용프로그램 중에는 게임이 가장 시장이 큰 분야이니 말이다. 그렇다면, 현재 게임 개발에 Java가 어느 정도 사용되고 있고 미래에 더 활성화 될 가능성은 있을 것인가? 이런 의문점을 가지고 "Java + Game"에 대해 조사해보기로 했다. 1. Java로 개발한 게임들 우선, Java로 개발한 게임들에 대해 살펴보자. Oracle의  Java in Action 웹페이지 를 보면 Java를 이용한 3D MMORPG RuneScape 에 대한 설명이 있다. 가입자가 1억 3000만명이 넘는다고 하다. 실제 게임을 설치해서 실행해보니 WOW같은 화려한 그래픽에는 못미치치만 잘만든 Role Playing 게임이다 Puppy Games 에서 개발한  Revenge of the Titans 게임도 눈여겨 볼 만하다. 이 회사는 작고 손쉽게 즐길 수 있는 게임을 개발하는데 모든 게임을 Java로 만든다. Revenge of the Titans는 Starcraft와 같은 전략 게임으로 너무 머리쓰지 않고 즐길 수 있는 게임이며 그래픽도 신선하다. 개발이 진행 중인 것으로 보이는 Urban Galaxy 라는 게임도 재미있을 것 같다. SF 영화를 보면 자주 등장하는 미래의 빌딩 숲을 날아다니는 자동차로 전투도 치르고 무역도 하며 캐릭터를 키우는 게임으로