Inflearn brand logo image
Inflearn brand logo image
Inflearn brand logo image
Hardware

/

Embedded IoT

Armアーキテクチャ:メモリモデルとバリア【著者直講第3部-3】

システムソフトウェアの基本中の基本、最新のArmアーキテクチャ(Armv8-A, Armv7-A)の核となる「メモリモデルとバリア」を『システムソフトウェア開発のためのArmアーキテクチャの構造と原理』の著者がしっかり解説します!

  • austinkim
저자 직강
이론 중심
동시성문제
임베디드리눅스
ARM Architecture
memory-mapped-io
barrier
armv8
cortex-a

こんなことが学べます

  • Armアーキテクチャ(Armv8-A)のメモリモデルとバリアの基本動作原理を把握できます。

  • Armアーキテクチャのメモリモデルとバリア関連機能が実際のプロジェクトでどのように活用されるか分かります。

  • 大まかにメモリモデルとバリアに関連する実行フローと構造を把握できます。

  • 面接でメモリモデルとバリアに関する質問によく答えられます。

<お知らせ>

1. 300人突破30%割引クーポン発行

受講生300人突破(1、2部)を記念して30%割引クーポンを発行します。ありがとうございます。先着順200名です。

2. ロードマップ案内🎯

今回の講義はロードマップ「システムソフトウェア開発者向けのArm - advanced course に含まれる講義。


体系的にArmアーキテクチャ(Armv8-A、Armv7-A)を学びたい方はロードマップ(全体講義の30%割引)を活用してください。ちなみに、Armアーキテクチャロードマップ(作者直江全体)はBasic CourseAdvanced Course 2つで構成されています。


最新のシステムソフトウェアから
最も重要な Arm アーキテクチャ

スマートフォンはもちろん、AI用SoCシステム半導体、電気自動車Automotive(自動運転、インフォテインメント)、クラウドサーバーやMacBookで使用されるArmプロセッサは、すべてArmv8-Aベースの64ビットCortex-Aプロセッサ(Cortex-A53、Cortex-A57、Cortex-A72など)です。現在、システムソフトウェア業界で最も多くの基盤知識が要求される領域がArmv8-Aアーキテクチャと見なされています。

高度なシステムSW開発者になる第一歩!
メモリ管理方法を理解する🙋‍♂

しかし、高度なシステムソフトウェア開発者になるためには、Armアーキテクチャを構成する主な機能の間にメモリを管理する方法をよく理解する必要があります。メモリを管理する方法の鍵は、「仮想メモリシステム」、「キャッシュ動作原理」、および「メモリモデルとバリア」です。


「メモリモデルとバリア」をなぜ学ぶのですか?

1⃣まず、メモリモデルとバリアをよく知ることで、デバイスドライバをうまく開発できます。ほとんどの場合、デバイスドライバはメモリマップドI / O方式でペリフェラルデバイスを制御します。

2⃣第二に、メモリマップドI/Oの基盤であるデバイスメモリ(メモリモデルの一つ)をよく理解しなければ、システム半導体を構成するハードウェアを効率的に制御するプログラミングがうまくできます。システム半導体(ペプリス)では、ほとんどがメモリマップドI / O方式を介してシステム半導体を構成する独立したモジュール(IP)を設計するためです。

3⃣第三に、メモリモデルとバリアをよく知ることで、Armプロセッサ内部の動作原理を細かく把握できます。特に、マルチコアシステムでバリアを使用して並行性の問題を解決する状況に非常に直面しています。

4⃣第四に、システムソフトウェア開発関連の技術面接をよく見るために「メモリモデルとバリア」はよく知る必要があります。キャリア開発者のインタビューでよく寄せられる質問の1つが、メモリー・リオーダリング、メモリー・マップドI/Oに関する内容です。


12年目システムエンジニアのノウハウを込めた著者直講!

「システムソフトウェア開発のためのArmアーキテクチャの構造と原理」の本(17章)では、「メモリモデルとバリア」を詳細に取り上げています。著者の講義を通じて、システムソフトウェア開発者としてさらに成長してください。

このようなことを学びます。

Armアーキテクチャで定義されているメモリモデルの種類とノーマルメモリを紹介します。

Arm仕様文書を詳細に分析しながら、メモリモデルの種類(ノーマルメモリとデバイスメモリ)を紹介します。

メモリマップドI/Oインタフェースであるデバイスメモリを詳細に説明し、BCM2711(ラズベリーパイ使用)のメモリマップドI/Oをレビューします。

デバッグ(Crash-Utility)を介してメモリマップドI / Oインターフェイスを分析します。

バリアを紹介し、バリアの例を詳細に説明する。

マルチコアシステムにおけるバリアの適用範囲とデータの一貫性について説明します。

バリアが実際のLinuxカーネルとXENハイパーバイザーでどのように利用されるかを詳しく説明します。

本の執筆/講義の経歴に基づいて
誰よりも深く詳細に!

国内システムソフトウェア分野で専務後無限! 「Armアーキテクチャ(Armv8-A、Armv7-A)」と「Linuxカーネル」の本を書いた著者です。

  • 「システムソフトウェア開発のためのArmアーキテクチャの構造と原理」( 2024年、大韓民国学術院優秀図書上著者

  • 「デバッグを通じて学ぶLinuxカーネルの構造と原理」2021年、大韓民国学術院優秀図書上)著者

  • 「プログラマスデブコース: Linuxシステムとカーネルの専門家」メインインストラクター

  • 2022年6月、韓国コンピュータ総合学術大会(KCC2022) - チュートリアル発表 [ftraceを利用してLinuxカーネルを征服する]

  • LG電子「Linuxカーネル」および「Armv8アーキテクチャ」社内講師(国内および海外開発者を含む) - (2020年~2024)


