Uart 칩 16c2550 EMIF 확장시 IO 매핑문제

rev7707의 이미지

안녕하세요.
저는 Ti dm368 칩을 이용해 제품 개발을 하고 있구요.
시리얼이 추가로 하나 더 필요해서 16C2550을 달았는데 문제가 생겼습니다.

IO 어드레스 매핑은 아래와 같이 되어있는데요.
실제 하드웨어 라인도 아래와 같이 구성되어 있습니다.
0x1C00 0000 ~ 1FF FFFF : 각종IO
0x200 0000 ~ 0x3FF FFFF : EMIF data(CE0) - nand flash
0x400 0000 ~ 0x5FF FFFF : EMIF data(CE1) - 16c2550
부트로더에서는 0x4000000번지에 읽고 쓰고 칩도 정상 동작합니다.
그런데 문제는 커널에서 0x400 000 에 read나 write를 하면 커널 패닉이 납니다.
시리얼드라이버가 그 주소에 접근해서 초기화를 해야하는 데 말이죠..
메시지는 아래와 같습니다.(fe000001은 0x4000000의 가상메모리주소)
"Unable to handle kernel paging request at virtual address fe000001"

커널 소스를 확인해 보니 io.h에 아래와 같이 0x1C00000~1CFF FFFF 까지만
영역이 지정되어 있다라구요.

#define IO_PHYS 0x01c00000
#define IO_OFFSET 0xfa000000 /* Virtual IO = 0xfbc00000 */
#define IO_SIZE 0x00400000
#define IO_VIRT (IO_PHYS + IO_OFFSET)
#define io_p2v(pa) ((pa) + IO_OFFSET)
#define io_v2p(va) ((va) - IO_OFFSET)
#define IO_ADDRESS(x) io_p2v(x)

그래서 IO 영역을 시리얼 IO까지 접근할 수 있도록
1c00 0000~ 6000000이 되도록 IO_SIZE를 수정했더니 커널이 뻗어 버리네요.

이쪽에 경험이 부족해서 답이 안나오네요.
이거 어떻게 해결해야 할까요..?

태훈의 이미지

가상 주소 0xfe000001를 물리 주소 0x4000000에 ioremap() 함수로 매핑 하셨나요?

리눅스 커널 코드 내에 참조 할 만한 코드가 많겠지만 한가지 예를 들면,

arch/arm/plat-orion/common.c에서 UART 관련 루틴을 참고 하십시오.

- 관련 함수: orion_uart0_init(), uart_complete(), fill_resource()
- 관련 자료구조: orion_uart0, orion_uart0_data, orion_uart0_resources

그대로 구현하시고 orion_uart0_init 함수를 호출하는 부분의 인자를 현재 플랫폼에 맞추어 주시면 됩니다.

리눅스 커널 컴파일 설정시 8250 드라이버 추가 해 주시고요.

Just do it!

익명 사용자의 이미지

성공하시면 방법 좀 알려주세요...
저도 지금 emif로 uart 확장해야 되는데(4개 --;)
할려니 막막하네요.

익명 사용자의 이미지

저도 emif에 exar uart 칩 묶어서 작업중인데
read, write 동작이 이상하네요.
혹시 성공하셨으면 조언 부탁드립니다.

익명 사용자의 이미지

저도 emif에 exar uart 칩 묶어서 작업중인데
read, write 동작이 이상하네요.
혹시 성공하셨으면 조언 부탁드립니다.

댓글 달기

Filtered HTML

  • 텍스트에 BBCode 태그를 사용할 수 있습니다. URL은 자동으로 링크 됩니다.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>
  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.

BBCode

  • 텍스트에 BBCode 태그를 사용할 수 있습니다. URL은 자동으로 링크 됩니다.
  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param>
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.

Textile

  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • You can use Textile markup to format text.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>

Markdown

  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • Quick Tips:
    • Two or more spaces at a line's end = Line break
    • Double returns = Paragraph
    • *Single asterisks* or _single underscores_ = Emphasis
    • **Double** or __double__ = Strong
    • This is [a link](http://the.link.example.com "The optional title text")
    For complete details on the Markdown syntax, see the Markdown documentation and Markdown Extra documentation for tables, footnotes, and more.
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>

Plain text

  • HTML 태그를 사용할 수 없습니다.
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.
  • 줄과 단락은 자동으로 분리됩니다.
댓글 첨부 파일
이 댓글에 이미지나 파일을 업로드 합니다.
파일 크기는 8 MB보다 작아야 합니다.
허용할 파일 형식: txt pdf doc xls gif jpg jpeg mp3 png rar zip.
CAPTCHA
이것은 자동으로 스팸을 올리는 것을 막기 위해서 제공됩니다.