83 lines
2.5 KiB
C
83 lines
2.5 KiB
C
/* Copyright (c) 2015, The Linux Foundation. All rights reserved.
|
|
*
|
|
* This program is free software; you can redistribute it and/or modify
|
|
* it under the terms of the GNU General Public License version 2 and
|
|
* only version 2 as published by the Free Software Foundation.
|
|
*
|
|
* This program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU General Public License for more details.
|
|
*/
|
|
#ifndef __WSA881X_IRQ_H__
|
|
#define __WSA881X_IRQ_H__
|
|
|
|
#include <linux/irqdomain.h>
|
|
#include <linux/interrupt.h>
|
|
#include <sound/soc.h>
|
|
|
|
/**
|
|
* enum wsa_interrupts - wsa interrupt number
|
|
* @WSA_INT_SAF2WAR: Temp irq interrupt, from safe state to warning state.
|
|
* @WSA_INT_WAR2SAF: Temp irq interrupt, from warning state to safe state.
|
|
* @WSA_INT_DISABLE: Disable Temp sensor interrupts.
|
|
* @WSA_INT_OCP: OCP interrupt.
|
|
* @WSA_INT_CLIP: CLIP detect interrupt.
|
|
* @WSA_NUM_IRQS: MAX Interrupt number.
|
|
*
|
|
* WSA IRQ Interrupt numbers.
|
|
*/
|
|
enum wsa_interrupts {
|
|
WSA_INT_SAF2WAR = 0,
|
|
WSA_INT_WAR2SAF,
|
|
WSA_INT_DISABLE,
|
|
WSA_INT_OCP,
|
|
WSA_INT_CLIP,
|
|
WSA_NUM_IRQS,
|
|
};
|
|
|
|
/**
|
|
* struct wsa_resource - the basic wsa_resource structure
|
|
* @irq_lock: lock used by irq_chip functions.
|
|
* @nested_irq_lock: lock used while handling nested interrupts.
|
|
* @irq: interrupt number.
|
|
* @irq_masks_cur: current mask value to be written to mask registers.
|
|
* @irq_masks_cache: cached mask value.
|
|
* @num_irqs: number of supported interrupts.
|
|
* @num_irq_regs: number of irq registers.
|
|
* @parent: parent pointer.
|
|
* @dev: device pointer.
|
|
* @domain: irq domain pointer.
|
|
* codec: codec pointer.
|
|
*
|
|
* Contains required members used in wsa irq driver.
|
|
*/
|
|
|
|
struct wsa_resource {
|
|
struct mutex irq_lock;
|
|
struct mutex nested_irq_lock;
|
|
unsigned int irq;
|
|
u8 irq_masks_cur;
|
|
u8 irq_masks_cache;
|
|
bool irq_level_high[8];
|
|
int num_irqs;
|
|
int num_irq_regs;
|
|
void *parent;
|
|
struct device *dev;
|
|
struct irq_domain *domain;
|
|
struct snd_soc_codec *codec;
|
|
};
|
|
|
|
void wsa_set_codec(struct snd_soc_codec *codec);
|
|
void wsa_free_irq(int irq, void *data);
|
|
void wsa_enable_irq(struct wsa_resource *wsa_res, int irq);
|
|
void wsa_disable_irq(struct wsa_resource *wsa_res, int irq);
|
|
void wsa_disable_irq_sync(struct wsa_resource *wsa_res, int irq);
|
|
int wsa_request_irq(struct wsa_resource *wsa_res,
|
|
int irq, irq_handler_t handler,
|
|
const char *name, void *data);
|
|
|
|
void wsa_irq_exit(struct wsa_resource *wsa_res);
|
|
|
|
#endif /* __WSA881X_IRQ_H__ */
|