Пытаюсь запустить DDR3 с использованием альтеровской IP core UniPhy. От ПЛИС к DDR3 идёт дифференциальный сигнал. Так вот UniPhy требует чтобы каждое плечё этого сигнала подавалось на разные входы этой мегафункции, mem_ck и mem_ck_n. Что делаю я: в схематике рисую два output (Bank0_CK и Bank0_CKn), подключаю их к выходам mem_ck и mem_ck_n мегафункции UniPhy, делаю назначения: set_location_assignment PIN_AT20 -to Bank0_CKn set_location_assignment PIN_AR20 -to Bank0_CK (AT20 и AR20 – это диф воды) set_instance_assignment -name IO_STANDARD "DIFFERENTIAL 1.5-V SSTL CLASS I" -to Bank0_CK set_instance_assignment -name IO_STANDARD "DIFFERENTIAL 1.5-V SSTL CLASS I" -to Bank0_CKn set_instance_assignment -name OUTPUT_TERMINATION "SERIES 50 OHM WITHOUT CALIBRATION" -to Bank0_CK set_instance_assignment -name OUTPUT_TERMINATION "SERIES 50 OHM WITHOUT CALIBRATION" -to Bank0_CKn Пинпланер считает что Bank0_CKn и Bank0_CK – это диф пара, но фиттер выдаёт предупреждение: Warning: Pin "Bank0_CK" is a differential I/O pin but does not have its complement pin. Hence, fitter automatically created the complement pin "Bank0_CK(n)" После чего выдаёт ошибку: Error: Cannot place node Bank0_CK(n) in location AT20 because location already occupied by node Bank0_CKn Может кто-нибудь уже сталкивался с подобной проблемой?
|