FPGA

위키백과, 우리 모두의 백과사전.
이동: 둘러보기, 검색
알테라 사이클론2 현장 프로그래머블 게이트 어레이

FPGA(field programmable gate array, 현장 프로그래머블 게이트 어레이)은 프로그래머블 논리 요소와 프로그래밍가능 내부선이 포함된 반도체 소자이다. 프로그래머블 논리 요소는 AND, OR, XOR, NOT, 더 복잡한 디코더나 계산기능의 조합 기능같은 기본적인 논리 게이트의 기능을 복제하여 프로그래밍할 수 있다. 대부분의 FPGA는 프로그래밍가능 논리 요소 (FPGA 식으로는 논리 블록이라고도 함)에 간단한 플립플롭이나 더 완벽한 메모리 블록으로 된 메모리 요소를 포함하고 있다.

프로그램이 가능한 내부선 계층구조는 FPGA의 논리블록을 시스템 설계자가 요구하는 대로 단일 칩 프로그래밍가능 빵판처럼 내부연결을 할 수 있다. 이 논리블록과 내부선은 제조공정 이후에 소비자/설계자가 프로그램할 수 있으므로 요구되는 어떠한 논리기능도 수행할 수 있다.(그러한 이유로 "현장 프로그래머블")

FPGA는 일반적으로 주문형 반도체(ASIC) 대용품보다 느리고, 복잡한 설계에 적용할 수 없으며, 소비전력이 크다. 그러나 개발시간이 짧고, 오류를 현장에서 재수정할 수 있고, 초기 개발비가 저렴하다는 장점이 있다. 제조사는 설계 이후에 수정할 수 없도록 할당된 덜 유연한 FPGA 버전으로 싸게 팔 수 있다. 이런 설계개발은 일반적인 FPGA에서 만들었고 좀 더 ASIC와 비슷한 고정된 버전으로 변경되었다. 복합 프로그래머블 논리 소자 (CPLD)는 비슷한 역할을 할 수 있는 소자이다.

역사[편집]

FPGA의 역사적 근원은 1980년대초의 복합 프로그래머블 논리 소자 (CPLD)이다. 자일링스 공동 창립자인 로스 프리맨 (Ross Freeman)은 1984년에 FPGA를 발명하였다. FPGA는 복합 프로그래머블 논리 소자보다 상대적으로 프로그램되는 논리 요소가 많다. 복합 프로그래머블 논리 소자에는 수천에서 수만의 논리 게이트가 있지만, FPGA에는 일반적으로 수만에서 수백만의 논리 게이트가 있다.

복합 프로그래머블 논리 소자와 FPGA의 가장 큰 차이점은 구조적인 차이이다. 복합 프로그래머블 논리 소자는 하나 이상의 프로그램되는 상대적으로 적은 수의 동기 레지스터를 제공하는 곱의 합 논리 어레이로 구성된 제한적인 구조이다. 이러한 것은 지연을 더 예측가능하게 하고 논리-내부선 속도를 더 빠르게 하지만 유연성이 떨어진다. 반대로 FPGA 구조는 내부선에 따라 결정된다. 내부선은 FPGA를 (내부적으로 동작하는 실제적인 설계범위의 기간에) 더 유연하고 설계에 더 복합적으로 만든다.

다음으로 큰 복합 프로그래머블 논리 소자와 FPGA의 차이점은 높은 수준의 내장 기능 (가산기와 곱셈기)과 내장 메모리의 존재여부이다. 또한 대부분의 FPGA는 완전히 혹은 부분적으로 시스템상에서 재설정을 지원하며 이들의 설계를 시스템 향상이나 시스템 동작의 일반적인 부분처럼 동적 재설정하여 "즉흥적으로" 변경하는 것을 가능하게 한다. 어떤 FPGA에는 다른 부분이 계속 동작하는 동안 소자의 일부분을 재프로그램하는 부분적 재설정의 기능이 있다..

현대의 개발[편집]

