cregit-Linux how code gets into the kernel

Release 4.7 drivers/xen/events/events_internal.h

/*
 * Xen Event Channels (internal header)
 *
 * Copyright (C) 2013 Citrix Systems R&D Ltd.
 *
 * This source code is licensed under the GNU General Public License,
 * Version 2 or later.  See the file COPYING for more details.
 */
#ifndef __EVENTS_INTERNAL_H__

#define __EVENTS_INTERNAL_H__

/* Interrupt types. */

enum xen_irq_type {
	
IRQT_UNBOUND = 0,
	
IRQT_PIRQ,
	
IRQT_VIRQ,
	
IRQT_IPI,
	
IRQT_EVTCHN
};

/*
 * Packed IRQ information:
 * type - enum xen_irq_type
 * event channel - irq->event channel mapping
 * cpu - cpu this event channel is bound to
 * index - type-specific information:
 *    PIRQ - vector, with MSB being "needs EIO", or physical IRQ of the HVM
 *           guest, or GSI (real passthrough IRQ) of the device.
 *    VIRQ - virq number
 *    IPI - IPI vector
 *    EVTCHN -
 */

struct irq_info {
	
struct list_head list;
	
int refcnt;
	
enum xen_irq_type type;	/* type */
	
unsigned irq;
	
unsigned int evtchn;	/* event channel */
	
unsigned short cpu;	/* cpu bound */

	union {
		
unsigned short virq;
		
enum ipi_vector ipi;
		struct {
			
unsigned short pirq;
			
unsigned short gsi;
			
unsigned char vector;
			
unsigned char flags;
			
uint16_t domid;
		} 
pirq;
	} 
u;
};


#define PIRQ_NEEDS_EOI	(1 << 0)

#define PIRQ_SHAREABLE	(1 << 1)

#define PIRQ_MSI_GROUP	(1 << 2)


struct evtchn_ops {
	
unsigned (*max_channels)(void);
	
unsigned (*nr_channels)(void);

	
int (*setup)(struct irq_info *info);
	
void (*bind_to_cpu)(struct irq_info *info, unsigned cpu);

	
void (*clear_pending)(unsigned port);
	
void (*set_pending)(unsigned port);
	
bool (*is_pending)(unsigned port);
	
bool (*test_and_set_mask)(unsigned port);
	
void (*mask)(unsigned port);
	
void (*unmask)(unsigned port);

	
void (*handle_events)(unsigned cpu);
	
void (*resume)(void);
};

extern const struct evtchn_ops *evtchn_ops;

extern int **evtchn_to_irq;
int get_evtchn_to_irq(unsigned int evtchn);

struct irq_info *info_for_irq(unsigned irq);
unsigned cpu_from_irq(unsigned irq);
unsigned cpu_from_evtchn(unsigned int evtchn);


static inline unsigned xen_evtchn_max_channels(void) { return evtchn_ops->max_channels(); }

Contributors

PersonTokensPropCommitsCommitProp
david vrabeldavid vrabel15100.00%1100.00%
Total15100.00%1100.00%

/* * Do any ABI specific setup for a bound event channel before it can * be unmasked and used. */
static inline int xen_evtchn_port_setup(struct irq_info *info) { if (evtchn_ops->setup) return evtchn_ops->setup(info); return 0; }

Contributors

PersonTokensPropCommitsCommitProp
david vrabeldavid vrabel29100.00%1100.00%
Total29100.00%1100.00%


static inline void xen_evtchn_port_bind_to_cpu(struct irq_info *info, unsigned cpu) { evtchn_ops->bind_to_cpu(info, cpu); }

Contributors

PersonTokensPropCommitsCommitProp
david vrabeldavid vrabel24100.00%2100.00%
Total24100.00%2100.00%


static inline void clear_evtchn(unsigned port) { evtchn_ops->clear_pending(port); }

Contributors

PersonTokensPropCommitsCommitProp
david vrabeldavid vrabel17100.00%2100.00%
Total17100.00%2100.00%


static inline void set_evtchn(unsigned port) { evtchn_ops->set_pending(port); }

Contributors

PersonTokensPropCommitsCommitProp
david vrabeldavid vrabel17100.00%2100.00%
Total17100.00%2100.00%


static inline bool test_evtchn(unsigned port) { return evtchn_ops->is_pending(port); }

Contributors

PersonTokensPropCommitsCommitProp
david vrabeldavid vrabel18100.00%2100.00%
Total18100.00%2100.00%


static inline bool test_and_set_mask(unsigned port) { return evtchn_ops->test_and_set_mask(port); }

Contributors

PersonTokensPropCommitsCommitProp
david vrabeldavid vrabel18100.00%2100.00%
Total18100.00%2100.00%


static inline void mask_evtchn(unsigned port) { return evtchn_ops->mask(port); }

Contributors

PersonTokensPropCommitsCommitProp
david vrabeldavid vrabel18100.00%2100.00%
Total18100.00%2100.00%


static inline void unmask_evtchn(unsigned port) { return evtchn_ops->unmask(port); }

Contributors

PersonTokensPropCommitsCommitProp
david vrabeldavid vrabel18100.00%2100.00%
Total18100.00%2100.00%


static inline void xen_evtchn_handle_events(unsigned cpu) { return evtchn_ops->handle_events(cpu); }

Contributors

PersonTokensPropCommitsCommitProp
david vrabeldavid vrabel18100.00%2100.00%
Total18100.00%2100.00%


static inline void xen_evtchn_resume(void) { if (evtchn_ops->resume) evtchn_ops->resume(); }

Contributors

PersonTokensPropCommitsCommitProp
david vrabeldavid vrabel20100.00%1100.00%
Total20100.00%1100.00%

void xen_evtchn_2l_init(void); int xen_evtchn_fifo_init(void); #endif /* #ifndef __EVENTS_INTERNAL_H__ */

Overall Contributors

PersonTokensPropCommitsCommitProp
david vrabeldavid vrabel50299.21%583.33%
roger pau monneroger pau monne40.79%116.67%
Total506100.00%6100.00%
Information contained on this website is for historical information purposes only and does not indicate or represent copyright ownership.
{% endraw %}