Thumbnail
하드웨어 반도체

Verilog FPGA Program 4 (MCU Porting, Arty A7-35T) 대시보드

50명이 수강하고 있어요.
132,000원

월 26,400원

5개월 할부 시
지식공유자: alex
총 151개 수업
수강기한: 
무제한
수료증: 발급
난이도: 
입문
-
초급
-
중급이상
지식공유자 답변이 제공되는 강의입니다
폴더에 추가 공유

중급자를 위해 준비한
[임베디드 · IoT, 반도체] 강의입니다.

FPGA안에 무료 MCU IP를 Porting 해서 사용하는 것을 알려드립니다.

✍️
이런 걸
배워요!
FPGA에 MCU 포팅해서 사용하기
Bootloader 구조
FPGA 내 MCU 메모리 구성하기

FPGA MCU 포팅,
내 기술로 만들어서 레벨업 해요! ✨

FPGA 개발자 성장의 기회,
MCU 포팅 🔦

저는 약 20년 정도 FPGA 관련된 일들을 해왔고, 대부분의 프로젝트에서 FPGA 내에 MCU를 포팅해서 진행했습니다. MCU를 FPGA 내에 포팅해서 사용하면 많은 장점이 있습니다. 외부에 별도로 MCU를 사용할 필요도 없고, MCU 파트와 LOGIC 파트로 나누어서 진행할 수도 있습니다.

저는 대부분의 FPGA(Spartan, Artix, Kintex, Virtex)에서 MCU를 포팅해서 사용했습니다. 기본적인 구조만 알면 대부분의 FPGA에 적용할 수 있습니다. 본 강의는 이러한 과정을 상세하게 설명하고 있습니다. 강의에선 FPGA 내에 MCU IP를 포팅해서 SOC(System On Chip)을 구현하는 방법을 설명합니다. 강의를 통해 FPGA로 프로그램하는 개발자분들의 스킬을 한 단계 업그레이드하길 바랍니다.

잠깐! ✋ MCU란?

마이크로컨트롤러 유닛(Micro Controller Unit)을 말해요. 단일 칩 내부에 프로세서, 메모리, 입출력 장치를 모두 갖춘 장치예요. 프로그래밍을 통해 제어나 연산 작업이 가능합니다. 자동차부터 가전제품, 장난감까지 넓은 분야에서 쓰이고 있어요. 특정 기능을 구현하기 위해 프로그래밍 과정을 거쳐야 해요.

본 강의는 모든 내용을 실습 보드(Arty A7-35T(100T), (Digilent 사))를 통해 직접 구현해 볼 수 있도록 소스를 제공합니다. 제공되는 소스는 현업에서 바로 사용할 수 있는 소스입니다. 저는 지난 15년 동안 이 솔루션을 모든 FPGA에 적용하여 진행하였습니다. 강의는 Xilinx의 Arty A7 보드를 기반으로 설명되어 있지만, Xilinx 사의 모든 FPGA에 적용할 수 있습니다. 강의에서 이해가 안 되는 부분은 인프런 커뮤니티 또는 제가 운영하는 카페를 통하여 질문을 올려주시면 답변해 드리도록 하겠습니다.

📢 수강 전 반드시 확인해주세요!

  • 본 강의는 전자문서 형식으로 구성된 텍스트 강의입니다. 본 강의를 수강하시는 분들께는 무료 MCU IP를 비롯하여 강의에 있는 모든 소스 파일을 제공합니다.
  • 강의 자료 (전자문서, 소스)는 '섹션 0 - 전자문서, 자료 공유 링크 - 첨부파일'에서 다운받을 수 있습니다.

이런 분들께 추천해요 🙋‍♀️

Verilog로 FPGA를 설계한 경험이 있으신 분

C 언어를 이용하여 FW를 해보신 분


이런 걸 배워요 ✨

내용이 적지는 않습니다. 그러나 하나하나 이해해서 자신의 것으로 만든다면 향후 FPGA를 사용하는 일에 대부분 적용할 수 있을 것입니다 💪

System Block와
Bootloader 이해

MCU Memory 및
LOGIC 구현

Application FW
구현 및 응용 

FW 다운로드를 위한
Windows Program 구현

 

