2011-08-20 3 views
4

이것은 내 배경으로, 컴퓨터 공학 석사 학위를 가지고 있으며, 대부분의 일은 다양한 가전 제품 용 장치 드라이버 작성과 관련되어 있습니다. 8051 및 8086 컨트롤러 프로그래밍을 내 커리큘럼의 일부로 수행했습니다. 또한 Automotive HW의 기능 검증에 대한 작업을 수행했습니다. 이제는 보드를 깜박이고, 전원을 켜고, 부트 로더 프로그래밍을하고, 보드의 다양한 구성 요소를 검증하고, 버스, 메모리 등을 확인하는 매우 낮은 레벨로 이동하려고합니다.게시판 가져 오기 및 hw 진단을 배우는 가장 좋은 방법은 무엇입니까?

+1

http://electronics.stackexchange.com/을 시도해보십시오. –

답변

1

마이크로 컨트롤러로 임베디드 시스템 디자인을 배우는 방법 보드를 디자인하고 가져 오십시오. Atmel AVR이있는 일부 프로젝트의 경우 http://www.avrfreaks.net/을 시도하십시오. 이 http://www.sixca.com/, http://www.eevblog.com/

http://www.webring.org/hub/avr 귀하의 질문은 매우 광범위하고 이러한 것들을 학습에 접근하는 방법에는 여러 가지가 있습니다, 정말 또한, 그러나 이것은 내가 처음 온 방향이며 잘 날 위해 일했다.

24

먼저 전자 공학에 대한 이해가 필요합니다. EE 학위는 도움이 되긴하지만 반드시 필요한 것은 아니지만, 시장에 따라 다릅니다.

강한 도식 읽기 기술, 좋은 회로도 및 나쁜 것들이 분명 필요합니다.

강력한 데이터 시트 및 기타 참조 설명서 기술이 필요합니다. 대부분의 매뉴얼에는 실수가 있으므로 해킹 기술이 필요합니다. 설명서를 신뢰하지 말고 하드웨어를 테스트하지 않고 수백 또는 수천 줄의 코드를 작성하지 마십시오. 한 번에 한 단계 씩. 일부 공급 업체는 좋은 문서를 보유하고 있으며, 일부는 끔찍하고, 서핑 스파크 펀 (surf sparkfun) 및 digikey 및 mouser와 같은 곳에서 여러 공급 업체의 다양한 데이터 시트를 얻을 수 있습니다.

sparkfun.com, 팔 기반, avr 기반, msp430 기반 등의 것들입니다. 물론이 모든 보드는 테스트를 거쳤지 만 부팅 방법, 회로도 및 데이터 시트를 읽는 방법을 가르쳐 줄 수 있습니다 (프로그래머 참조 매뉴얼 등), 그리고이를 수행 할 수 있도록 디바이스를 프로그래밍하는 방법에 대해 설명합니다.

칩을 가져 오지 않았거나 리셋에서 부팅 한 적이 없다면 github에서 시뮬레이터를 몇 개 가지고 있습니다. 그 중 하나를 찾고 거기에서 이동하기 위해 썸휠을 검색합니다. 하드웨어/로직 버전을 시뮬레이션 할 수있는 방법이있어서 lsasim이 재미있을 것입니다. 실행중인 동안 내부 동작을 볼 수 있습니다. gcc가 칩을 부팅 할 수있는 바이너리를 빌드하는 방법에 대한 느낌을 얻을 수 있습니다.

verilog 및 vhdl을 읽을 수있는 능력이 있으면 쓰기가 더 좋습니다. 디자인을위한 "실제"문서는 소스 코드 자체입니다.

오실로스코프를 작동 할 수있는 능력. 아마도 뭔가가 왜 나오지 않았는지 알아 내고 테스트 소프트웨어를 개발하고 소프트웨어를 디버깅하는 데 사용되는 최고의 디버그 도구 일 것입니다.

자주 사용하는 인터페이스에 대한 강력한 지식을 습득하십시오. spi, i2c, mdio, serial 등. spi 버스에 몇 개의 스코프 프로브를 놓고 명령과 응답을 읽을 수 있어야합니다.

위의 버스 중 임의의 비트에 코드를 작성하여 관련 부분의 I/O 속도 기능을 초과하지 않도록 타이밍을 제어 할 수 있어야합니다.

기본 이더넷 프로토콜 및 wireshark 또는 이와 유사한 도구. 보드에 이더넷이있는 경우 해당 인터페이스를 가져와 일부 데이터를 수신하고 바이트를 구문 분석하여 패킷을 볼 수 있도록 덤프해야합니다. 간단한 패킷, arp, ping, udp을 생성 할 수 있어야합니다.

뚱뚱한 파일 시스템에 읽으십시오. SD 카드 및 기타 유사한 인터페이스가 이것을 사용합니다.

learn usb.

learn pci/pcie. TI의

DRAM