최근 경향은 성긴(coarse-grained) 구조적 접근을 채택하고 있다. 이는 임베디드 프로세서와 관련 주변기기를 전통적인 FPGA의 논리블록과 내부선에 조합하여, 완전한 "프로그래머블칩 시스템"을 만드는 것이다. 이런 하이브리드 기술의 예로는 자일링스 버텍스2 프로, 버텍스4 소자, 그리고 한 개이상의 PowerPC 프로세서가 FPGA의 논리 구조에 내장된 것을 들 수 있다. 아트멜 FPSLIC도 이런 소자 중 하나며, 아트멜의 프로그래머블 논리 구조와 조합되어 AVR 프로세서를 사용한다. 또 다른 접근은 내부 FPGA 논리로 구현된 "소프트" 프로세서 코어를 쓰는 것이다. 이런 코어들로는 제 3자의 (상업용이거나 무료인) 프로세서 코어로 알려진, 자일링스 매크로블래이즈피코블래이즈, 알테라 나이오스와 나이오스2 프로세서, 오픈 소스 래티스미코32래티스미코8등이 있다. 중앙 처리 장치 구조가 내장된 하드 중앙 처리 장치 코어는 소프트코어 중앙 처리 장치보다 성능이 우월할 것이다. (예시: 중앙 처리 장치의 프로그래머블 논리 실행)

이전에 언급했듯이 대다수 현대의 FPGA는 "동작 시간" 동안에 재프로그램할 수 있고, 리컨피규러블 컴퓨팅이나 즉시 태스크를 적용하도록 재설정하는 리컨퓨규러블 시스템중앙 처리 장치의 아이디어를 이끌었다. 그러나, 현대의 FPGA 도구는 이런 방법론을 완벽하게 지원하지 않는다.

덧붙여 지금은 비FPGA 구조가 나오기 시작했다. Stretch S5000같은 소프트웨어로 설정되는 마이크로프로세서는 하나의 칩에 프로세서 코어 어레이와 FPGA같은 프로그래머블 코어를 제공함으로써 하이브리드 접근이 도입된다. (현장 프로그래머블 오브젝트 어레이 (field programmable object array, FPOA) 같은) 다른 소자는 FPGA의 논리블록과 복합 프로세서 중간상태로 높은수준의 프로그래머블 오브젝트 어레이를 제공한다.

응용[편집]

FPGA의 응용으로 디지털 신호 프로세서 (DSP), 소프트웨어로 정의된 라디오, 우주과학방어 시스템, 주문형 반도체 (ASIC) 초기버전, 의료 영상, 컴퓨터 비전, 음성 인식, 암호학, 생물정보학, 컴퓨터 하드웨어 에뮬레이터와 성장하는 다른영역에 사용된다. FPGA는 복합 프로그래머블 논리 소자의 경쟁소자로 처음에 시작되었고, PCB에서 글루 논리의 비슷한 크기로 경쟁하였다. 용량 및 속도가 향상되어 어떤 것은 완전한 칩의 시스템 (SOC)처럼 지금 판매되는 상황으로 더욱 더 큰 기능을 넘어서기 시작했다.

FPGA는 어떤 영역이나 구조에 따라 제공된 거대 병렬 알고리즘에 특히 유용하다. 이 중 하나는 암호 체계에 대한 무차별 대입 공격 (brute force attack) 암호해독기이다.

구조[편집]

일반적인 기본 구조는 컨피규러블 논리 블록 (configurable logic blocks) 어레이와 라우팅 채널로 구성된다. 다중 I/O 패드는 한행의 높이나 한열의 너비에 적합할지도 모른다. 일반적으로 모든 라우팅 채널은 동일한 (전선수) 폭을 가지고 있다.

응용회로는 적합한 자원을 가지는 FPGA를 반드시 매핑해야한다.

일반적인 FPGA의 논리 블록은 아래에 보이는 것처럼 4개의 입력 룩업 테이블 (lookup table)과 플립플롭으로 구성된다.

논리 블록

레지스터나 언레지스터 룩업 테이블이 가능한 하나의 출력만 있다. 논리 블록에는 룩업 테이블를 위한 4개의 입력과 클럭 입력이 있다. 클럭 신호 (와 높은 팬 아웃 신호)는 일반적으로 특별용도 전용 라우팅망을 통하여 연결되고 다른 신호는 분리하여 관리하기 때문이다.

이 예시구조로 FPGA의 논리 블록 핀 위치는 아래와 같이 보인다.

논리 블록 핀위치

