Roy Huang | 088eec1 | 2007-06-21 11:34:16 +0800 | [diff] [blame] | 1 | /* |
Mike Frysinger | 287050f | 2007-07-24 15:23:20 +0800 | [diff] [blame] | 2 | * File: include/asm-blackfin/mach-bf548/anomaly.h |
| 3 | * Bugs: Enter bugs at http://blackfin.uclinux.org/ |
Roy Huang | 088eec1 | 2007-06-21 11:34:16 +0800 | [diff] [blame] | 4 | * |
Mike Frysinger | 287050f | 2007-07-24 15:23:20 +0800 | [diff] [blame] | 5 | * Copyright (C) 2004-2007 Analog Devices Inc. |
| 6 | * Licensed under the GPL-2 or later. |
Roy Huang | 088eec1 | 2007-06-21 11:34:16 +0800 | [diff] [blame] | 7 | */ |
| 8 | |
Mike Frysinger | 1aafd90 | 2007-07-25 11:19:14 +0800 | [diff] [blame] | 9 | /* This file shoule be up to date with: |
Mike Frysinger | 7cc1c4b | 2007-12-24 20:05:09 +0800 | [diff] [blame] | 10 | * - Revision E, 11/28/2007; ADSP-BF542/BF544/BF547/BF548/BF549 Blackfin Processor Anomaly List |
Mike Frysinger | 1aafd90 | 2007-07-25 11:19:14 +0800 | [diff] [blame] | 11 | */ |
| 12 | |
Roy Huang | 088eec1 | 2007-06-21 11:34:16 +0800 | [diff] [blame] | 13 | #ifndef _MACH_ANOMALY_H_ |
| 14 | #define _MACH_ANOMALY_H_ |
Mike Frysinger | 287050f | 2007-07-24 15:23:20 +0800 | [diff] [blame] | 15 | |
Mike Frysinger | 1aafd90 | 2007-07-25 11:19:14 +0800 | [diff] [blame] | 16 | /* Multi-Issue Instruction with dsp32shiftimm in slot1 and P-reg Store in slot 2 Not Supported */ |
| 17 | #define ANOMALY_05000074 (1) |
| 18 | /* DMA_RUN Bit Is Not Valid after a Peripheral Receive Channel DMA Stops */ |
| 19 | #define ANOMALY_05000119 (1) |
| 20 | /* Rx.H Cannot Be Used to Access 16-bit System MMR Registers */ |
| 21 | #define ANOMALY_05000122 (1) |
| 22 | /* Spurious Hardware Error from an Access in the Shadow of a Conditional Branch */ |
| 23 | #define ANOMALY_05000245 (1) |
Mike Frysinger | 1aafd90 | 2007-07-25 11:19:14 +0800 | [diff] [blame] | 24 | /* Sensitivity To Noise with Slow Input Edge Rates on External SPORT TX and RX Clocks */ |
| 25 | #define ANOMALY_05000265 (1) |
| 26 | /* Certain Data Cache Writethrough Modes Fail for Vddint <= 0.9V */ |
| 27 | #define ANOMALY_05000272 (1) |
Mike Frysinger | 60e9356 | 2007-07-25 11:56:01 +0800 | [diff] [blame] | 28 | /* False Hardware Error Exception when ISR context is not restored */ |
Mike Frysinger | 7cc1c4b | 2007-12-24 20:05:09 +0800 | [diff] [blame] | 29 | #define ANOMALY_05000281 (__SILICON_REVISION__ < 1) |
Mike Frysinger | bc8c84c | 2007-08-05 17:32:25 +0800 | [diff] [blame] | 30 | /* SSYNCs After Writes To CAN/DMA MMR Registers Are Not Always Handled Correctly */ |
Mike Frysinger | 7cc1c4b | 2007-12-24 20:05:09 +0800 | [diff] [blame] | 31 | #define ANOMALY_05000304 (__SILICON_REVISION__ < 1) |
Mike Frysinger | 1aafd90 | 2007-07-25 11:19:14 +0800 | [diff] [blame] | 32 | /* False Hardware Errors Caused by Fetches at the Boundary of Reserved Memory */ |
| 33 | #define ANOMALY_05000310 (1) |
| 34 | /* Errors When SSYNC, CSYNC, or Loads to LT, LB and LC Registers Are Interrupted */ |
Mike Frysinger | 7cc1c4b | 2007-12-24 20:05:09 +0800 | [diff] [blame] | 35 | #define ANOMALY_05000312 (__SILICON_REVISION__ < 1) |
Mike Frysinger | 1aafd90 | 2007-07-25 11:19:14 +0800 | [diff] [blame] | 36 | /* TWI Slave Boot Mode Is Not Functional */ |
Mike Frysinger | 7cc1c4b | 2007-12-24 20:05:09 +0800 | [diff] [blame] | 37 | #define ANOMALY_05000324 (__SILICON_REVISION__ < 1) |
Mike Frysinger | 1aafd90 | 2007-07-25 11:19:14 +0800 | [diff] [blame] | 38 | /* External FIFO Boot Mode Is Not Functional */ |
Mike Frysinger | 7cc1c4b | 2007-12-24 20:05:09 +0800 | [diff] [blame] | 39 | #define ANOMALY_05000325 (__SILICON_REVISION__ < 1) |
Mike Frysinger | 1aafd90 | 2007-07-25 11:19:14 +0800 | [diff] [blame] | 40 | /* Data Lost When Core and DMA Accesses Are Made to the USB FIFO Simultaneously */ |
Mike Frysinger | 7cc1c4b | 2007-12-24 20:05:09 +0800 | [diff] [blame] | 41 | #define ANOMALY_05000327 (__SILICON_REVISION__ < 1) |
Mike Frysinger | 1aafd90 | 2007-07-25 11:19:14 +0800 | [diff] [blame] | 42 | /* Incorrect Access of OTP_STATUS During otp_write() Function */ |
Mike Frysinger | 7cc1c4b | 2007-12-24 20:05:09 +0800 | [diff] [blame] | 43 | #define ANOMALY_05000328 (__SILICON_REVISION__ < 1) |
Mike Frysinger | 1aafd90 | 2007-07-25 11:19:14 +0800 | [diff] [blame] | 44 | /* Synchronous Burst Flash Boot Mode Is Not Functional */ |
Mike Frysinger | 7cc1c4b | 2007-12-24 20:05:09 +0800 | [diff] [blame] | 45 | #define ANOMALY_05000329 (__SILICON_REVISION__ < 1) |
Mike Frysinger | 1aafd90 | 2007-07-25 11:19:14 +0800 | [diff] [blame] | 46 | /* Host DMA Boot Mode Is Not Functional */ |
Mike Frysinger | 7cc1c4b | 2007-12-24 20:05:09 +0800 | [diff] [blame] | 47 | #define ANOMALY_05000330 (__SILICON_REVISION__ < 1) |
Mike Frysinger | 1aafd90 | 2007-07-25 11:19:14 +0800 | [diff] [blame] | 48 | /* Inadequate Timing Margins on DDR DQS to DQ and DQM Skew */ |
Mike Frysinger | 7cc1c4b | 2007-12-24 20:05:09 +0800 | [diff] [blame] | 49 | #define ANOMALY_05000334 (__SILICON_REVISION__ < 1) |
Mike Frysinger | 1aafd90 | 2007-07-25 11:19:14 +0800 | [diff] [blame] | 50 | /* Inadequate Rotary Debounce Logic Duration */ |
Mike Frysinger | 7cc1c4b | 2007-12-24 20:05:09 +0800 | [diff] [blame] | 51 | #define ANOMALY_05000335 (__SILICON_REVISION__ < 1) |
Mike Frysinger | 1aafd90 | 2007-07-25 11:19:14 +0800 | [diff] [blame] | 52 | /* Phantom Interrupt Occurs After First Configuration of Host DMA Port */ |
Mike Frysinger | 7cc1c4b | 2007-12-24 20:05:09 +0800 | [diff] [blame] | 53 | #define ANOMALY_05000336 (__SILICON_REVISION__ < 1) |
Mike Frysinger | 1aafd90 | 2007-07-25 11:19:14 +0800 | [diff] [blame] | 54 | /* Disallowed Configuration Prevents Subsequent Allowed Configuration on Host DMA Port */ |
Mike Frysinger | 7cc1c4b | 2007-12-24 20:05:09 +0800 | [diff] [blame] | 55 | #define ANOMALY_05000337 (__SILICON_REVISION__ < 1) |
Mike Frysinger | 1aafd90 | 2007-07-25 11:19:14 +0800 | [diff] [blame] | 56 | /* Slave-Mode SPI0 MISO Failure With CPHA = 0 */ |
Mike Frysinger | 7cc1c4b | 2007-12-24 20:05:09 +0800 | [diff] [blame] | 57 | #define ANOMALY_05000338 (__SILICON_REVISION__ < 1) |
Mike Frysinger | bc8c84c | 2007-08-05 17:32:25 +0800 | [diff] [blame] | 58 | /* If Memory Reads Are Enabled on SDH or HOSTDP, Other DMAC1 Peripherals Cannot Read */ |
Mike Frysinger | 7cc1c4b | 2007-12-24 20:05:09 +0800 | [diff] [blame] | 59 | #define ANOMALY_05000340 (__SILICON_REVISION__ < 1) |
Mike Frysinger | bc8c84c | 2007-08-05 17:32:25 +0800 | [diff] [blame] | 60 | /* Boot Host Wait (HWAIT) and Boot Host Wait Alternate (HWAITA) Signals Are Swapped */ |
Mike Frysinger | 7cc1c4b | 2007-12-24 20:05:09 +0800 | [diff] [blame] | 61 | #define ANOMALY_05000344 (__SILICON_REVISION__ < 1) |
Mike Frysinger | bc8c84c | 2007-08-05 17:32:25 +0800 | [diff] [blame] | 62 | /* USB Calibration Value Is Not Intialized */ |
Mike Frysinger | 7cc1c4b | 2007-12-24 20:05:09 +0800 | [diff] [blame] | 63 | #define ANOMALY_05000346 (__SILICON_REVISION__ < 1) |
Mike Frysinger | bc8c84c | 2007-08-05 17:32:25 +0800 | [diff] [blame] | 64 | /* Boot ROM Kernel Incorrectly Alters Reset Value of USB Register */ |
Mike Frysinger | 7cc1c4b | 2007-12-24 20:05:09 +0800 | [diff] [blame] | 65 | #define ANOMALY_05000347 (__SILICON_REVISION__ < 1) |
Mike Frysinger | bc8c84c | 2007-08-05 17:32:25 +0800 | [diff] [blame] | 66 | /* Data Lost when Core Reads SDH Data FIFO */ |
Mike Frysinger | 7cc1c4b | 2007-12-24 20:05:09 +0800 | [diff] [blame] | 67 | #define ANOMALY_05000349 (__SILICON_REVISION__ < 1) |
Mike Frysinger | bc8c84c | 2007-08-05 17:32:25 +0800 | [diff] [blame] | 68 | /* PLL Status Register Is Inaccurate */ |
Mike Frysinger | 7cc1c4b | 2007-12-24 20:05:09 +0800 | [diff] [blame] | 69 | #define ANOMALY_05000351 (__SILICON_REVISION__ < 1) |
| 70 | /* Serial Port (SPORT) Multichannel Transmit Failure when Channel 0 Is Disabled */ |
| 71 | #define ANOMALY_05000357 (1) |
| 72 | /* External Memory Read Access Hangs Core With PLL Bypass */ |
| 73 | #define ANOMALY_05000360 (1) |
| 74 | /* DMAs that Go Urgent during Tight Core Writes to External Memory Are Blocked */ |
| 75 | #define ANOMALY_05000365 (1) |
| 76 | /* Addressing Conflict between Boot ROM and Asynchronous Memory */ |
| 77 | #define ANOMALY_05000369 (1) |
Mike Frysinger | a70ce07 | 2008-05-31 15:47:17 +0800 | [diff] [blame] | 78 | /* Possible RETS Register Corruption when Subroutine Is under 5 Cycles in Duration */ |
| 79 | #define ANOMALY_05000371 (1) |
Mike Frysinger | 7cc1c4b | 2007-12-24 20:05:09 +0800 | [diff] [blame] | 80 | /* Mobile DDR Operation Not Functional */ |
| 81 | #define ANOMALY_05000377 (1) |
| 82 | /* Security/Authentication Speedpath Causes Authentication To Fail To Initiate */ |
| 83 | #define ANOMALY_05000378 (1) |
Roy Huang | 088eec1 | 2007-06-21 11:34:16 +0800 | [diff] [blame] | 84 | |
Mike Frysinger | 1aafd90 | 2007-07-25 11:19:14 +0800 | [diff] [blame] | 85 | /* Anomalies that don't exist on this proc */ |
| 86 | #define ANOMALY_05000125 (0) |
Bryan Wu | 2cbfe10 | 2007-08-05 15:31:16 +0800 | [diff] [blame] | 87 | #define ANOMALY_05000158 (0) |
Mike Frysinger | 1aafd90 | 2007-07-25 11:19:14 +0800 | [diff] [blame] | 88 | #define ANOMALY_05000183 (0) |
| 89 | #define ANOMALY_05000198 (0) |
Mike Frysinger | 0174dd5 | 2007-08-05 16:53:10 +0800 | [diff] [blame] | 90 | #define ANOMALY_05000230 (0) |
Mike Frysinger | 1aafd90 | 2007-07-25 11:19:14 +0800 | [diff] [blame] | 91 | #define ANOMALY_05000244 (0) |
Mike Frysinger | 60e9356 | 2007-07-25 11:56:01 +0800 | [diff] [blame] | 92 | #define ANOMALY_05000261 (0) |
Mike Frysinger | 1aafd90 | 2007-07-25 11:19:14 +0800 | [diff] [blame] | 93 | #define ANOMALY_05000263 (0) |
| 94 | #define ANOMALY_05000266 (0) |
| 95 | #define ANOMALY_05000273 (0) |
| 96 | #define ANOMALY_05000311 (0) |
Michael Hennerich | 2b39331 | 2007-10-10 16:58:49 +0800 | [diff] [blame] | 97 | #define ANOMALY_05000323 (0) |
Sonic Zhang | 4d55563 | 2008-04-25 03:28:10 +0800 | [diff] [blame] | 98 | #define ANOMALY_05000363 (0) |
Mike Frysinger | 1aafd90 | 2007-07-25 11:19:14 +0800 | [diff] [blame] | 99 | |
| 100 | #endif |