일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | ||||||
2 | 3 | 4 | 5 | 6 | 7 | 8 |
9 | 10 | 11 | 12 | 13 | 14 | 15 |
16 | 17 | 18 | 19 | 20 | 21 | 22 |
23 | 24 | 25 | 26 | 27 | 28 |
- dfs
- 백준
- 시뮬레이션
- 수영대회결승전
- Calibration
- ICER
- 마법의숲탐색
- 순서대로방문하기
- 소프티어
- BFS
- 루돌프의반란
- ros
- 조합
- 슈퍼컴퓨터클러스터
- 마이크로프로세서
- DP
- 구현
- 코드트리빵
- ARM
- 이진탐색
- 토끼와 경주
- 나무박멸
- 싸움땅
- 포탑부수기
- ISER
- 코드트리
- 삼성기출
- DenseDepth
- 왕실의기사대결
- 3Dreconstruction
- Today
- Total
목록EE 학부과목/마이크로프로세서 (7)
from palette import colorful_colors
![](http://i1.daumcdn.net/thumb/C150x150/?fname=https://blog.kakaocdn.net/dn/eq0ViY/btsjGnI0KAU/D8Ji0ikVypkHyemXBkpQM0/img.jpg)
1. GPIO의 ODR 비트 조절하기 예시: GPIOA의 ODR의 8번 비트를 1로 켜기 C 언어: GPIOA->ODR |= 1UL ODR의 bit8을 1로 만든다 ARM 어셈블리어: GPIOA_BASE EQU 0x48000000; GPIOA의 BASE 주소는 0x48000000이다. GPIO_ODR EQU 0x14; ODR은 GPIO BASE에서 0x14만큼 떨어져 있으므로 LDR r7, = GPIOA_BASE LDR r1, [r7, #GPIO_ODR]; r1에 GPIOA의 ODR에 있는 값을 불러온다 ORR r1, r1, #2_100000000; 8번 비트를 1로 만든다 STR r1, [r7, #GPIO_ODR]; GPIOA의 ODR에 다시 변경한 값을 저장한다. 2. GPIO OUTPUT 예시: G..
![](http://i1.daumcdn.net/thumb/C150x150/?fname=https://blog.kakaocdn.net/dn/bV8rt8/btsbkGEgcpZ/nfbbkr47r6PA6wv0Km616K/img.jpg)
Arm 명령어에 대해 알고 싶다면 아래 링크 클릭 https://colorful-palette.tistory.com/48 예시1: Register indirect addressing mode (원하는 주소에서 값을 넣고 포인터를 상승시키는 예시) → 0x12456주소에 25를 넣고 포인터 상승시키기 #include int main(){ char * ourPointer; ourPointer = (char*) 0x12456 // ourPointer를 1byte char형을 가리키는 포인터로 선언했다. *ourPointer = 25 ourPointer ++ return 0; } LDR R2, = 0x12456 MOV R0, #25 STRB R0, [R2] ADD R2, R2, #1 예시2: 주어진 배열에서 M..
![](http://i1.daumcdn.net/thumb/C150x150/?fname=https://blog.kakaocdn.net/dn/WpatI/btsbkGjLLYq/ZUH9hGjppKxJNlra6flcF0/img.jpg)
해당 포스팅은 RISC계열 명령어중 ARM 명령어들을 정리한 포스팅입니다. 1. 기본 명령어(move, load, store) MOV Rm or Op2 : register값(Rm) 혹은 immediate value (Op2) 값을 레지스터로 복사 예시: MOV R2 #25 ; 25를 R2 레지스터에 넣는다 MOV R2 #0x87 ; 16진수 87을 R2 레지스터에 넣는다 LDR Rd [Rx] : (Rx레지스터의 값)에 해당하는 주소에 있는 값을 Rd로 불러온다. STR Rx [Rd]: Rx값을 (Rd레지스터 값)에 해당하는 메모리 주소에 저장한다. 1-2. 추가적인 load, store instruction: LDRB / LDRH Rd [Rx] : (Rx레지스터의 값)에 해당하는 주소에서 1byte / ..
![](http://i1.daumcdn.net/thumb/C150x150/?fname=https://blog.kakaocdn.net/dn/6QQP4/btr45kMpP4Y/sa4ZQ5bIKlOHnQNdeFQqC1/img.jpg)
일부글씨가 안 보이거나 헷갈리는 부분이 있으면 말씀해주세요 (보라색 글씨는 참고사항이라서 패스해도 됩니다) 127을 바이어스해서(더해서) 저장한다는 사실 잊지말기!
![](http://i1.daumcdn.net/thumb/C150x150/?fname=https://blog.kakaocdn.net/dn/SIlPi/btr4gVmNxLS/T7hWyw9CXvPwterP2ZFj60/img.png)
경북대학교 ㅂㅇㅈ 교수님의 필기자료입니다. MIPS 구조에 대해 설명하시기 때문에 ㅅㄷㄱ교수님의 프로젝트 내용과 겹치는 부분이 많아 3학년 1학기 논리회로설계 → 3학년 2학기 컴퓨터 구조를 들으시는 것을 추천드립니다 파일 용량 한계가 20MB라 나눠서 업로드했습니다. 다만 글씨체가... 도움이 되면 좋겠습니다 ㅠ
![](http://i1.daumcdn.net/thumb/C150x150/?fname=https://blog.kakaocdn.net/dn/dvLJnC/btr2EalNeDa/9k5JRjL7Opki6H9G9Db9K1/img.jpg)
Instruction(명령어) 컴퓨터 언어에 쓰이는 명령어를 의미한다. Assembly language(예시: $add, $ls, ... ), Machine language(기계어, 010101...)로 표현 가능하다. 명령어에는 CISC 계열과 RISC 계열이 있다. CISC(Complex Instruction Set Computer) vs RISC(Reduced Instruction Set Computer) cisc는 명령어가 complex(복잡)하고, risc는 명령어가 reduced(간단)하다. cisc는 Intel CPU에 해당하는 Architecture고, RISC는 ARM계열에서 사용하는 애플의 M1칩 등등에서 사용하는 Architecture다. 좀 더 자세히 알아보자. CISC 예를 들어 ..
![](http://i1.daumcdn.net/thumb/C150x150/?fname=https://blog.kakaocdn.net/dn/bfGrBC/btr2EasyigQ/vuwym3mLs0OFO1oV2tK5v0/img.jpg)
Microprocessor(마이크로프로세서) 레지스터(저장), ALU(연산), CU(제어) 3가지 구성요소를 담고 있는 single chip Microcomputer(마이크로컴퓨터) 마이크로 프로세서를 이용해 만든 하나의 컴퓨터 시스템. I.O포트, 마이크로프로세서, 메모리가 합쳐진 것을 의미한다. ex) 라즈베리 파이 버스가 각 부분들의 데이터를 이동시켜준다. (Address Bus, Data Bus) Microcontroller(마이크로컨트롤러) 위의 마이크로컴퓨터(마이크로 프로세서, I.O포트, 카운터, 인터럽트 회로, ...) 들어있는 single chip 저가형, 저전력, 특정 작업에 맞춤으로 제작된다. SoC(System on Chip) 여러 CPU와 다른 하드웨어를 결합한 하나의 칩, 여러 ..