각 입력은 출력핀이 바로 연결된 채널과 논리 블록을 통한 채널으로된 라우팅 전선을 연결할 수 있는 동안에 논리 블록의 한면으로 접근할 수 있다.

각 논리 블록 출력핀은 이렇게 이웃한 채널에서 분할된 전선 중 하나를 연결할 수 있다.

비슷하게 I/O 패드도 이렇게 이웃한 채널에서 분할된 전선중 하나를 연결할 수 있다. 예시로 칩의 맨위에 있는 I/O 패드는 바로 밑의 수평 채널에 있는 W 전선 (W는 채널 폭임)의 어떤것과 연결할 수 있다.

일반적으로 FPGA의 라우팅은 분할되지 않는다. 각 전선의 분할은 스위치 상자로 차단되기 이전에 하나의 논리 블록과 연결되어 있다. 스위치 상자 내부의 프로그래머블 스위치를 켜서 긴 라인을 구성할 수 있다. 고속의 내부선을 위해서 FPGA의 구조는 다중의 논리 블록과 연결된 긴 라우팅 라인을 사용한다.

어떤 수평 채널이나 수직 채널도 스위치 상자를 교차한다. 이 구조에서 전선이 스위치 상자로 들어갈 때 인접한 채널 분할에서 3개의 다른 전선을 연결할 수 있는 3개의 프로그래머블 스위치가 있다. 이 구조에서 사용되는 스위치의 패턴이나 위상은 평면이나 도메이기반의 스위치 상자 위상이다. 스위치 상자 위상에서 트랙 숫자 1의 전선은 인접한 채널 분할에 있는 트랙 숫자 1의 전선에만 연결되고, 트랙 숫자 2의 전선은 트랙 숫자 2의 다른전선에만 연결되며 이렇게 반복 연결된다. 아래의 그림은 스위치 상자에 있는 연결을 설명한다.

스위치 상자 위상

현대의 FPGA 계열은 반도체 공정 기술의 발전에 의해 높은 수준의 기능들을 가지게 되었으며, 초기 버전보다 속도와 기능이 향상되었다. 이런 기능들로는 곱셈기, 일반적인 DSP 블록, 임베디드 프로세서, 고속 IO 논리, 임베디드 메모리 등을 들 수 있다.

FPGA는 이전 실리콘의 유효성, 이후 실리콘의 유효성, 펌웨어 개발을 포함하여 시스템 유효성 검사에 널리 사용되고 있다. 칩이 공장에서 생산되기 이전에 설계를 검증하는 칩 회사가 생겨서 개발시간이 짧아졌다.

FPGA 설계와 프로그래밍[편집]

FPGA의 동작 정의를 위해서 사용자에게 하드웨어 기술 언어 (HDL)나 도면 설계를 제공하고 있다. 일반적인 하드웨어 기술 언어는 VHDL베릴로그가 있다. 전자설계 자동화 도구를 사용하면 기술적으로 매핑된 넷리스트가 생성된다. 넷리스트는 배치와 배선라고 불리는 작업을 통해 실제 FPGA에 적합하게 할 수 있으며, 일반적으로 FPGA 회사 자산인 배치와 배선 소프트웨어로 수행한다. 사용자는 맵, 타이밍 분선을 통한 배치와 배선, 시뮬레이션, 다른 검증 방법론으로 검증할 것이다. 한번 설계와 검증 과정이 완료되면, (FPGA 회사 자산 소프트웨어를 사용하여) 생성된 이진 파일을 FPGA의 (재)설정에 사용한다.

하드웨어 기술 언어들을 도입함으로써 어셈블리어와 비교해서 설계의 복잡성을 감소시키는 경향으로 설계를 추상적인 수준으로 끌어올린다. 캐던시 디자인 시스템, 시놉시스, 셀록시카 같은 회사들은 전통적인 하드웨어 기술 언어를 사용하여 가능한것보다 FPGA 설계 주기를 더 빠르게 가능한 병행 모델을 갖는 높은 수준 언어를 조합하는 방법으로 시스템C를 선전하였다. (라이브러리나 다른 확장이 되는 병렬 프로그래밍를 가지는) 표준 CC++ 기반의 접근은 멘토 그래픽스의 캐터펄트 C 도구나 임펄스 가속 기술의 임펄스 C 도구들이 발견된다. 아나폴리스 마이크로 시스템 (Annapolis Micro Systems, Inc.)의 코어파이어 디자인 슈트는 높은 수준 설계 엔트리에 그림형태의 데이터흐름 접근을 제공한다. 시스템베릴로그, 시스템VHDL, (셀록시카로부터) 헨델 C같은 언어들은 동일한 목적을 성취하려고 추구하였지만 생산된 현재의 하드웨어 공학은 더 생산적인것과 생산된 FPGA는 현재의 소프트웨어 공학에 더 접근하는 게 목적이다.