스텔라 보드는 이야기하는 방법을 알아 내려고 시도하는 주변 장치와 함께로드됩니다.

비글 회로도 또는 오픈 번째를 얻거나 컴퓨터 회로도 연결 등 모든 주요 구성 요소, D 램, 플래시, SATA, 이더넷, USB를 연구,

아, 맞다 확실히의 EEPROM을 프로그래밍하는 방법 그리고 eeproms가 죽어 가고 있지만 불행하게도 서로 더 일치합니다. 플래시 부품, 스파이, 병렬, 플러스 모든 마이크로 컨트롤러는 사용자 정의 인터페이스를 가지고, 다양한 있습니다.

jtag를 사용하는 데 익숙하지 않습니다. openocd가 좋다면, sparkfun의 ftdi 시리얼 브레이크 아웃 보드는 jtag를 비트하는 데 사용할 수 있습니다. amontek은 JTAG-Tiny를 팔이나 다른 플랫폼에 맞게 재사용 할 수 있습니다. 나는 격자 프로그래머가 또한 용도 변경 될 수 있다고 생각한다. 말하기 ... 여러 가지 fpgas를 프로그래밍하고 부팅 할 수있는 방법을 이해합니다. 마찬가지로 일부 gpio 인터페이스를 bitbanging하여 FPGA를 프로그래밍하는 방법은 종종 fpga 공급 업체가 골격 (예 : svf 플레이어)을 가지며 openocd에 백엔드를 설치하는 것과 달리 백엔드를 제공해야합니다. 일부 마이크로 컨트롤러 제품군은 칩을로드/프로그래밍하는 대체 방법으로 사용할 수있는 비 직렬, 보통 직렬 인터페이스를 가지고있다.

찾아보기, pwm, 펄스 폭 변조에 대해 알아보십시오.

vpi 및 시뮬레이션을 통해 하드웨어/hdl과 테스트 소프트웨어를 연결하는 다른 방법을 사용하면 보드에 올라 가기 전에 칩/로직 테스트 소프트웨어를 테스트하고 작성할 때 큰 이점이 있습니다.

커패시턴스가 너무 많거나 resitance가 있거나 각 (ringing)이 충분하지 않을 때 시계가 어떻게 보이는지 알 수 있습니다. 누화가 어떤지 알 수 있습니다.

솔더링이 가능합니다. 3 시간 쯤 지나면 소프트웨어 실수를 저지르고 보드를 벽돌로 만들어 버리므로 플래시가 팔리지 않아야합니다. 늑대를 부른 소년처럼 많은 도움을 얻지 못할 것입니다.

애드혹 프로그래밍을 사용하면 프로그램/도구를 빠르게 정리하면 하루에 더 많은 것을 얻을 수 있습니다.

그건 훌륭한 훈련과 인내가 필요하다는 것을 상기시켜줍니다. 테스트/디버깅을 할 때 한 번에 한 가지만 변경하십시오. 한 번에 한 가지씩 잘못 될 수있는 모든 작업을 통해 영원히 작업하여 논리적 경로를 취할 수 있습니다. 원인을 찾을 때까지 문제를 반으로 나누십시오. 가능한 모든 것을 문서화하고 저장하고 해당 데이터 콜렉션에서 관련 정보를 불러 와서 제시 할 수 있습니다. 그것을 처음으로 올바르게하십시오. 보드는 쉽게 벽돌을 만들 수 있으며 패드는 보드가 스크랩되기 전에 여러 번 재 작업을 처리 할 수 ​​있습니다. 가장 쉬운 해결책은 실수를하지 않는 것입니다. 사람의 실수로 인한 오류를 줄이는 테스트 및 테스트 설비를 만들 수 있습니다. 자신의 실수를 관리 할 수 ​​없다면 어떻게하면 생산 테스트와 관련된 사람의 실수를 줄일 수 있습니까? 문제/해결책/테스트 방법이 무엇인지에 대한 당신의 믿음을 방어하고 입증 할 수있는 능력과 용기를 가짐. 예를 들어, 다음 카드를 비 벽돌로 만드는 방법, 보드 당 얼마의 비용이들 것인지, 그리고 개발 비용으로 그 비용을 상쇄하기 위해 얼마나 절약 할 것인가가 여기에 있습니다.

귀하의 질문은 너무 넓습니다. 개방형 질문에 대한 대답은 PC 보드에 있거나 PC 보드에 연결될 수있는 모든 것을 배우는 것이 필요하다는 것입니다. 당신은 가장 낮은 수준에서 편안하게 프로그램 할 수 있어야합니다. digikey, mouser 등의 모든 데이터 시트를 완벽하게 이해할 수 있으므로 질문의 범위를 좁히면 더 많은 소화가 가능한 답을 줄 수 있습니다.

+2

Facebook의 경우 'super like'라고 말했을 것입니다. D – itisravi

관련 문제