EzDoum

찾기
처음으로 | 찾기 | 아카이브 | 글 올리기 | 링크 | 자료실 | 통계 | 연락처 | 자유게시판
이지도움 특집
전체보기
네트워크
TI OMAP35x
TI DaVinci
Analog Blackfin
RobotWar2005
임베디드!
캐쉬의 모든것
메모리 할당 알고리즘
CPU 파이프라이닝
자료구조(Tree)
금융

Login
이름

암호

기억하기


사용자 등록

현재 접속중인 등록 사용자는 0명, 익명 사용자는 4명 입니다.
전체 등록 사용자: 751명

마지막 답장
·libcurl + fuse 조합으로 되는게 많네. (1)
·Linux Ftrace에 관해 (3)
·Android MTP ( Media Transfer Protocol ) (1)
·Lighttpd에 인증을 digest 사용시 IE 오동작 문제? (1)
·Dtrace에 관해 (1)

최근글
·OpenSSL and multi-threads (0)
·ARM 환경에서 OpenCL 사용 (0)
·IoT용 WIFI 모듈 비교 ( MCU ) 클래스 (0)
·Glances - 리눅스 여러 가지 항목을 한 화면에서 모니터링 (0)
·plugin 방식의 로그 분석기 (0)

뜨거운 감자
·나는 인터렉티브한 환경에서 역어셈블 한다. (12)
·GNU REGEX (정규표현식) 프로그래밍 강좌 (7)
·SoCRobotWar 2005 - 신입생 기초 교육자료 (7)
·ASP.NET의 데이터 그리드와 사용자 컨트롤 (7)
·DHTML Editing Control (7)

가장 많이 읽은 글
·[Cache] 2-way Set-Associative 방식이란 무엇일까? (2)
·멀티쓰레드(Pthread) 프로그래밍
·GNU REGEX (정규표현식) 프로그래밍 강좌 (7)
·Sorting Algorithm Animation (2)
·SoCRobotWar 2005 - 신입생 기초 교육자료 (7)

임베디드! - I2C/SPI to UART/IrDA/GPIO
글쓴이: EzDoum 글쓴날: 2007년 01월 19일 오후 03:41
하드웨어



blackfin 에서 uart를 두개 사용할 필요가 생겼다. bf-531은 하나 뿐이어서 해결책이 필요하다. 솔류션은 software로 uart를 구현하는 것이랑 spi나 i2c로 브릿지 해주는 ic를 사용하는 것을 고려했다.

1. software uart

IAR Systems: Generic Software Uart written in C
http://supp.iar.com/Support/?note=88469
baud rate의 3배수 샘플링이 가능한 타이머 인터럽트가 있어야 한다.

AVR305: Half Duplex Compact Software UART :: AVR Freaks-
http://www.avrfreaks.net/index.php?module=FreaksTools&func=viewItem&item_id=79


2. ic 사용
ic는 찾아 보니까 필립스에서 나온게 있었다. I2C/SPI to UART/IrDA/GPIO 가능한 제품으로 딱 원하는 기능이긴 했으나 범용적인 제품이 아니라서 가격이 안맞다. 결국은 spi포트가 내장된 마이컴이 유력한 후보가 됐다.

atmel쪽 응용노트 보니까 uart, spi 컨버팅 하는 예제
http://www.atmel.com/dyn/resources/prod_documents/doc2557.pdf
http://www.avrfreaks.net/index.php?module=Freaks%20Tools&func=viewItem&item_id=641

블랙핀 spi 구조도
http://docs.blackfin.uclinux.org/doku.php?id=spi

