KVM & QEMU Notları

Merhaba

Bu sayfa Qemu ve KVM üzerine çalışırken alınmış bazı notlardır.

QEMU Nedir

QEMU (Quick Emulator) ihtiyaç duyulan donanımları hızlı bir şekilde taklit edebilecek bir emülatördür. QEMU farklı CPU çeşitlerini (x86, PowerPC, ARM vb.) farklı mimarilerde (x86, PowerPC, ARM, Sparc, MIPS vb.) kullanmaya izin vermektedir. Aynı zamanda donanım ile sanallaştırmayı da desteklemektedir. Kısaca QEMU'nun temel özelliklerini şu şekilde sıralıyabiliriz.

  • Full Emülatör
  • Dynamic Translation
  • KVM ile birlikte kullanılarak sanallaştırma yapabilmektedir.

QEMU Tarihçesi

QEMU 2003 yılında Fabrice Bellard tarafından duyurulmuş ve GPLv2 ile lisanslanmıştır. Aynı zamanda programın bazı parçaları da BSD lisansı ile lisanslanmıştır. Şu an bir çok farklı bölüme ayrılan QEMU projesi özellikle RedHat ekibi tarafından güncel tutulmaktadır. Aynı zamanda büyük bir topluluk desteği ile birlikte geliştirilmektedir.

  • Guest CPU cores (TCG)
  • FPU emulation
  • ARM TCG CPUs
  • AVR TCG CPUs
  • MIPS TCG CPUs
  • OpenRISC TCG CPUs
  • PowerPC TCG CPUs
  • RISC-V TCG CPUs
  • .......

Tüm listeye maintainer referanslarından ulaşılabilir.

Qemu Kaynak Kodunun İncelenmesi

Bu yazıda QEMU’nun kaynak kodu temel seviyede incelenecektir. Bu bağlamda ilk olarak, QEMU’nun başlangıcında çalıştırılan main fonksiyonu incelenecektir. Main fonksiyonu QEMU/softmmu/main.c klasörü altında bulunur. main fonksiyonu içerisinde sadece 3 fonkisyon çağrılır.

  • qemu_init()
  • qemu_main_loop()
  • qemu_cleanup()
int main(int argc, char **argv, char **envp)
{
    qemu_init(argc, argv, envp);
    qemu_main_loop();
    qemu_cleanup();
    return 0;
}
Fonksiyon Açıklama
qemu_init_subsystems() - cpu_list, cpu_loop, crypto init ediliyor
qemu_validate_options() - QEMU'ya verilen ayarlar burada kontrol edilmekte ve oluşabilicek yanlışların önüne geçilmektedir
qemu_process_early_options() - ? + log dosyaları hazırlanıyor
qemu_init_main_loop() - QEMU, main_loop'un başlaması için ön hazırlıklıkları yapmaktadır.
cpu_timer_init() - QEMU, CPU için çalışacak gerçek zamanlı saatin frekans ve geri kalan ayarlarını yapmaktadır
configure_rtc() - QEMU, RTC ayarları yapılıyor (UTC)
qemu_create_machine() - QEMU, simüle edilecek cihazı oluşturmaktadır
qemu_disable_default_devices() - Sanal cihaza bağlı seri bağlantılar (SD kart, CD-ROM) ve grafik hizmetleri durdurulur.
qemu_create_default_devices() - Serial ve grafik cihazlarını oluşturulur.
qemu_create_early_backends() - ???
configure_accelerators() - Kullanılacak hızlandırıcı seçilmektedir bunlar kvm veya tcg olabilmektedir.
migration_object_init() - ???
qemu_create_late_backends() - ???
accel_init_interfaces() - CPU arayüzleri başlatılır.
qemu_init_displays() - Lokal ve uzak displayler başlatılır.
os_setup_post()