도와주세요!!
글 수 15,339
2009.06.30 15:21:12 (*.178.74.253)
7295
안녕하세요 ^^
저는 DVR 회사에다니는 김정훈 입니다.
다름이 아니고 Silicon Image 의 3114드라이버를 포팅하려고 하고있습니다.
아직 하드웨어가 나오진 않은 상태라서 S3C2800 을 사용하는 EZ-M28 에 Silicon Image 3114
PCI카드를 꼽고 포팅테스트를 진행하고 있습니다.
kelp나 구글링해서 찾은 정보에 의하면 2.4.26커널드라이버중 SCSI부분이 문제가 있어서
2.4.36으로 SCSI부분을 업그레이드해야한다고 들었습니다.
그래서 2.4.26 드라이버에 2.4.36 SCSI부분은 포팅하였는데 각포트(4포트)의 tf( task file) 레지스터에대해
Readb/Writeb 를 수행하게 되면 "Internal Register Space – Base Address 5"레지스터 전체(1024Byte)의 가상주소
가 깨지는 증상을 확인하였습니다.
아래 참고1의 tf offset(0x80, 0xC0, 0x280, 0x2C0) 을 read/write 하게되면 0xFF가 읽히고 ioremap 한 Base Address 5 레지스터의 가상
주소전체가 0xFF로 읽힙니다.
tf레지스터를 읽지않고 tf이외의 다른 레지스터(ctl, bmdma, scr, sien, xfer_mode .. 등등) 을 읽을때는 정상 입니다.
그런데 위에서말씀드렸듯이 tf레지스터를 한번이라도 read/write를 시도하게되면 Base Address 5 레지스터 전체가 0xFF로 변경되고 write 도 분가능한 상태가 됨니다.
참고 1:
/* per-port register offsets */
/* TODO: we can probably calculate rather than use a table */
static const struct {
unsigned long tf; /* ATA taskfile register block */
unsigned long ctl; /* ATA control/altstatus register block */
unsigned long bmdma; /* DMA register block */
unsigned long scr; /* SATA control register block */
unsigned long sien; /* SATA Interrupt Enable register */
unsigned long xfer_mode;/* data transfer mode register */
} sil_port[] = {
/* port 0 ... */
{ 0x80, 0x8A, 0x00, 0x100, 0x148, 0xb4 },
{ 0xC0, 0xCA, 0x08, 0x180, 0x1c8, 0xf4 },
{ 0x280, 0x28A, 0x200, 0x300, 0x348, 0x2b4 },
{ 0x2C0, 0x2CA, 0x208, 0x380, 0x3c8, 0x2f4 },
/* ... port 3 */
};
참고 2: Base Address 5 레지스터 덤프메시지중 일부입니다.
[445 sil_init_one sata_sil.c] addr = 0xc2800070 data = 0xff
[445 sil_init_one sata_sil.c] addr = 0xc2800071 data = 0xff
[445 sil_init_one sata_sil.c] addr = 0xc2800072 data = 0xff
[445 sil_init_one sata_sil.c] addr = 0xc2800073 data = 0xff
[445 sil_init_one sata_sil.c] addr = 0xc2800074 data = 0x0
[445 sil_init_one sata_sil.c] addr = 0xc2800075 data = 0x0
[445 sil_init_one sata_sil.c] addr = 0xc2800076 data = 0xe5
[445 sil_init_one sata_sil.c] addr = 0xc2800077 data = 0x67
[445 sil_init_one sata_sil.c] addr = 0xc2800078 data = 0x0
[445 sil_init_one sata_sil.c] addr = 0xc2800079 data = 0x0
[445 sil_init_one sata_sil.c] addr = 0xc280007a data = 0x0
[445 sil_init_one sata_sil.c] addr = 0xc280007b data = 0x0
[445 sil_init_one sata_sil.c] addr = 0xc280007c data = 0x0
[445 sil_init_one sata_sil.c] addr = 0xc280007d data = 0x0
[445 sil_init_one sata_sil.c] addr = 0xc280007e data = 0x0
[445 sil_init_one sata_sil.c] addr = 0xc280007f data = 0x0
[445 sil_init_one sata_sil.c] addr = 0xc2800080 data = 0xff <<무조건 이번지만 접근하면
[445 sil_init_one sata_sil.c] addr = 0xc2800081 data = 0xff Base Address 5 레지스터 전체가 0xFF로 변경>>
[445 sil_init_one sata_sil.c] addr = 0xc2800082 data = 0xff
[445 sil_init_one sata_sil.c] addr = 0xc2800083 data = 0xff
[445 sil_init_one sata_sil.c] addr = 0xc2800084 data = 0xff
[445 sil_init_one sata_sil.c] addr = 0xc2800085 data = 0xff
[445 sil_init_one sata_sil.c] addr = 0xc2800086 data = 0xff
[445 sil_init_one sata_sil.c] addr = 0xc2800087 data = 0xff
[445 sil_init_one sata_sil.c] addr = 0xc2800088 data = 0xff
[445 sil_init_one sata_sil.c] addr = 0xc2800089 data = 0xff
바쁘신시간 와중에도 저의 글을 끝까지 읽어주셔서 정말 감사합니다.
일정이 한달넘구 두달 다되어가니 눈치도 보이고, 야근에 힘도들고
그래서 이렇게 도움을 청합니다.
감사합니다.
저는 DVR 회사에다니는 김정훈 입니다.
다름이 아니고 Silicon Image 의 3114드라이버를 포팅하려고 하고있습니다.
아직 하드웨어가 나오진 않은 상태라서 S3C2800 을 사용하는 EZ-M28 에 Silicon Image 3114
PCI카드를 꼽고 포팅테스트를 진행하고 있습니다.
kelp나 구글링해서 찾은 정보에 의하면 2.4.26커널드라이버중 SCSI부분이 문제가 있어서
2.4.36으로 SCSI부분을 업그레이드해야한다고 들었습니다.
그래서 2.4.26 드라이버에 2.4.36 SCSI부분은 포팅하였는데 각포트(4포트)의 tf( task file) 레지스터에대해
Readb/Writeb 를 수행하게 되면 "Internal Register Space – Base Address 5"레지스터 전체(1024Byte)의 가상주소
가 깨지는 증상을 확인하였습니다.
아래 참고1의 tf offset(0x80, 0xC0, 0x280, 0x2C0) 을 read/write 하게되면 0xFF가 읽히고 ioremap 한 Base Address 5 레지스터의 가상
주소전체가 0xFF로 읽힙니다.
tf레지스터를 읽지않고 tf이외의 다른 레지스터(ctl, bmdma, scr, sien, xfer_mode .. 등등) 을 읽을때는 정상 입니다.
그런데 위에서말씀드렸듯이 tf레지스터를 한번이라도 read/write를 시도하게되면 Base Address 5 레지스터 전체가 0xFF로 변경되고 write 도 분가능한 상태가 됨니다.
참고 1:
/* per-port register offsets */
/* TODO: we can probably calculate rather than use a table */
static const struct {
unsigned long tf; /* ATA taskfile register block */
unsigned long ctl; /* ATA control/altstatus register block */
unsigned long bmdma; /* DMA register block */
unsigned long scr; /* SATA control register block */
unsigned long sien; /* SATA Interrupt Enable register */
unsigned long xfer_mode;/* data transfer mode register */
} sil_port[] = {
/* port 0 ... */
{ 0x80, 0x8A, 0x00, 0x100, 0x148, 0xb4 },
{ 0xC0, 0xCA, 0x08, 0x180, 0x1c8, 0xf4 },
{ 0x280, 0x28A, 0x200, 0x300, 0x348, 0x2b4 },
{ 0x2C0, 0x2CA, 0x208, 0x380, 0x3c8, 0x2f4 },
/* ... port 3 */
};
참고 2: Base Address 5 레지스터 덤프메시지중 일부입니다.
[445 sil_init_one sata_sil.c] addr = 0xc2800070 data = 0xff
[445 sil_init_one sata_sil.c] addr = 0xc2800071 data = 0xff
[445 sil_init_one sata_sil.c] addr = 0xc2800072 data = 0xff
[445 sil_init_one sata_sil.c] addr = 0xc2800073 data = 0xff
[445 sil_init_one sata_sil.c] addr = 0xc2800074 data = 0x0
[445 sil_init_one sata_sil.c] addr = 0xc2800075 data = 0x0
[445 sil_init_one sata_sil.c] addr = 0xc2800076 data = 0xe5
[445 sil_init_one sata_sil.c] addr = 0xc2800077 data = 0x67
[445 sil_init_one sata_sil.c] addr = 0xc2800078 data = 0x0
[445 sil_init_one sata_sil.c] addr = 0xc2800079 data = 0x0
[445 sil_init_one sata_sil.c] addr = 0xc280007a data = 0x0
[445 sil_init_one sata_sil.c] addr = 0xc280007b data = 0x0
[445 sil_init_one sata_sil.c] addr = 0xc280007c data = 0x0
[445 sil_init_one sata_sil.c] addr = 0xc280007d data = 0x0
[445 sil_init_one sata_sil.c] addr = 0xc280007e data = 0x0
[445 sil_init_one sata_sil.c] addr = 0xc280007f data = 0x0
[445 sil_init_one sata_sil.c] addr = 0xc2800080 data = 0xff <<무조건 이번지만 접근하면
[445 sil_init_one sata_sil.c] addr = 0xc2800081 data = 0xff Base Address 5 레지스터 전체가 0xFF로 변경>>
[445 sil_init_one sata_sil.c] addr = 0xc2800082 data = 0xff
[445 sil_init_one sata_sil.c] addr = 0xc2800083 data = 0xff
[445 sil_init_one sata_sil.c] addr = 0xc2800084 data = 0xff
[445 sil_init_one sata_sil.c] addr = 0xc2800085 data = 0xff
[445 sil_init_one sata_sil.c] addr = 0xc2800086 data = 0xff
[445 sil_init_one sata_sil.c] addr = 0xc2800087 data = 0xff
[445 sil_init_one sata_sil.c] addr = 0xc2800088 data = 0xff
[445 sil_init_one sata_sil.c] addr = 0xc2800089 data = 0xff
바쁘신시간 와중에도 저의 글을 끝까지 읽어주셔서 정말 감사합니다.
일정이 한달넘구 두달 다되어가니 눈치도 보이고, 야근에 힘도들고
그래서 이렇게 도움을 청합니다.
감사합니다.