2014-01-16 00:58:33 +02:00
/*
*
* Intel Management Engine Interface ( Intel MEI ) Linux driver
* Copyright ( c ) 2013 - 2014 , Intel Corporation .
*
* This program is free software ; you can redistribute it and / or modify it
* under the terms and conditions of the GNU General Public License ,
* version 2 , as published by the Free Software Foundation .
*
* This program is distributed in the hope 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 _MEI_HW_TXE_H_
# define _MEI_HW_TXE_H_
2014-02-21 16:38:28 +11:00
# include <linux/irqreturn.h>
2014-01-16 00:58:33 +02:00
# include "hw.h"
# include "hw-txe-regs.h"
2014-03-18 22:52:03 +02:00
# define MEI_TXI_RPM_TIMEOUT 500 /* ms */
2014-01-16 00:58:33 +02:00
/* Flatten Hierarchy interrupt cause */
# define TXE_INTR_READINESS_BIT 0 /* HISR_INT_0_STS */
# define TXE_INTR_READINESS HISR_INT_0_STS
# define TXE_INTR_ALIVENESS_BIT 1 /* HISR_INT_1_STS */
# define TXE_INTR_ALIVENESS HISR_INT_1_STS
# define TXE_INTR_OUT_DB_BIT 2 /* HISR_INT_2_STS */
# define TXE_INTR_OUT_DB HISR_INT_2_STS
# define TXE_INTR_IN_READY_BIT 8 /* beyond HISR */
# define TXE_INTR_IN_READY BIT(8)
/**
* struct mei_txe_hw - txe hardware specifics
*
2014-03-18 22:51:59 +02:00
* @ mem_addr : SeC and BRIDGE bars
* @ aliveness : aliveness ( power gating ) state of the hardware
* @ readiness : readiness state of the hardware
2014-09-29 16:31:50 +03:00
* @ slots : number of empty slots
2014-03-18 22:51:59 +02:00
* @ wait_aliveness_resp : aliveness wait queue
* @ intr_cause : translated interrupt cause
2014-01-16 00:58:33 +02:00
*/
struct mei_txe_hw {
2017-01-26 17:16:26 +02:00
void __iomem * const * mem_addr ;
2014-01-16 00:58:33 +02:00
u32 aliveness ;
u32 readiness ;
2014-02-19 17:35:48 +02:00
u32 slots ;
2014-01-16 00:58:33 +02:00
2014-03-18 22:51:59 +02:00
wait_queue_head_t wait_aliveness_resp ;
2014-01-16 00:58:33 +02:00
unsigned long intr_cause ;
} ;
# define to_txe_hw(dev) (struct mei_txe_hw *)((dev)->hw)
static inline struct mei_device * hw_txe_to_mei ( struct mei_txe_hw * hw )
{
return container_of ( ( void * ) hw , struct mei_device , hw ) ;
}
2014-09-29 16:31:45 +03:00
struct mei_device * mei_txe_dev_init ( struct pci_dev * pdev ) ;
2014-01-16 00:58:33 +02:00
irqreturn_t mei_txe_irq_quick_handler ( int irq , void * dev_id ) ;
irqreturn_t mei_txe_irq_thread_handler ( int irq , void * dev_id ) ;
int mei_txe_aliveness_set_sync ( struct mei_device * dev , u32 req ) ;
int mei_txe_setup_satt2 ( struct mei_device * dev , phys_addr_t addr , u32 range ) ;
# endif /* _MEI_HW_TXE_H_ */