FPGA에서 복장한 시스템의 설계를 간단히 하려고 설계 과정을 빠르게 검증하고 최적화한 미리 정의된 복잡한 기능과 회로의 라이브러리가 존재한다. 미리 정의된 회로는 일반적으로 “IP 코어”라고 불리고 (드물게 자유 라이선스와 일반적으로 사유 라이선스로 공개한) FPGA 제조사와 제 3의 IP 공급자에게서 제공받을 수 있다. 다른 미리 정의된 회로는 (일반적으로 “자유 소프트웨어", GNU 일반 공중 사용 허가서, BSD 사용 허가서와 비슷한 라이선스로 공개한) 오픈코어와 다른 제공 커뮤니티같은 개발자 커뮤니티로부터 제공받을 수 있다.

일반적인 설계 흐름에서 FPGA 응용 개발자는 설계과정을 거치며 여러 단계에서 설계를 시뮬레이션할 것이다. 초기에 VHDL이나 Verilog (베릴로그)로 된 RTL 기술은 시스템을 시뮬레이션하고 결과를 관측하기 위해 생성된 테스트 벤치에 따라 시뮬레이션한다. 그런 다음 합성 엔진은 설계를 넷리스트에 매핑한후 넷리스트는 게이트 수준 기술로 번역하며 시뮬레이션은 합성을 진행하는 중에 오류가 없는지 확인을 되풀이한다. 마지막으로 설계는 FPGA에 배치하는 경우에 어떤 지점의 전달 지연은 추가될 수 있고 시뮬레이션은 이런 값을 넷리스트에 기록하여 다시 실행한다.

기본적인 제조기술 종류[편집]

  • 에스램 - 정적 메모리 기술 기반. 시스템에서 프로그램과 리프로그램이 됨. 외부 부트소자가 필요함. 시모스.
  • 안티퓨즈 - 한번만 프로그램이 됨. 시모스.
  • 이피롬 - 소거 및 프로그램되는 읽기용 메모리 기술. 일반적으로 플라스틱 패키지의 제품은 한번만 프로그램이 됨. 창이있는 소자는 자외선 (UV)로 삭제할 수 있음. 시모스.
  • 이이피롬 - 전기적소거 및 프로그램되는 읽기용 메모리 기술. 플라스틱 패키지라도 소거할 수 있음. 일부 EEPROM 소자는 시스템에서 프로그램할 수 있음. 시모스.
  • 플래시 메모리 - 플래시소거 이이피롬 기술. 플라스틱 패키지라도 소거할 수 있음. 일부 플래시 소자는 시스템에서 프로그램할 수 있음. 일반적으로 플래시 셀은 동등한 이이피롬 셀보다 작고 제조비용이 저렴함. 시모스.
  • 퓨즈 - 한번만 프로그램됨. 접합형.

FPGA 제조회사와 특징[편집]

2005년 후반에 FPGA 시장은 2개의 주된 “일반용” FPGA 제조사와 제공된 특별한 능력으로 구별하는 몇 개의 다른 용도로 거의 안정되었다.

  • 자일링스알테라는 두개의 큰 FPGA 선도회사이다.
  • 래티스 세미컨덕터는 에스램과 비휘발성을 가지는 플래시 기반 FPGA를 제공한다.
  • 액텔은 안티퓨즈와 재프로그램되는 플래시 기반 FPGA가 있고, 신호가 혼합된 플래시 기반 FPGA도 제공한다.
  • 아트멜자일링스 XC62xx처럼 미립자의 재설정되는 소자를 공급한다. 동일한 다이 (칩)의 FPGA 구조에 AVR 마이크로프로세서를 포함하고 있다.

같이보기[편집]

바깥 고리[편집]