상세 커리큘럼이 궁금하다면?
1 개요 (5) 2 HW 구성 (8) 2.1 USB-JTAG를 이용하는 방법 (8)
2.2 JTAG-HS3(HS2)를 이용하는 방법
(9)
2.3 RS-232 커넥터 (10) 2.4 Serial Flash 연결 (10) 3 System Block (11) 3.1 Bootloader ROM (11) 3.2 Serial Flash (14) 3.3 Ext_Mem_SRAM(External Memory SRAM) (14) 3.4 FW_SRAM (14) 3.5 Int_Mem(Internal Memory) (14) 3.6 MCU Core (15) 3.7 LOGIC (15) 3.8 Register Map (15) 4 메모리 구성 (16) 4.1 Ext_Mem_SRAM (External Memory SRAM) (15) 4.2 FW_SRAM (20) 4.3 Bootloader ROM (21) 5 Clock 구성 (23) 6 Bootloader (26) 6.1 Sequence (26) 6.2 Memory Map (27) 6.3 코드 구현 (29) 6.3.1 프로젝트 생성 (29) 6.4 coe 파일 생성 (35) 6.5 Bootloader 소스 (36) 6.5.1 main() (36) 6.5.2 update_data() (38) 7 LOGIC 구현하기 (40) 7.1 mcu_top (40) 7.1.1 mcu_core (40) 7.1.2 addr_map.v (42) 7.1.3 mcs_reg (45) 7.2 pwm_top (45) 8 Application fw (46) 8.1 프로젝트 생성 (46) 8.2 프로젝트 빌드 (51) 8.3 소스 분석 (52) 8.3.1 main1.c (52) 8.3.2 ax_pwm.h (55) 8.3.3 ax_string.h (55) 8.3.4 al8051_func.h (56) 8.3.5 isp_reg.h (56) 9 Windows Application Program (Win_App) (57) 9.1 화면 구성 (57) 9.2 App_fw download sequence (58) 9.3 pwm control protocol (62) 9.3.1 write pwm frequency (62) 9.3.2 write pwm duty (62) 9.3.3 read pwm frequency (63) 9.3.4 read pwm duty (63) 10 FPGA Configurtion file download (64) 10.1 프로젝트 환경 설정 (64) 10.2 Configuration file download (64) 11 결과 확인 (68) 11.1 pwm 확인 (68) 11.2 버튼 확인 (69) 12 UART Baudrate 변경 (70) 12.1 UART Baudrate 설정 (70) 12.2 Bootloader fw 변경 (72) 12.3 Bootloader ROM 재생성 (73) 12.4 mcuProtingTop.v 수정 (75) 12.5 Application fw 수정 (77) 12.6 결과 확인 (78) 13 Application fw 에서 I2C 사용하기 (81) 13.1 I2C Master Controller (81) 13.1.1 I2CTP – Timer Period Register (81) 13.1.2 I2CCR – Control and Status Register (83) 13.1.3 I2CSA – Slave Address Register (83) 13.1.4 I2CBUF – Receiver and Transmitter Register (84) 13.2 Logic 구성 (84) 13.2.1 AL8051EX (84) 13.2.2 mcu_core.v (85) 13.2.3 mcu_top.v (86) 13.2.4 mcuPortingTop.v (87) 13.2.5 mcuPortingTop.xdc (87) 13.3 Application fw (88) 13.4 결과 확인 (94) 14 W5500 고속 인터페이스 구현 (95) 14.1 시스템 블락 (96) 14.2 Logic 구현 (96) 14.2.1 clock (96) 14.2.2 fw_sram (98) 14.2.3 External memory (ext_sram) (99) 14.2.4 spi_sram (100) 14.2.5 Memory Map (101) 14.2.6 addr_map.v 수정 (102) 14.2.7 Bootloader fw 수정 (103) 14.2.8 mcs_reg 모듈 수정 (104) 14.3 W5500 SPI Timing (105) 14.4 SPI 인터페이스 구현 (106) 14.4.1 코드 구현 (106) 14.4.2 simulation (115) 14.5 Top Module 구현 (122) 14.6 Application fw 구현 (126) 14.6.1 외부 flash memory 사용하기 (125) 14.6.2 프로젝트 구성 (127) 14.6.3 flash api (129) 14.6.4 w5500 api (130) 14.6.5 main1.c (134)
14.6.6 Build (137)
14.7 Windows Application Program (138) 14.8 결과 확인( 140) 14.8.1 Bitstream 다운로드( 143) 14.8.2 PC Network 환경 설정 (143) 14.8.3 Application fw 다운로드 (144) 14.8.4 전송 시간 측정( 148) 14.9 결론 (151)
15 참고자료 (152)
16 Revision History (153)

