static struct atmel_ssc_info ssc_info[NUM_SSC_DEVICES] = {
        {
        .name           = "ssc0",
-       .lock           = __SPIN_LOCK_UNLOCKED(ssc_info[0].lock),
        .dir_mask       = SSC_DIR_MASK_UNUSED,
        .initialized    = 0,
        },
        {
        .name           = "ssc1",
-       .lock           = __SPIN_LOCK_UNLOCKED(ssc_info[1].lock),
        .dir_mask       = SSC_DIR_MASK_UNUSED,
        .initialized    = 0,
        },
        {
        .name           = "ssc2",
-       .lock           = __SPIN_LOCK_UNLOCKED(ssc_info[2].lock),
        .dir_mask       = SSC_DIR_MASK_UNUSED,
        .initialized    = 0,
        },
 
        snd_soc_dai_set_dma_data(dai, substream, dma_params);
 
-       spin_lock_irq(&ssc_p->lock);
-       if (ssc_p->dir_mask & dir_mask) {
-               spin_unlock_irq(&ssc_p->lock);
+       if (ssc_p->dir_mask & dir_mask)
                return -EBUSY;
-       }
+
        ssc_p->dir_mask |= dir_mask;
-       spin_unlock_irq(&ssc_p->lock);
 
        return 0;
 }
 
        dir_mask = 1 << dir;
 
-       spin_lock_irq(&ssc_p->lock);
        ssc_p->dir_mask &= ~dir_mask;
        if (!ssc_p->dir_mask) {
                if (ssc_p->initialized) {
                ssc_p->cmr_div = ssc_p->tcmr_period = ssc_p->rcmr_period = 0;
                ssc_p->forced_divider = 0;
        }
-       spin_unlock_irq(&ssc_p->lock);
 
        /* Shutdown the SSC clock. */
        pr_debug("atmel_ssc_dai: Stopping clock\n");