첨부는 필립스 브릿지IC

  • 첨부 파일: Philips_BridgeICs.pdf Philips_BridgeICs.pdf (150 KiB(154,103 Bytes))

    [분류: 하드웨어 인쇄용 페이지 본문 email로 보내기 ]

  • <  책으로 받은 보너스 | 아직도 가야 할 길 : 스캇 펙 박사의  >
    임베디드! - I2C/SPI to UART/IrDA/GPIO | 답장: 1개 | 본문에 답장
    정렬 :  
    답장 EzDoum 2007년 01월 19일 오후 03:52 [ 이글에 답장 | 본문에 답장 | 책갈피 ]
    SS_ Pin Functionality

    #Slave Mode

    When the SPI is configured as a Slave, the Slave Select (SS) pin is always input. When SS_ is held low, the SPI is activated, and MISO becomes an output if configured so by the user. All other pins are inputs. When SS_ is driven high, all pins are inputs, and the SPI is passive, which means that it will not receive incoming data. Note that the SPI logic will be reset once the SS_ pin is driven high.

    The SS_ pin is useful for packet/byte synchronization to keep the Slave bit counter synchronous with the master clock generator. When the SS_ pin is driven high, the SPI Slave will immediately reset the send and receive logic, and drop any partially received data in the Shift Register.

    # Master Mode


    When the SPI is configured as a Master (MSTR in SPCR is set), the user can determine the direction of the SS_ pin.

    If SS_ is configured as an output, the pin is a general output pin which does not affect the SPI system. Typically, the pin will be driving the SS_ pin of the SPI Slave.

    If SS_ is configured as an input, it must be held high to ensure Master SPI operation. If the SS_ pin is driven low by peripheral circuitry when the SPI is configured as a Master with the SS_ pin defined as an input, the SPI system interprets this as another Master selecting the SPI as a Slave and starting to send data to it. To avoid bus contention, the SPI system takes the following actions:

    1. The MSTR bit in SPCR is cleared and the SPI system becomes a Slave. As a
    result of the SPI becoming a Slave, the MOSI and SCK pins become inputs.

    2. The SPIF Flag in SPSR is set, and if the SPI interrupt is enabled, and the I-bit in
    SREG is set, the interrupt routine will be executed.

    Thus, when interrupt-driven SPI transmission is used in Master mode, and there exists a possibility that SS_ is driven low, the interrupt should always check that the MSTR bit is still set. If the MSTR bit has been cleared by a Slave Select, it must be set by the user to re-enable SPI Master mode.


    [수정]

    임베디드! - I2C/SPI to UART/IrDA/GPIO | 답장: 1개 | 본문에 답장
    정렬 :  

    답장 쓰기
    글을 올리시려면 로그인 (사용자 등록) 하셔야 합니다.

    검색
    Google

    분류
    ·공지 (6)
    ·인터넷 (87)
    ·하드웨어 (260)
    ·C/C++ (65)
    ·어셈블리 (7)
    ·리눅스 (136)
    ·리눅스 커널 (67)
    ·윈도우즈 (25)
    ·데이터베이스 (20)
    ·보안 (16)
    ·.NET (25)
    ·그래픽 (13)
    ·책소개 (42)
    ·호기심 천국 (80)
    ·잡담 (111)
    ·사랑 (3)

    전체 본문수: 963
    전체 답장수: 525


    분류 : 하드웨어
    최근글
    최근글
    가장 많이 읽은 글
    ·[Cache] 2-way Set-Associative 방식이란 무엇일까? (2)
    뜨거운 감자
    ·SoCRobotWar 2005 - 신입생 기초 교육자료 (7)

    EzDoum투표
    이지도움 어때요?
    이게 뭐야. 다시 안올란다. --;
    아이 좋아라~ +_+;
    관심없다.
    먼가는 있는거 같은데 뭐하는 곳이지?
    기타 (자유게시판에 글로 남겨 주세요)
    [ 결과 | 투표 ]

    랜덤 링크
    http://kldp.net


     Home ^ BACK TO TOP ^ EzDoum - 도움이 필요하세요~??
     Powered by KorWeblog 1.5.8 Copyleft © 2001 EzDoum, 관리자: EzDoum