지식공유자 소개 ✒️

이력 사항

저는 20여 년 동안 대기업, 중소기업에서 개발자로 일해왔고 현재는 작은 기업을 운영하고 있습니다. CCTV용 ISP(Image Signal Processing) ASIC을 개발하였고 OLED 검사 장비, DAQ (Data Acquisition System) 등 FPGA를 이용한 많은 제품을 개발하였습니다. FPGA뿐만 아니라 FW 개발 (STM32, PIC32, AVR, ATMEGA 등), 회로 설계, Windows Program 등 많은 경험을 가지고 있습니다.


이런 분들께 추천드려요!

🎓
학습 대상은
누구일까요?
FPGA 스킬업을 원하시는 분
FPGA SOC 구현을 원하시는 분
FPGA에 MCU를 포팅해서 사용하시기 원하시는 분
📚
선수 지식,
필요할까요?
C 언어
Verilog 언어
FPGA 설계

안녕하세요
alex 입니다.
alex의 썸네일

저는 지난 20여년 동안 대기업, 중소기업에서 개발자로 일해왔고

현재는 작은 기업의 대표로 있습니다.

주요 경력사항은

  • Verilog HDL을 이용한 FPGA 설계

    • CCTV용 ISP ASIC 개발 (약 10년)

    • OLED Display 검사장비 개발 (약 3년)

    • FPGA를 이용한 장비 개발

  • MCU FW

    • STM32

    • PIC32

    • AVR, ATMEGA

    • DSP (TI)

  • Windows Application Program

    • Visual Studio MFC, C++

입니다.