国内で誰よりもArmアーキテクチャ(Armv8-A、Armv7-A)を成し遂げる主な機能をよく説明できる教育者だと自信を持ってお話しできます。

学習者が残した鮮やかな受講評

<システムソフトウェア開発のためのArmアーキテクチャの構造と原理 - 1/2部作者直講>


受講前の注意

選手の知識と注意事項📢

  • 「メモリーモデルとバリア」講義は、選手の知識がなくても無難に従うことができる講義です。

  • アセンブリ命令とレジスタの基本概念を知っておく必要があります。

  • マルチコアシステムとシステム構造について理解しておくとよいでしょう。


こんな方に
おすすめです

学習対象は
誰でしょう?

  • システム半導体(ファブレス)、電気自動車分野(自動運転、インフォテインメント)を含むシステムソフトウェア分野で力量を培いたいジュニア開発者

  • システム半導体(ファブレス)、電気自動車分野でシステムソフトウェア開発をしたい就活生

  • Armアーキテクチャの機能を活用して実務でどのようにデバッグしているか知りたいシステムソフトウェア開発者(システム半導体、電気自動車)

前提知識、
必要でしょうか?

  • コンピュータ構造

  • OS

こんにちは
です。

5,439

受講生

148

受講レビュー

84

回答

4.9

講座評価

21

講座

글로벌 저자 & 리눅스 시스템 소프트웨어 개발자 (Arm, RISC-V 아키텍처)

국내 시스템 소프트웨어 분야에서 전무후무한! 'Arm 아키텍처(Armv8-A, Armv7-A)'와 '리눅스 커널' 책을 쓴 저자(2권의 책 모두 대한민국 학술원 우수도서에 선정)이며, 국내 최초로 해외 출판사(Packt)를 통해 "Reverse Engineering Armv8-A Systems" 책(영어)을 집필한 글로벌 저자입니다. 무엇보다 최신 시스템 소프트웨어 트렌드(전기자동차, 시스템 반도체- 시스템 소프트웨어)를 가장 잘 알고 있는 현업 개발자입니다. 또한 시스템 소프트웨어 분야에서 가장 지식 전파 활동을 활발하게 하는 교육자입니다. 

  • 'Reverse Engineering Armv8-A Systems: A practical guide to Kernel, Firmware, and TrustZone analysis' 책(영어) 저자, (Packt 출판사)

  • '시스템 소프트웨어 개발을 위한 Arm 아키텍처의 구조와 원리'(2024년, 대한민국 학술원 우수도서상) 저자

  • '디버깅을 통해 배우는 리눅스 커널의 구조와 원리' (2021년, 대한민국 학술원 우수도서상) 저자

  • '프로그래머스 데브 코스: 리눅스 시스템 및 커널 전문가' 메인 강사

  • 2022년 6월, 한국컴퓨터종합학술대회 (KCC2022) - 튜토리얼 발표 [ftrace를 이용해 리눅스 커널 정복하기]

  • LG전자 '리눅스 커널' 및 'Armv8 아키텍처' 사내 강사(국내 및 해외 개발자 포함) - (2020년~현재)

국내에서 어느 누구보다 리눅스 커널과 Arm 아키텍처(Armv8-A, Armv7-A)를 잘 설명할 수 있는 교육자라고 자신있게 말씀드릴 수 있습니다.

강의문의 : austindh.kim@gmail.com

주요 로드맵 🎯

'시스템 소프트웨어 개발자를 위한 Arm - basic course'

'시스템 소프트웨어 개발자를 위한 Arm - advanced course'

시스템 소프트웨어 개발자를 위한 Linux kernel - basic course

カリキュラム

全体

27件 ∙ (3時間 50分)

講座掲載日: 
最終更新日: 

受講レビュー

全体

6件

4.8

6件の受講レビュー

  • grapesgun0624님의 프로필 이미지
    grapesgun0624

    受講レビュー 4

    平均評価 5.0

    5

    100% 受講後に作成

    Sẽ thực sự tốt nếu bạn giải thích nó bằng mã hạt nhân trong đó rào cản được sử dụng trực tiếp làm ví dụ.

    • austinkim
      知識共有者

      Cảm ơn bạn đã đánh giá tốt.

  • woo12346560311님의 프로필 이미지
    woo12346560311

    受講レビュー 5

    平均評価 5.0

    5

    33% 受講後に作成

    • kfcwee9463님의 프로필 이미지
      kfcwee9463

      受講レビュー 5

      平均評価 5.0

      5

      100% 受講後に作成

      • jinhoo05096242님의 프로필 이미지
        jinhoo05096242

        受講レビュー 3

        平均評価 5.0

        5

        63% 受講後に作成

        • aceoftop1975님의 프로필 이미지
          aceoftop1975

          受講レビュー 94

          平均評価 5.0

          5

          100% 受講後に作成

          29/07/2024/Thứ Hai 15:30 Tôi rất thích bài giảng. Mỗi lần tôi nghe giảng, "Ah~ Ah~" Tôi nghĩ tôi đã làm điều đó nhiều lần. Tôi đã học được điều gì đó mà tôi chưa biết, và tôi đã cảm động mà không hề nhận ra. Thời gian khóa học: không giới hạn, học phí thấp, và mặc dù hiện tại tôi đang nghe vội nhưng tôi nghĩ mình sẽ bình tĩnh nghe lại vài lần trong tương lai. Cảm ơn bạn đã tạo ra một khóa học tuyệt vời.

          ¥4,052

          austinkimの他の講座

          知識共有者の他の講座を見てみましょう!