|
@@ -186,9 +186,45 @@ static void __init l1_inst_sram_init(void)
|
|
|
#endif
|
|
|
}
|
|
|
|
|
|
+#ifdef __ADSPBF60x__
|
|
|
+static irqreturn_t l2_ecc_err(int irq, void *dev_id)
|
|
|
+{
|
|
|
+ int status;
|
|
|
+
|
|
|
+ printk(KERN_ERR "L2 ecc error happend\n");
|
|
|
+ status = bfin_read32(L2CTL0_STAT);
|
|
|
+ if (status & 0x1)
|
|
|
+ printk(KERN_ERR "Core channel error type:0x%x, addr:0x%x\n",
|
|
|
+ bfin_read32(L2CTL0_ET0), bfin_read32(L2CTL0_EADDR0));
|
|
|
+ if (status & 0x2)
|
|
|
+ printk(KERN_ERR "System channel error type:0x%x, addr:0x%x\n",
|
|
|
+ bfin_read32(L2CTL0_ET1), bfin_read32(L2CTL0_EADDR1));
|
|
|
+
|
|
|
+ status = status >> 8;
|
|
|
+ if (status)
|
|
|
+ printk(KERN_ERR "L2 Bank%d error, addr:0x%x\n",
|
|
|
+ status, bfin_read32(L2CTL0_ERRADDR0 + status));
|
|
|
+
|
|
|
+ panic("L2 Ecc error");
|
|
|
+ return IRQ_HANDLED;
|
|
|
+}
|
|
|
+#endif
|
|
|
+
|
|
|
static void __init l2_sram_init(void)
|
|
|
{
|
|
|
#if L2_LENGTH != 0
|
|
|
+
|
|
|
+#ifdef __ADSPBF60x__
|
|
|
+ int ret;
|
|
|
+
|
|
|
+ ret = request_irq(IRQ_L2CTL0_ECC_ERR, l2_ecc_err, 0, "l2-ecc-err",
|
|
|
+ NULL);
|
|
|
+ if (unlikely(ret < 0)) {
|
|
|
+ printk(KERN_INFO "Fail to request l2 ecc error interrupt");
|
|
|
+ return;
|
|
|
+ }
|
|
|
+#endif
|
|
|
+
|
|
|
free_l2_sram_head.next =
|
|
|
kmem_cache_alloc(sram_piece_cache, GFP_KERNEL);
|
|
|
if (!free_l2_sram_head.next) {
|