커리큘럼 총 151 개
이 강의는 수업 노트, 첨부 파일이 제공됩니다. 미리보기를 통해 콘텐츠를 확인해보세요.
섹션 0. 개요
섹션 1. HW 구성
HW 구성 - 0
HW 구성 - 1
HW 구성 - 2
섹션 2. System Block
System Block - 0 미리보기
System Block - 1
System Block - 2
System Block - 3
System Block - 4
섹션 3. 메모리 구성
메모리 구성 - 0
메모리 구성 - 1
메모리 구성 - 2
메모리 구성 - 3
메모리 구성 - 4
메모리 구성 - 5
메모리 구성 - 6
섹션 4. Clock 구성
Clock 구성 - 0 미리보기
Clock 구성 - 1
Clock 구성 - 2
섹션 5. Bootloader
Bootloader - 0 미리보기 Bootloader - 1 미리보기 Bootloader - 2 미리보기
Bootloader - 3
Bootloader - 4
Bootloader - 5
Bootloader - 6
Bootloader - 7
Bootloader - 8
Bootloader - 9
Bootloader - 10
Bootloader - 11
Bootloader - 12
Bootloader - 13
섹션 6. LOGIC 구현하기
LOGIC 구현하기 - 0
LOGIC 구현하기 - 1
LOGIC 구현하기 - 2 미리보기 LOGIC 구현하기 - 3 미리보기
LOGIC 구현하기 - 4
LOGIC 구현하기 - 5
섹션 7. Application FW
Application FW - 0
Application FW - 1
Application FW - 2
Application FW - 3
Application FW - 4
Application FW - 5
Application FW - 6
Application FW - 7
Application FW - 8
Application FW - 9
Application FW - 10
섹션 8. Windows Application Program
Windows Application Program - 0
Windows Application Program - 1
Windows Application Program - 2
Windows Application Program - 3
Windows Application Program - 4
Windows Application Program - 5
Windows Application Program - 6
섹션 9. FPGA Configuration File Download
FPGA Configuration File Download - 0
FPGA Configuration File Download - 1
FPGA Configuration File Download - 2
FPGA Configuration File Download - 3
섹션 10. 결과 확인
결과 확인 - 0
결과 확인 - 1
섹션 11. UART Baudrate
UART Baudrate - 0 미리보기
UART Baudrate - 1
UART Baudrate - 2
UART Baudrate - 3
UART Baudrate - 4 미리보기
UART Baudrate - 5
UART Baudrate - 6
UART Baudrate - 7
UART Baudrate - 8
UART Baudrate - 9
UART Baudrate - 10
섹션 12. Application fw에서 I2C 사용
Application fw에서 I2C 사용 - 0
Application fw에서 I2C 사용 - 1
Application fw에서 I2C 사용 - 2
Application fw에서 I2C 사용 - 3
Application fw에서 I2C 사용 - 4
Application fw에서 I2C 사용 - 5
Application fw에서 I2C 사용 - 6
Application fw에서 I2C 사용 - 7
Application fw에서 I2C 사용 - 8 미리보기
Application fw에서 I2C 사용 - 9
Application fw에서 I2C 사용 - 10
Application fw에서 I2C 사용 - 11
Application fw에서 I2C 사용 - 12
Application fw에서 I2C 사용 - 13
섹션 13. w5500 인터페이스 구현
w5500 인터페이스 구현 - 0 미리보기 w5500 인터페이스 구현 - 1 미리보기
w5500 인터페이스 구현 - 2
w5500 인터페이스 구현 - 3
w5500 인터페이스 구현 - 4
w5500 인터페이스 구현 - 5
w5500 인터페이스 구현 - 6 미리보기
w5500 인터페이스 구현 - 7
w5500 인터페이스 구현 - 8
w5500 인터페이스 구현 - 9
w5500 인터페이스 구현 - 10
w5500 인터페이스 구현 - 11 미리보기
w5500 인터페이스 구현 - 12
w5500 인터페이스 구현 - 13
w5500 인터페이스 구현 - 14
w5500 인터페이스 구현 - 15
w5500 인터페이스 구현 - 16
w5500 인터페이스 구현 - 17
w5500 인터페이스 구현 - 18
w5500 인터페이스 구현 - 19
w5500 인터페이스 구현 - 20
w5500 인터페이스 구현 - 21
w5500 인터페이스 구현 - 22
w5500 인터페이스 구현 - 23
w5500 인터페이스 구현 - 24
w5500 인터페이스 구현 - 25 미리보기
w5500 인터페이스 구현 - 26
w5500 인터페이스 구현 - 27
w5500 인터페이스 구현 - 28
w5500 인터페이스 구현 - 29
w5500 인터페이스 구현 - 30
w5500 인터페이스 구현 - 31
w5500 인터페이스 구현 - 32
w5500 인터페이스 구현 - 33
w5500 인터페이스 구현 - 34
w5500 인터페이스 구현 - 35
w5500 인터페이스 구현 - 36
w5500 인터페이스 구현 - 37
w5500 인터페이스 구현 - 38
w5500 인터페이스 구현 - 39
w5500 인터페이스 구현 - 40
w5500 인터페이스 구현 - 41
w5500 인터페이스 구현 - 42
w5500 인터페이스 구현 - 43
w5500 인터페이스 구현 - 44
w5500 인터페이스 구현 - 45
w5500 인터페이스 구현 - 46
w5500 인터페이스 구현 - 47
w5500 인터페이스 구현 - 48
w5500 인터페이스 구현 - 49
w5500 인터페이스 구현 - 50
w5500 인터페이스 구현 - 51
w5500 인터페이스 구현 - 52 미리보기
w5500 인터페이스 구현 - 53
w5500 인터페이스 구현 - 54
w5500 인터페이스 구현 - 55
w5500 인터페이스 구현 - 56
섹션 14. 기타
기타 - 0
기타 - 1
기타 - 2
강의 게시일 : 2022년 11월 04일 (마지막 업데이트일 : 2023년 04월 19일)
수강평
수강생분들이 직접 작성하신 수강평입니다.
아직 평가를 충분히 받지 못한 강의 입니다.
모두에게 도움이 되는 수강평의 주인공이 되어주세요!😄️️