DSP Design [2]
앞서의 글에서 공개된 아키텍쳐를 이용해서 만드는 것이 좋다고 말씀드렸습니다.
공개된 아키텍쳐 중에서 당장 눈에 뛰는 것은 4가지 입니다.
- OpenCores 와
- SUN Sparc Processor
- Core-A
- MIPS-I
각각의 프로세서를 간략하게 정리하였습니다.
2-1 OpenCore - 1000/1200
Damjanl Lampret 라는 사람이 만든 OpenCores에서 공개한 프로세서로서 32비트 및 64비트까지 지원하는
명령어 세트를 가지고 있습니다.
오픈 코아는 명령어 자체가 걸려있는 것이 아닌것으로 생각되어, 구현 해도 큰 문제는 없을 것으로 생각합니다.
다만 현재 있는 것도 잘 되어 있어서 큰 문제는 없고, 실제 사용한 적도 있기 때문에
굳이 구현할 필요까지는 없을 것 같습니다.
무엇보다 공짜인데.. 라는 생각이 강한 오픈 코아이기 때문에 개인적으로는 위화감이 있습니다.
2-2 SUN Sparc
요게 맘에 들긴 합니다.
뭣보다도 정식 라이센스도 가능하고, 컴파일러와 O/S도 다 갖추고 있기 때문에 구현후에 좋습니다.
선에서 구할 수 있는 것은 T1과 T2프로세서 입니다.
T2는 서버를 원칩에 담겠다는 개념으로 만들어서 코드네임도 “NAIAGARA"로 명명했습니다.
결과물을 보면 물량전에서 절대 지지 않는 울트라 리스크 러쉬라고 할까요 ?
그런 정도의 엄청난 물량을 가지고 있습니다.
T1도 잘 만들었고 실제 이넘에서 프로세서 하나를 떼서 사업화 하겠다던 회사도 있었습니다.
그후에 소식은 못들어서 또 역사의 물결 속으로 사라진게 아닌가 하는 의구심도 듭니다.
하여튼 개인적으로는 이러한 레지스터 윈도우 방식은 참으로 좋은 아이디어로 생각합니다.
일정 수준까지의 함수의 호출에서는 스택을 건드리지 않고 파라미터와 내용을 전달하기 때문에
속도가 아주 빠릅니다.
다만 일정 수준을 넘어가면 Exception이 발생하고, 그 후에 다시 처리하는 것이 조금 시간이 걸린다는 단점이 있습니다.
개인적으로는 Embedded IP에서 게이트 카운트에 압박을 벗어나는 시대이므로, 용량이 좀 되는 어플리케이션에서는 좋은 어프로치라고 생각합니다.
2-3 Core-A
작년 여름께 발표된 것으로, 특허청과 국내 대학 연합에서 만들어서 발표한 아키텍쳐입니다.
아키텍쳐가 공개된는지는 모르겠습니다만, 명령어 세트를 구하는 것은 쉬운 것이라서
구현이 가능한 범주에 넣었습니다.
NOP를 명령어 비트에 집어넣은 발상으로 만들었기 때문에 Data forwarding이 필요 없다는
개념을 가진 아키텍쳐로 보입니다.
컴파일러와 시뮬레이터가 아직 완전하지 않은것으로 보여 이 부분에 대한 보완이 시급한 것 같습니다.
하지만, 이제 시작이고 국내에서 EISC외에 새로운 아키텍쳐가 나왔다는 점에서 의미가 있다고 생각합니다.
2-4 MIPS-I
위의 사진은 도시바에서 만든 MIPS-4400입니다.
MIPS WIKI페이지에서 옮겼습니다.
ARM과 쌍벽을 이루면서, 미국에서 자존심을 걸고 지켜주는 프로세서이죠
프로세서 아키텍쳐 바이블 서적인 Computer Organization and Design: The Hardware/Software Interface 에서 설명하는 구조입니다.
프로세서 공부하시는 분들은 모르는 사이에 한번 공부한 아키텍쳐죠..
MIPS의 클론 프로세서를 검토한다면 렉서라라는 회사에 대해서 알아야 합니다. 이것에 대해서는 아래 링크를 한번 읽어보시면 좋겠습니다.
(눈물 없이는 읽을 수 없는 글입니다.)
http://jonahprobell.com/lexra.html
LEXRA는 MIPS-I 클론을 만들었고, 특허를 피해가기 위해서 노력을 했습니다만, MIPS의 현질 공세에 밀려서 사라진 회사입니다. 저자는 MIPS가 Lexra에 대항했을 때의 그 노력으로 ARM에 대항했다면, 훨씬 좋은 결과를 만들었을 거라는 아쉬움을 이야기합니다.
MIPS-I에서 특허로 보호받는 부분은 명령어중 4개 정도 입니다. 그리고 이 명령어들은 Memory Miss Alignment에 대한 것들입니다.
이 것에 대해서는 우여 곡절이 많지만 하여튼 2006년 12월에 특허가 완전히 풀렸습니다.
따라서 구현에 법적인 문제는 없는것으로 되어 있습니다.
관련해서 오픈 코아의 Plasma프로세서가 MIPS-I을 이용해서 구현했습니다.
http://www.opencores.org/projects.cgi/web/mips/overview
앞서 말씀드린 바와 같이 MIPS-I의 특허는 완전히 풀렸기 때문에 이것을 이용해서 프로세서를 만드는 것이 가능합니다.
2-5 어떤 아키텍쳐를 ??
어떤 것을 구현하는게 좋은지는 법적인 문제와 실제 문제 그리고, 프로세서의 개발 환경 문제도 검토해야 합니다.
그리고 컴파일러의 최적화 문제에 대해서 고민을 해봐야 하고 또, 프로세서의 용도에 따라서 선택해야 하는 문제입니다.
이번에 만들고 싶은 프로세서는 고성능 DSP프로세서이기 때문에 명령어 확장도 가능한 형태로 가야 합니다. 이 부분을 고려하여서 위의 4가지 아키텍쳐 중에서 하나를 선택해서 구현합니다.
---------
그외에 공개된 아키텍쳐가 있다면 좋겠습니다.
이 자료는 현재까지 알고 있는 아키텍쳐에 대해서 검토한 과정을 정리한 것입니다.
언제나 그렇듯 제가 알고 있는 부분과 사실과 틀릴수도 있습니다. ㅋㅋ