{
        mpic_setup_this_cpu();
 }
+
+void mpic_reset_core(int cpu)
+{
+       struct mpic *mpic = mpic_primary;
+       u32 pir;
+       int cpuid = get_hard_smp_processor_id(cpu);
+
+       /* Set target bit for core reset */
+       pir = mpic_read(mpic->gregs, MPIC_INFO(GREG_PROCESSOR_INIT));
+       pir |= (1 << cpuid);
+       mpic_write(mpic->gregs, MPIC_INFO(GREG_PROCESSOR_INIT), pir);
+       mpic_read(mpic->gregs, MPIC_INFO(GREG_PROCESSOR_INIT));
+
+       /* Restore target bit after reset complete */
+       pir &= ~(1 << cpuid);
+       mpic_write(mpic->gregs, MPIC_INFO(GREG_PROCESSOR_INIT), pir);
+       mpic_read(mpic->gregs, MPIC_INFO(GREG_PROCESSOR_INIT));
+}
 #endif /* CONFIG_SMP */
 
 #ifdef CONFIG_PM
 
 extern int mpic_set_irq_type(unsigned int virq, unsigned int flow_type);
 extern void mpic_set_vector(unsigned int virq, unsigned int vector);
 extern int mpic_set_affinity(unsigned int irq, const struct cpumask *cpumask);
+extern void mpic_reset_core(int cpu);
 
 #endif /* _POWERPC_SYSDEV_MPIC_H */