diff options
Diffstat (limited to 'include/linux')
199 files changed, 5603 insertions, 1247 deletions
| diff --git a/include/linux/Kbuild b/include/linux/Kbuild index ca9b9b9bd33..a2df7030d49 100644 --- a/include/linux/Kbuild +++ b/include/linux/Kbuild @@ -135,9 +135,11 @@ header-y += posix_types.h  header-y += ppdev.h  header-y += prctl.h  header-y += qnxtypes.h +header-y += qnx4_fs.h  header-y += radeonfb.h  header-y += raw.h  header-y += resource.h +header-y += romfs_fs.h  header-y += rose.h  header-y += serial_reg.h  header-y += smbno.h @@ -307,14 +309,13 @@ unifdef-y += poll.h  unifdef-y += ppp_defs.h  unifdef-y += ppp-comp.h  unifdef-y += ptrace.h -unifdef-y += qnx4_fs.h  unifdef-y += quota.h  unifdef-y += random.h +unifdef-y += rfkill.h  unifdef-y += irqnr.h  unifdef-y += reboot.h  unifdef-y += reiserfs_fs.h  unifdef-y += reiserfs_xattr.h -unifdef-y += romfs_fs.h  unifdef-y += route.h  unifdef-y += rtc.h  unifdef-y += rtnetlink.h diff --git a/include/linux/acpi.h b/include/linux/acpi.h index 88be890ee3c..51b4b0a5ce8 100644 --- a/include/linux/acpi.h +++ b/include/linux/acpi.h @@ -119,7 +119,7 @@ extern int pci_mmcfg_config_num;  extern int sbf_port;  extern unsigned long acpi_realmode_flags; -int acpi_register_gsi (u32 gsi, int triggering, int polarity); +int acpi_register_gsi (struct device *dev, u32 gsi, int triggering, int polarity);  int acpi_gsi_to_irq (u32 gsi, unsigned int *irq);  #ifdef CONFIG_X86_IO_APIC diff --git a/include/linux/amba/bus.h b/include/linux/amba/bus.h index 51e6e54b2aa..9b93cafa82a 100644 --- a/include/linux/amba/bus.h +++ b/include/linux/amba/bus.h @@ -28,7 +28,7 @@ struct amba_id {  struct amba_driver {  	struct device_driver	drv; -	int			(*probe)(struct amba_device *, void *); +	int			(*probe)(struct amba_device *, struct amba_id *);  	int			(*remove)(struct amba_device *);  	void			(*shutdown)(struct amba_device *);  	int			(*suspend)(struct amba_device *, pm_message_t); diff --git a/include/linux/amba/pl022.h b/include/linux/amba/pl022.h new file mode 100644 index 00000000000..dcad0ffd175 --- /dev/null +++ b/include/linux/amba/pl022.h @@ -0,0 +1,264 @@ +/* + * include/linux/amba/pl022.h + * + * Copyright (C) 2008-2009 ST-Ericsson AB + * Copyright (C) 2006 STMicroelectronics Pvt. Ltd. + * + * Author: Linus Walleij <linus.walleij@stericsson.com> + * + * Initial version inspired by: + *	linux-2.6.17-rc3-mm1/drivers/spi/pxa2xx_spi.c + * Initial adoption to PL022 by: + *      Sachin Verma <sachin.verma@st.com> + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation; either version 2 of the License, or + * (at your option) any later version. + * + * 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 _SSP_PL022_H +#define _SSP_PL022_H + +#include <linux/device.h> + +/** + * whether SSP is in loopback mode or not + */ +enum ssp_loopback { +	LOOPBACK_DISABLED, +	LOOPBACK_ENABLED +}; + +/** + * enum ssp_interface - interfaces allowed for this SSP Controller + * @SSP_INTERFACE_MOTOROLA_SPI: Motorola Interface + * @SSP_INTERFACE_TI_SYNC_SERIAL: Texas Instrument Synchronous Serial + * interface + * @SSP_INTERFACE_NATIONAL_MICROWIRE: National Semiconductor Microwire + * interface + * @SSP_INTERFACE_UNIDIRECTIONAL: Unidirectional interface (STn8810 + * &STn8815 only) + */ +enum ssp_interface { +	SSP_INTERFACE_MOTOROLA_SPI, +	SSP_INTERFACE_TI_SYNC_SERIAL, +	SSP_INTERFACE_NATIONAL_MICROWIRE, +	SSP_INTERFACE_UNIDIRECTIONAL +}; + +/** + * enum ssp_hierarchy - whether SSP is configured as Master or Slave + */ +enum ssp_hierarchy { +	SSP_MASTER, +	SSP_SLAVE +}; + +/** + * enum ssp_clock_params - clock parameters, to set SSP clock at a + * desired freq + */ +struct ssp_clock_params { +	u8 cpsdvsr; /* value from 2 to 254 (even only!) */ +	u8 scr;	    /* value from 0 to 255 */ +}; + +/** + * enum ssp_rx_endian - endianess of Rx FIFO Data + */ +enum ssp_rx_endian { +	SSP_RX_MSB, +	SSP_RX_LSB +}; + +/** + * enum ssp_tx_endian - endianess of Tx FIFO Data + */ +enum ssp_tx_endian { +	SSP_TX_MSB, +	SSP_TX_LSB +}; + +/** + * enum ssp_data_size - number of bits in one data element + */ +enum ssp_data_size { +	SSP_DATA_BITS_4 = 0x03, SSP_DATA_BITS_5, SSP_DATA_BITS_6, +	SSP_DATA_BITS_7, SSP_DATA_BITS_8, SSP_DATA_BITS_9, +	SSP_DATA_BITS_10, SSP_DATA_BITS_11, SSP_DATA_BITS_12, +	SSP_DATA_BITS_13, SSP_DATA_BITS_14, SSP_DATA_BITS_15, +	SSP_DATA_BITS_16, SSP_DATA_BITS_17, SSP_DATA_BITS_18, +	SSP_DATA_BITS_19, SSP_DATA_BITS_20, SSP_DATA_BITS_21, +	SSP_DATA_BITS_22, SSP_DATA_BITS_23, SSP_DATA_BITS_24, +	SSP_DATA_BITS_25, SSP_DATA_BITS_26, SSP_DATA_BITS_27, +	SSP_DATA_BITS_28, SSP_DATA_BITS_29, SSP_DATA_BITS_30, +	SSP_DATA_BITS_31, SSP_DATA_BITS_32 +}; + +/** + * enum ssp_mode - SSP mode of operation (Communication modes) + */ +enum ssp_mode { +	INTERRUPT_TRANSFER, +	POLLING_TRANSFER, +	DMA_TRANSFER +}; + +/** + * enum ssp_rx_level_trig - receive FIFO watermark level which triggers + * IT: Interrupt fires when _N_ or more elements in RX FIFO. + */ +enum ssp_rx_level_trig { +	SSP_RX_1_OR_MORE_ELEM, +	SSP_RX_4_OR_MORE_ELEM, +	SSP_RX_8_OR_MORE_ELEM, +	SSP_RX_16_OR_MORE_ELEM, +	SSP_RX_32_OR_MORE_ELEM +}; + +/** + * Transmit FIFO watermark level which triggers (IT Interrupt fires + * when _N_ or more empty locations in TX FIFO) + */ +enum ssp_tx_level_trig { +	SSP_TX_1_OR_MORE_EMPTY_LOC, +	SSP_TX_4_OR_MORE_EMPTY_LOC, +	SSP_TX_8_OR_MORE_EMPTY_LOC, +	SSP_TX_16_OR_MORE_EMPTY_LOC, +	SSP_TX_32_OR_MORE_EMPTY_LOC +}; + +/** + * enum SPI Clock Phase - clock phase (Motorola SPI interface only) + * @SSP_CLK_RISING_EDGE: Receive data on rising edge + * @SSP_CLK_FALLING_EDGE: Receive data on falling edge + */ +enum ssp_spi_clk_phase { +	SSP_CLK_RISING_EDGE, +	SSP_CLK_FALLING_EDGE +}; + +/** + * enum SPI Clock Polarity - clock polarity (Motorola SPI interface only) + * @SSP_CLK_POL_IDLE_LOW: Low inactive level + * @SSP_CLK_POL_IDLE_HIGH: High inactive level + */ +enum ssp_spi_clk_pol { +	SSP_CLK_POL_IDLE_LOW, +	SSP_CLK_POL_IDLE_HIGH +}; + +/** + * Microwire Conrol Lengths Command size in microwire format + */ +enum ssp_microwire_ctrl_len { +	SSP_BITS_4 = 0x03, SSP_BITS_5, SSP_BITS_6, +	SSP_BITS_7, SSP_BITS_8, SSP_BITS_9, +	SSP_BITS_10, SSP_BITS_11, SSP_BITS_12, +	SSP_BITS_13, SSP_BITS_14, SSP_BITS_15, +	SSP_BITS_16, SSP_BITS_17, SSP_BITS_18, +	SSP_BITS_19, SSP_BITS_20, SSP_BITS_21, +	SSP_BITS_22, SSP_BITS_23, SSP_BITS_24, +	SSP_BITS_25, SSP_BITS_26, SSP_BITS_27, +	SSP_BITS_28, SSP_BITS_29, SSP_BITS_30, +	SSP_BITS_31, SSP_BITS_32 +}; + +/** + * enum Microwire Wait State + * @SSP_MWIRE_WAIT_ZERO: No wait state inserted after last command bit + * @SSP_MWIRE_WAIT_ONE: One wait state inserted after last command bit + */ +enum ssp_microwire_wait_state { +	SSP_MWIRE_WAIT_ZERO, +	SSP_MWIRE_WAIT_ONE +}; + +/** + * enum Microwire - whether Full/Half Duplex + * @SSP_MICROWIRE_CHANNEL_FULL_DUPLEX: SSPTXD becomes bi-directional, + *     SSPRXD not used + * @SSP_MICROWIRE_CHANNEL_HALF_DUPLEX: SSPTXD is an output, SSPRXD is + *     an input. + */ +enum ssp_duplex { +	SSP_MICROWIRE_CHANNEL_FULL_DUPLEX, +	SSP_MICROWIRE_CHANNEL_HALF_DUPLEX +}; + +/** + * CHIP select/deselect commands + */ +enum ssp_chip_select { +	SSP_CHIP_SELECT, +	SSP_CHIP_DESELECT +}; + + +/** + * struct pl022_ssp_master - device.platform_data for SPI controller devices. + * @num_chipselect: chipselects are used to distinguish individual + *     SPI slaves, and are numbered from zero to num_chipselects - 1. + *     each slave has a chipselect signal, but it's common that not + *     every chipselect is connected to a slave. + * @enable_dma: if true enables DMA driven transfers. + */ +struct pl022_ssp_controller { +	u16 bus_id; +	u8 num_chipselect; +	u8 enable_dma:1; +}; + +/** + * struct ssp_config_chip - spi_board_info.controller_data for SPI + * slave devices, copied to spi_device.controller_data. + * + * @lbm: used for test purpose to internally connect RX and TX + * @iface: Interface type(Motorola, TI, Microwire, Universal) + * @hierarchy: sets whether interface is master or slave + * @slave_tx_disable: SSPTXD is disconnected (in slave mode only) + * @clk_freq: Tune freq parameters of SSP(when in master mode) + * @endian_rx: Endianess of Data in Rx FIFO + * @endian_tx: Endianess of Data in Tx FIFO + * @data_size: Width of data element(4 to 32 bits) + * @com_mode: communication mode: polling, Interrupt or DMA + * @rx_lev_trig: Rx FIFO watermark level (for IT & DMA mode) + * @tx_lev_trig: Tx FIFO watermark level (for IT & DMA mode) + * @clk_phase: Motorola SPI interface Clock phase + * @clk_pol: Motorola SPI interface Clock polarity + * @ctrl_len: Microwire interface: Control length + * @wait_state: Microwire interface: Wait state + * @duplex: Microwire interface: Full/Half duplex + * @cs_control: function pointer to board-specific function to + * assert/deassert I/O port to control HW generation of devices chip-select. + * @dma_xfer_type: Type of DMA xfer (Mem-to-periph or Periph-to-Periph) + * @dma_config: DMA configuration for SSP controller and peripheral + */ +struct pl022_config_chip { +	struct device *dev; +	enum ssp_loopback lbm; +	enum ssp_interface iface; +	enum ssp_hierarchy hierarchy; +	bool slave_tx_disable; +	struct ssp_clock_params clk_freq; +	enum ssp_rx_endian endian_rx; +	enum ssp_tx_endian endian_tx; +	enum ssp_data_size data_size; +	enum ssp_mode com_mode; +	enum ssp_rx_level_trig rx_lev_trig; +	enum ssp_tx_level_trig tx_lev_trig; +	enum ssp_spi_clk_phase clk_phase; +	enum ssp_spi_clk_pol clk_pol; +	enum ssp_microwire_ctrl_len ctrl_len; +	enum ssp_microwire_wait_state wait_state; +	enum ssp_duplex duplex; +	void (*cs_control) (u32 control); +}; + +#endif /* _SSP_PL022_H */ diff --git a/include/linux/amba/serial.h b/include/linux/amba/serial.h index 48ee32a18ac..5a5a7fd6249 100644 --- a/include/linux/amba/serial.h +++ b/include/linux/amba/serial.h @@ -114,6 +114,9 @@  #define UART011_IFLS_TX4_8	(2 << 0)  #define UART011_IFLS_TX6_8	(3 << 0)  #define UART011_IFLS_TX7_8	(4 << 0) +/* special values for ST vendor with deeper fifo */ +#define UART011_IFLS_RX_HALF	(5 << 3) +#define UART011_IFLS_TX_HALF	(5 << 0)  #define UART011_OEIM		(1 << 10)	/* overrun error interrupt mask */  #define UART011_BEIM		(1 << 9)	/* break error interrupt mask */ @@ -159,6 +162,7 @@  #define UART01x_FR_MODEM_ANY	(UART01x_FR_DCD|UART01x_FR_DSR|UART01x_FR_CTS)  #ifndef __ASSEMBLY__ +struct amba_device; /* in uncompress this is included but amba/bus.h is not */  struct amba_pl010_data {  	void (*set_mctrl)(struct amba_device *dev, void __iomem *base, unsigned int mctrl);  }; diff --git a/include/linux/ata.h b/include/linux/ata.h index cb79b7a208e..915da43edee 100644 --- a/include/linux/ata.h +++ b/include/linux/ata.h @@ -730,6 +730,34 @@ static inline int ata_id_has_unload(const u16 *id)  	return 0;  } +static inline int ata_id_form_factor(const u16 *id) +{ +	u16 val = id[168]; + +	if (ata_id_major_version(id) < 7 || val == 0 || val == 0xffff) +		return 0; + +	val &= 0xf; + +	if (val > 5) +		return 0; + +	return val; +} + +static inline int ata_id_rotation_rate(const u16 *id) +{ +	u16 val = id[217]; + +	if (ata_id_major_version(id) < 7 || val == 0 || val == 0xffff) +		return 0; + +	if (val > 1 && val < 0x401) +		return 0; + +	return val; +} +  static inline int ata_id_has_trim(const u16 *id)  {  	if (ata_id_major_version(id) >= 7 && diff --git a/include/linux/atmel-mci.h b/include/linux/atmel-mci.h index 2f1f95737ac..57b1846a3c8 100644 --- a/include/linux/atmel-mci.h +++ b/include/linux/atmel-mci.h @@ -10,6 +10,7 @@   * @bus_width: Number of data lines wired up the slot   * @detect_pin: GPIO pin wired to the card detect switch   * @wp_pin: GPIO pin wired to the write protect sensor + * @detect_is_active_high: The state of the detect pin when it is active   *   * If a given slot is not present on the board, @bus_width should be   * set to 0. The other fields are ignored in this case. @@ -24,6 +25,7 @@ struct mci_slot_pdata {  	unsigned int		bus_width;  	int			detect_pin;  	int			wp_pin; +	bool			detect_is_active_high;  };  /** diff --git a/include/linux/auto_fs.h b/include/linux/auto_fs.h index 63265852b7d..7b09c8348fd 100644 --- a/include/linux/auto_fs.h +++ b/include/linux/auto_fs.h @@ -14,13 +14,12 @@  #ifndef _LINUX_AUTO_FS_H  #define _LINUX_AUTO_FS_H +#include <linux/types.h>  #ifdef __KERNEL__  #include <linux/fs.h>  #include <linux/limits.h> -#include <linux/types.h>  #include <linux/ioctl.h>  #else -#include <asm/types.h>  #include <sys/ioctl.h>  #endif /* __KERNEL__ */ diff --git a/include/linux/bio.h b/include/linux/bio.h index 7b214fd672a..2a04eb54c0d 100644 --- a/include/linux/bio.h +++ b/include/linux/bio.h @@ -218,12 +218,12 @@ struct bio {  #define bio_sectors(bio)	((bio)->bi_size >> 9)  #define bio_empty_barrier(bio)	(bio_barrier(bio) && !bio_has_data(bio) && !bio_discard(bio)) -static inline unsigned int bio_cur_sectors(struct bio *bio) +static inline unsigned int bio_cur_bytes(struct bio *bio)  {  	if (bio->bi_vcnt) -		return bio_iovec(bio)->bv_len >> 9; +		return bio_iovec(bio)->bv_len;  	else /* dataless requests such as discard */ -		return bio->bi_size >> 9; +		return bio->bi_size;  }  static inline void *bio_data(struct bio *bio) @@ -279,7 +279,7 @@ static inline int bio_has_allocated_vec(struct bio *bio)  #define __BIO_SEG_BOUNDARY(addr1, addr2, mask) \  	(((addr1) | (mask)) == (((addr2) - 1) | (mask)))  #define BIOVEC_SEG_BOUNDARY(q, b1, b2) \ -	__BIO_SEG_BOUNDARY(bvec_to_phys((b1)), bvec_to_phys((b2)) + (b2)->bv_len, (q)->seg_boundary_mask) +	__BIO_SEG_BOUNDARY(bvec_to_phys((b1)), bvec_to_phys((b2)) + (b2)->bv_len, queue_segment_boundary((q)))  #define BIO_SEG_BOUNDARY(q, b1, b2) \  	BIOVEC_SEG_BOUNDARY((q), __BVEC_END((b1)), __BVEC_START((b2))) @@ -506,7 +506,7 @@ static inline int bio_has_data(struct bio *bio)  }  /* - * BIO list managment for use by remapping drivers (e.g. DM or MD). + * BIO list management for use by remapping drivers (e.g. DM or MD) and loop.   *   * A bio_list anchors a singly-linked list of bios chained through the bi_next   * member of the bio.  The bio_list also caches the last list member to allow @@ -590,6 +590,11 @@ static inline void bio_list_merge_head(struct bio_list *bl,  	bl->head = bl2->head;  } +static inline struct bio *bio_list_peek(struct bio_list *bl) +{ +	return bl->head; +} +  static inline struct bio *bio_list_pop(struct bio_list *bl)  {  	struct bio *bio = bl->head; diff --git a/include/linux/blkdev.h b/include/linux/blkdev.h index b4f71f1a4af..8963d9149b5 100644 --- a/include/linux/blkdev.h +++ b/include/linux/blkdev.h @@ -166,19 +166,9 @@ struct request {  	enum rq_cmd_type_bits cmd_type;  	unsigned long atomic_flags; -	/* Maintain bio traversal state for part by part I/O submission. -	 * hard_* are block layer internals, no driver should touch them! -	 */ - -	sector_t sector;		/* next sector to submit */ -	sector_t hard_sector;		/* next sector to complete */ -	unsigned long nr_sectors;	/* no. of sectors left to submit */ -	unsigned long hard_nr_sectors;	/* no. of sectors left to complete */ -	/* no. of sectors left to submit in the current segment */ -	unsigned int current_nr_sectors; - -	/* no. of sectors left to complete in the current segment */ -	unsigned int hard_cur_sectors; +	/* the following two fields are internal, NEVER access directly */ +	sector_t __sector;		/* sector cursor */ +	unsigned int __data_len;	/* total data len */  	struct bio *bio;  	struct bio *biotail; @@ -211,8 +201,8 @@ struct request {  	unsigned short ioprio; -	void *special; -	char *buffer; +	void *special;		/* opaque pointer available for LLD use */ +	char *buffer;		/* kaddr of the current segment if available */  	int tag;  	int errors; @@ -226,10 +216,9 @@ struct request {  	unsigned char __cmd[BLK_MAX_CDB];  	unsigned char *cmd; -	unsigned int data_len;  	unsigned int extra_len;	/* length of alignment and padding */  	unsigned int sense_len; -	void *data; +	unsigned int resid_len;	/* residual count */  	void *sense;  	unsigned long deadline; @@ -318,6 +307,26 @@ struct blk_cmd_filter {  	struct kobject kobj;  }; +struct queue_limits { +	unsigned long		bounce_pfn; +	unsigned long		seg_boundary_mask; + +	unsigned int		max_hw_sectors; +	unsigned int		max_sectors; +	unsigned int		max_segment_size; +	unsigned int		physical_block_size; +	unsigned int		alignment_offset; +	unsigned int		io_min; +	unsigned int		io_opt; + +	unsigned short		logical_block_size; +	unsigned short		max_hw_segments; +	unsigned short		max_phys_segments; + +	unsigned char		misaligned; +	unsigned char		no_cluster; +}; +  struct request_queue  {  	/* @@ -369,7 +378,6 @@ struct request_queue  	/*  	 * queue needs bounce pages for pages above this limit  	 */ -	unsigned long		bounce_pfn;  	gfp_t			bounce_gfp;  	/* @@ -398,14 +406,6 @@ struct request_queue  	unsigned int		nr_congestion_off;  	unsigned int		nr_batching; -	unsigned int		max_sectors; -	unsigned int		max_hw_sectors; -	unsigned short		max_phys_segments; -	unsigned short		max_hw_segments; -	unsigned short		hardsect_size; -	unsigned int		max_segment_size; - -	unsigned long		seg_boundary_mask;  	void			*dma_drain_buffer;  	unsigned int		dma_drain_size;  	unsigned int		dma_pad_mask; @@ -415,12 +415,14 @@ struct request_queue  	struct list_head	tag_busy_list;  	unsigned int		nr_sorted; -	unsigned int		in_flight; +	unsigned int		in_flight[2];  	unsigned int		rq_timeout;  	struct timer_list	timeout;  	struct list_head	timeout_list; +	struct queue_limits	limits; +  	/*  	 * sg stuff  	 */ @@ -522,6 +524,11 @@ static inline void queue_flag_clear_unlocked(unsigned int flag,  	__clear_bit(flag, &q->queue_flags);  } +static inline int queue_in_flight(struct request_queue *q) +{ +	return q->in_flight[0] + q->in_flight[1]; +} +  static inline void queue_flag_clear(unsigned int flag, struct request_queue *q)  {  	WARN_ON_ONCE(!queue_is_locked(q)); @@ -752,10 +759,17 @@ extern void blk_rq_init(struct request_queue *q, struct request *rq);  extern void blk_put_request(struct request *);  extern void __blk_put_request(struct request_queue *, struct request *);  extern struct request *blk_get_request(struct request_queue *, int, gfp_t); +extern struct request *blk_make_request(struct request_queue *, struct bio *, +					gfp_t);  extern void blk_insert_request(struct request_queue *, struct request *, int, void *);  extern void blk_requeue_request(struct request_queue *, struct request *);  extern int blk_rq_check_limits(struct request_queue *q, struct request *rq);  extern int blk_lld_busy(struct request_queue *q); +extern int blk_rq_prep_clone(struct request *rq, struct request *rq_src, +			     struct bio_set *bs, gfp_t gfp_mask, +			     int (*bio_ctr)(struct bio *, struct bio *, void *), +			     void *data); +extern void blk_rq_unprep_clone(struct request *rq);  extern int blk_insert_cloned_request(struct request_queue *q,  				     struct request *rq);  extern void blk_plug_device(struct request_queue *); @@ -768,12 +782,6 @@ extern int sg_scsi_ioctl(struct request_queue *, struct gendisk *, fmode_t,  			 struct scsi_ioctl_command __user *);  /* - * Temporary export, until SCSI gets fixed up. - */ -extern int blk_rq_append_bio(struct request_queue *q, struct request *rq, -			     struct bio *bio); - -/*   * A queue has just exitted congestion.  Note this in the global counter of   * congested queues, and wake up anyone who was waiting for requests to be   * put back. @@ -798,7 +806,6 @@ extern void blk_sync_queue(struct request_queue *q);  extern void __blk_stop_queue(struct request_queue *q);  extern void __blk_run_queue(struct request_queue *);  extern void blk_run_queue(struct request_queue *); -extern void blk_start_queueing(struct request_queue *);  extern int blk_rq_map_user(struct request_queue *, struct request *,  			   struct rq_map_data *, void __user *, unsigned long,  			   gfp_t); @@ -831,41 +838,73 @@ static inline void blk_run_address_space(struct address_space *mapping)  		blk_run_backing_dev(mapping->backing_dev_info, NULL);  } -extern void blkdev_dequeue_request(struct request *req); +/* + * blk_rq_pos()		: the current sector + * blk_rq_bytes()	: bytes left in the entire request + * blk_rq_cur_bytes()	: bytes left in the current segment + * blk_rq_sectors()	: sectors left in the entire request + * blk_rq_cur_sectors()	: sectors left in the current segment + */ +static inline sector_t blk_rq_pos(const struct request *rq) +{ +	return rq->__sector; +} + +static inline unsigned int blk_rq_bytes(const struct request *rq) +{ +	return rq->__data_len; +} + +static inline int blk_rq_cur_bytes(const struct request *rq) +{ +	return rq->bio ? bio_cur_bytes(rq->bio) : 0; +} + +static inline unsigned int blk_rq_sectors(const struct request *rq) +{ +	return blk_rq_bytes(rq) >> 9; +} + +static inline unsigned int blk_rq_cur_sectors(const struct request *rq) +{ +	return blk_rq_cur_bytes(rq) >> 9; +} + +/* + * Request issue related functions. + */ +extern struct request *blk_peek_request(struct request_queue *q); +extern void blk_start_request(struct request *rq); +extern struct request *blk_fetch_request(struct request_queue *q);  /* - * blk_end_request() and friends. - * __blk_end_request() and end_request() must be called with - * the request queue spinlock acquired. + * Request completion related functions. + * + * blk_update_request() completes given number of bytes and updates + * the request without completing it. + * + * blk_end_request() and friends.  __blk_end_request() must be called + * with the request queue spinlock acquired.   *   * Several drivers define their own end_request and call   * blk_end_request() for parts of the original function.   * This prevents code duplication in drivers.   */ -extern int blk_end_request(struct request *rq, int error, -				unsigned int nr_bytes); -extern int __blk_end_request(struct request *rq, int error, -				unsigned int nr_bytes); -extern int blk_end_bidi_request(struct request *rq, int error, -				unsigned int nr_bytes, unsigned int bidi_bytes); -extern void end_request(struct request *, int); -extern int blk_end_request_callback(struct request *rq, int error, -				unsigned int nr_bytes, -				int (drv_callback)(struct request *)); +extern bool blk_update_request(struct request *rq, int error, +			       unsigned int nr_bytes); +extern bool blk_end_request(struct request *rq, int error, +			    unsigned int nr_bytes); +extern void blk_end_request_all(struct request *rq, int error); +extern bool blk_end_request_cur(struct request *rq, int error); +extern bool __blk_end_request(struct request *rq, int error, +			      unsigned int nr_bytes); +extern void __blk_end_request_all(struct request *rq, int error); +extern bool __blk_end_request_cur(struct request *rq, int error); +  extern void blk_complete_request(struct request *);  extern void __blk_complete_request(struct request *);  extern void blk_abort_request(struct request *);  extern void blk_abort_queue(struct request_queue *); -extern void blk_update_request(struct request *rq, int error, -			       unsigned int nr_bytes); - -/* - * blk_end_request() takes bytes instead of sectors as a complete size. - * blk_rq_bytes() returns bytes left to complete in the entire request. - * blk_rq_cur_bytes() returns bytes left to complete in the current segment. - */ -extern unsigned int blk_rq_bytes(struct request *rq); -extern unsigned int blk_rq_cur_bytes(struct request *rq);  /*   * Access functions for manipulating queue properties @@ -877,10 +916,21 @@ extern void blk_cleanup_queue(struct request_queue *);  extern void blk_queue_make_request(struct request_queue *, make_request_fn *);  extern void blk_queue_bounce_limit(struct request_queue *, u64);  extern void blk_queue_max_sectors(struct request_queue *, unsigned int); +extern void blk_queue_max_hw_sectors(struct request_queue *, unsigned int);  extern void blk_queue_max_phys_segments(struct request_queue *, unsigned short);  extern void blk_queue_max_hw_segments(struct request_queue *, unsigned short);  extern void blk_queue_max_segment_size(struct request_queue *, unsigned int); -extern void blk_queue_hardsect_size(struct request_queue *, unsigned short); +extern void blk_queue_logical_block_size(struct request_queue *, unsigned short); +extern void blk_queue_physical_block_size(struct request_queue *, unsigned short); +extern void blk_queue_alignment_offset(struct request_queue *q, +				       unsigned int alignment); +extern void blk_queue_io_min(struct request_queue *q, unsigned int min); +extern void blk_queue_io_opt(struct request_queue *q, unsigned int opt); +extern void blk_set_default_limits(struct queue_limits *lim); +extern int blk_stack_limits(struct queue_limits *t, struct queue_limits *b, +			    sector_t offset); +extern void disk_stack_limits(struct gendisk *disk, struct block_device *bdev, +			      sector_t offset);  extern void blk_queue_stack_limits(struct request_queue *t, struct request_queue *b);  extern void blk_queue_dma_pad(struct request_queue *, unsigned int);  extern void blk_queue_update_dma_pad(struct request_queue *, unsigned int); @@ -967,19 +1017,87 @@ extern void blk_set_cmd_filter_defaults(struct blk_cmd_filter *filter);  #define blkdev_entry_to_request(entry) list_entry((entry), struct request, queuelist) -static inline int queue_hardsect_size(struct request_queue *q) +static inline unsigned long queue_bounce_pfn(struct request_queue *q) +{ +	return q->limits.bounce_pfn; +} + +static inline unsigned long queue_segment_boundary(struct request_queue *q) +{ +	return q->limits.seg_boundary_mask; +} + +static inline unsigned int queue_max_sectors(struct request_queue *q) +{ +	return q->limits.max_sectors; +} + +static inline unsigned int queue_max_hw_sectors(struct request_queue *q) +{ +	return q->limits.max_hw_sectors; +} + +static inline unsigned short queue_max_hw_segments(struct request_queue *q) +{ +	return q->limits.max_hw_segments; +} + +static inline unsigned short queue_max_phys_segments(struct request_queue *q) +{ +	return q->limits.max_phys_segments; +} + +static inline unsigned int queue_max_segment_size(struct request_queue *q) +{ +	return q->limits.max_segment_size; +} + +static inline unsigned short queue_logical_block_size(struct request_queue *q)  {  	int retval = 512; -	if (q && q->hardsect_size) -		retval = q->hardsect_size; +	if (q && q->limits.logical_block_size) +		retval = q->limits.logical_block_size;  	return retval;  } -static inline int bdev_hardsect_size(struct block_device *bdev) +static inline unsigned short bdev_logical_block_size(struct block_device *bdev) +{ +	return queue_logical_block_size(bdev_get_queue(bdev)); +} + +static inline unsigned int queue_physical_block_size(struct request_queue *q) +{ +	return q->limits.physical_block_size; +} + +static inline unsigned int queue_io_min(struct request_queue *q) +{ +	return q->limits.io_min; +} + +static inline unsigned int queue_io_opt(struct request_queue *q) +{ +	return q->limits.io_opt; +} + +static inline int queue_alignment_offset(struct request_queue *q) +{ +	if (q && q->limits.misaligned) +		return -1; + +	if (q && q->limits.alignment_offset) +		return q->limits.alignment_offset; + +	return 0; +} + +static inline int queue_sector_alignment_offset(struct request_queue *q, +						sector_t sector)  { -	return queue_hardsect_size(bdev_get_queue(bdev)); +	return ((sector << 9) - q->limits.alignment_offset) +		& (q->limits.io_min - 1);  }  static inline int queue_dma_alignment(struct request_queue *q) @@ -1109,6 +1227,8 @@ struct block_device_operations {  	int (*direct_access) (struct block_device *, sector_t,  						void **, unsigned long *);  	int (*media_changed) (struct gendisk *); +	unsigned long long (*set_capacity) (struct gendisk *, +						unsigned long long);  	int (*revalidate_disk) (struct gendisk *);  	int (*getgeo)(struct block_device *, struct hd_geometry *);  	struct module *owner; diff --git a/include/linux/blktrace_api.h b/include/linux/blktrace_api.h index d960889e92e..7e4350ece0f 100644 --- a/include/linux/blktrace_api.h +++ b/include/linux/blktrace_api.h @@ -116,9 +116,9 @@ struct blk_io_trace {   * The remap event   */  struct blk_io_trace_remap { -	__be32 device;  	__be32 device_from; -	__be64 sector; +	__be32 device_to; +	__be64 sector_from;  };  enum { @@ -165,8 +165,9 @@ struct blk_trace {  extern int blk_trace_ioctl(struct block_device *, unsigned, char __user *);  extern void blk_trace_shutdown(struct request_queue *); -extern int do_blk_trace_setup(struct request_queue *q, -	char *name, dev_t dev, struct blk_user_trace_setup *buts); +extern int do_blk_trace_setup(struct request_queue *q, char *name, +			      dev_t dev, struct block_device *bdev, +			      struct blk_user_trace_setup *buts);  extern void __trace_note_message(struct blk_trace *, const char *fmt, ...);  /** @@ -193,22 +194,42 @@ extern void __trace_note_message(struct blk_trace *, const char *fmt, ...);  extern void blk_add_driver_data(struct request_queue *q, struct request *rq,  				void *data, size_t len);  extern int blk_trace_setup(struct request_queue *q, char *name, dev_t dev, +			   struct block_device *bdev,  			   char __user *arg);  extern int blk_trace_startstop(struct request_queue *q, int start);  extern int blk_trace_remove(struct request_queue *q); +extern int blk_trace_init_sysfs(struct device *dev);  extern struct attribute_group blk_trace_attr_group;  #else /* !CONFIG_BLK_DEV_IO_TRACE */ -#define blk_trace_ioctl(bdev, cmd, arg)		(-ENOTTY) -#define blk_trace_shutdown(q)			do { } while (0) -#define do_blk_trace_setup(q, name, dev, buts)	(-ENOTTY) -#define blk_add_driver_data(q, rq, data, len)	do {} while (0) -#define blk_trace_setup(q, name, dev, arg)	(-ENOTTY) -#define blk_trace_startstop(q, start)		(-ENOTTY) -#define blk_trace_remove(q)			(-ENOTTY) -#define blk_add_trace_msg(q, fmt, ...)		do { } while (0) +# define blk_trace_ioctl(bdev, cmd, arg)		(-ENOTTY) +# define blk_trace_shutdown(q)				do { } while (0) +# define do_blk_trace_setup(q, name, dev, bdev, buts)	(-ENOTTY) +# define blk_add_driver_data(q, rq, data, len)		do {} while (0) +# define blk_trace_setup(q, name, dev, bdev, arg)	(-ENOTTY) +# define blk_trace_startstop(q, start)			(-ENOTTY) +# define blk_trace_remove(q)				(-ENOTTY) +# define blk_add_trace_msg(q, fmt, ...)			do { } while (0) +static inline int blk_trace_init_sysfs(struct device *dev) +{ +	return 0; +}  #endif /* CONFIG_BLK_DEV_IO_TRACE */ + +#if defined(CONFIG_EVENT_TRACING) && defined(CONFIG_BLOCK) + +static inline int blk_cmd_buf_len(struct request *rq) +{ +	return blk_pc_request(rq) ? rq->cmd_len * 3 : 1; +} + +extern void blk_dump_cmd(char *buf, struct request *rq); +extern void blk_fill_rwbs(char *rwbs, u32 rw, int bytes); +extern void blk_fill_rwbs_rq(char *rwbs, struct request *rq); + +#endif /* CONFIG_EVENT_TRACING && CONFIG_BLOCK */ +  #endif /* __KERNEL__ */  #endif diff --git a/include/linux/can/Kbuild b/include/linux/can/Kbuild index eff898aac02..8cb05aae661 100644 --- a/include/linux/can/Kbuild +++ b/include/linux/can/Kbuild @@ -1,3 +1,4 @@  header-y += raw.h  header-y += bcm.h  header-y += error.h +header-y += netlink.h diff --git a/include/linux/can/dev.h b/include/linux/can/dev.h new file mode 100644 index 00000000000..4a37a56f6cd --- /dev/null +++ b/include/linux/can/dev.h @@ -0,0 +1,70 @@ +/* + * linux/can/dev.h + * + * Definitions for the CAN network device driver interface + * + * Copyright (C) 2006 Andrey Volkov <avolkov@varma-el.com> + *               Varma Electronics Oy + * + * Copyright (C) 2008 Wolfgang Grandegger <wg@grandegger.com> + * + * Send feedback to <socketcan-users@lists.berlios.de> + */ + +#ifndef CAN_DEV_H +#define CAN_DEV_H + +#include <linux/can/netlink.h> +#include <linux/can/error.h> + +/* + * CAN mode + */ +enum can_mode { +	CAN_MODE_STOP = 0, +	CAN_MODE_START, +	CAN_MODE_SLEEP +}; + +/* + * CAN common private data + */ +#define CAN_ECHO_SKB_MAX  4 + +struct can_priv { +	struct can_device_stats can_stats; + +	struct can_bittiming bittiming; +	struct can_bittiming_const *bittiming_const; +	struct can_clock clock; + +	enum can_state state; +	u32 ctrlmode; + +	int restart_ms; +	struct timer_list restart_timer; + +	struct sk_buff *echo_skb[CAN_ECHO_SKB_MAX]; + +	int (*do_set_bittiming)(struct net_device *dev); +	int (*do_set_mode)(struct net_device *dev, enum can_mode mode); +	int (*do_get_state)(const struct net_device *dev, +			    enum can_state *state); +}; + +struct net_device *alloc_candev(int sizeof_priv); +void free_candev(struct net_device *dev); + +int open_candev(struct net_device *dev); +void close_candev(struct net_device *dev); + +int register_candev(struct net_device *dev); +void unregister_candev(struct net_device *dev); + +int can_restart_now(struct net_device *dev); +void can_bus_off(struct net_device *dev); + +void can_put_echo_skb(struct sk_buff *skb, struct net_device *dev, int idx); +void can_get_echo_skb(struct net_device *dev, int idx); + +#endif /* CAN_DEV_H */ diff --git a/include/linux/can/netlink.h b/include/linux/can/netlink.h new file mode 100644 index 00000000000..9ecbb7871c0 --- /dev/null +++ b/include/linux/can/netlink.h @@ -0,0 +1,113 @@ +/* + * linux/can/netlink.h + * + * Definitions for the CAN netlink interface + * + * Copyright (c) 2009 Wolfgang Grandegger <wg@grandegger.com> + * + * Send feedback to <socketcan-users@lists.berlios.de> + * + */ + +#ifndef CAN_NETLINK_H +#define CAN_NETLINK_H + +#include <linux/types.h> + +/* + * CAN bit-timing parameters + * + * For futher information, please read chapter "8 BIT TIMING + * REQUIREMENTS" of the "Bosch CAN Specification version 2.0" + * at http://www.semiconductors.bosch.de/pdf/can2spec.pdf. + */ +struct can_bittiming { +	__u32 bitrate;		/* Bit-rate in bits/second */ +	__u32 sample_point;	/* Sample point in one-tenth of a percent */ +	__u32 tq;		/* Time quanta (TQ) in nanoseconds */ +	__u32 prop_seg;		/* Propagation segment in TQs */ +	__u32 phase_seg1;	/* Phase buffer segment 1 in TQs */ +	__u32 phase_seg2;	/* Phase buffer segment 2 in TQs */ +	__u32 sjw;		/* Synchronisation jump width in TQs */ +	__u32 brp;		/* Bit-rate prescaler */ +}; + +/* + * CAN harware-dependent bit-timing constant + * + * Used for calculating and checking bit-timing parameters + */ +struct can_bittiming_const { +	char name[16];		/* Name of the CAN controller hardware */ +	__u32 tseg1_min;	/* Time segement 1 = prop_seg + phase_seg1 */ +	__u32 tseg1_max; +	__u32 tseg2_min;	/* Time segement 2 = phase_seg2 */ +	__u32 tseg2_max; +	__u32 sjw_max;		/* Synchronisation jump width */ +	__u32 brp_min;		/* Bit-rate prescaler */ +	__u32 brp_max; +	__u32 brp_inc; +}; + +/* + * CAN clock parameters + */ +struct can_clock { +	__u32 freq;		/* CAN system clock frequency in Hz */ +}; + +/* + * CAN operational and error states + */ +enum can_state { +	CAN_STATE_ERROR_ACTIVE = 0,	/* RX/TX error count < 96 */ +	CAN_STATE_ERROR_WARNING,	/* RX/TX error count < 128 */ +	CAN_STATE_ERROR_PASSIVE,	/* RX/TX error count < 256 */ +	CAN_STATE_BUS_OFF,		/* RX/TX error count >= 256 */ +	CAN_STATE_STOPPED,		/* Device is stopped */ +	CAN_STATE_SLEEPING,		/* Device is sleeping */ +	CAN_STATE_MAX +}; + +/* + * CAN controller mode + */ +struct can_ctrlmode { +	__u32 mask; +	__u32 flags; +}; + +#define CAN_CTRLMODE_LOOPBACK	0x1	/* Loopback mode */ +#define CAN_CTRLMODE_LISTENONLY	0x2 	/* Listen-only mode */ +#define CAN_CTRLMODE_3_SAMPLES	0x4	/* Triple sampling mode */ + +/* + * CAN device statistics + */ +struct can_device_stats { +	__u32 bus_error;	/* Bus errors */ +	__u32 error_warning;	/* Changes to error warning state */ +	__u32 error_passive;	/* Changes to error passive state */ +	__u32 bus_off;		/* Changes to bus off state */ +	__u32 arbitration_lost; /* Arbitration lost errors */ +	__u32 restarts;		/* CAN controller re-starts */ +}; + +/* + * CAN netlink interface + */ +enum { +	IFLA_CAN_UNSPEC, +	IFLA_CAN_BITTIMING, +	IFLA_CAN_BITTIMING_CONST, +	IFLA_CAN_CLOCK, +	IFLA_CAN_STATE, +	IFLA_CAN_CTRLMODE, +	IFLA_CAN_RESTART_MS, +	IFLA_CAN_RESTART, +	__IFLA_CAN_MAX +}; + +#define IFLA_CAN_MAX	(__IFLA_CAN_MAX - 1) + +#endif /* CAN_NETLINK_H */ diff --git a/include/linux/can/platform/sja1000.h b/include/linux/can/platform/sja1000.h new file mode 100644 index 00000000000..01ee2aeb048 --- /dev/null +++ b/include/linux/can/platform/sja1000.h @@ -0,0 +1,35 @@ +#ifndef _CAN_PLATFORM_SJA1000_H_ +#define _CAN_PLATFORM_SJA1000_H_ + +/* clock divider register */ +#define CDR_CLKOUT_MASK 0x07 +#define CDR_CLK_OFF	0x08 /* Clock off (CLKOUT pin) */ +#define CDR_RXINPEN	0x20 /* TX1 output is RX irq output */ +#define CDR_CBP		0x40 /* CAN input comparator bypass */ +#define CDR_PELICAN	0x80 /* PeliCAN mode */ + +/* output control register */ +#define OCR_MODE_BIPHASE  0x00 +#define OCR_MODE_TEST     0x01 +#define OCR_MODE_NORMAL   0x02 +#define OCR_MODE_CLOCK    0x03 +#define OCR_MODE_MASK     0x07 +#define OCR_TX0_INVERT    0x04 +#define OCR_TX0_PULLDOWN  0x08 +#define OCR_TX0_PULLUP    0x10 +#define OCR_TX0_PUSHPULL  0x18 +#define OCR_TX1_INVERT    0x20 +#define OCR_TX1_PULLDOWN  0x40 +#define OCR_TX1_PULLUP    0x80 +#define OCR_TX1_PUSHPULL  0xc0 +#define OCR_TX_MASK       0xfc +#define OCR_TX_SHIFT      2 + +struct sja1000_platform_data { +	u32 clock;	/* CAN bus oscillator frequency in Hz */ + +	u8 ocr;		/* output control register */ +	u8 cdr;		/* clock divider register */ +}; + +#endif	/* !_CAN_PLATFORM_SJA1000_H_ */ diff --git a/include/linux/cb710.h b/include/linux/cb710.h new file mode 100644 index 00000000000..63bc9a4d292 --- /dev/null +++ b/include/linux/cb710.h @@ -0,0 +1,231 @@ +/* + *  cb710/cb710.h + * + *  Copyright by Michał Mirosław, 2008-2009 + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License version 2 as + * published by the Free Software Foundation. + */ +#ifndef LINUX_CB710_DRIVER_H +#define LINUX_CB710_DRIVER_H + +#include <linux/io.h> +#include <linux/interrupt.h> +#include <linux/spinlock.h> +#include <linux/pci.h> +#include <linux/platform_device.h> +#include <linux/mmc/host.h> + +struct cb710_slot; + +typedef int (*cb710_irq_handler_t)(struct cb710_slot *); + +/* per-virtual-slot structure */ +struct cb710_slot { +	struct platform_device	pdev; +	void __iomem		*iobase; +	cb710_irq_handler_t	irq_handler; +}; + +/* per-device structure */ +struct cb710_chip { +	struct pci_dev		*pdev; +	void __iomem		*iobase; +	unsigned		platform_id; +#ifdef CONFIG_CB710_DEBUG_ASSUMPTIONS +	atomic_t		slot_refs_count; +#endif +	unsigned		slot_mask; +	unsigned		slots; +	spinlock_t		irq_lock; +	struct cb710_slot	slot[0]; +}; + +/* NOTE: cb710_chip.slots is modified only during device init/exit and + * they are all serialized wrt themselves */ + +/* cb710_chip.slot_mask values */ +#define CB710_SLOT_MMC		1 +#define CB710_SLOT_MS		2 +#define CB710_SLOT_SM		4 + +/* slot port accessors - so the logic is more clear in the code */ +#define CB710_PORT_ACCESSORS(t) \ +static inline void cb710_write_port_##t(struct cb710_slot *slot,	\ +	unsigned port, u##t value)					\ +{									\ +	iowrite##t(value, slot->iobase + port);				\ +}									\ +									\ +static inline u##t cb710_read_port_##t(struct cb710_slot *slot,		\ +	unsigned port)							\ +{									\ +	return ioread##t(slot->iobase + port);				\ +}									\ +									\ +static inline void cb710_modify_port_##t(struct cb710_slot *slot,	\ +	unsigned port, u##t set, u##t clear)				\ +{									\ +	iowrite##t(							\ +		(ioread##t(slot->iobase + port) & ~clear)|set,		\ +		slot->iobase + port);					\ +} + +CB710_PORT_ACCESSORS(8) +CB710_PORT_ACCESSORS(16) +CB710_PORT_ACCESSORS(32) + +void cb710_pci_update_config_reg(struct pci_dev *pdev, +	int reg, uint32_t and, uint32_t xor); +void cb710_set_irq_handler(struct cb710_slot *slot, +	cb710_irq_handler_t handler); + +/* some device struct walking */ + +static inline struct cb710_slot *cb710_pdev_to_slot( +	struct platform_device *pdev) +{ +	return container_of(pdev, struct cb710_slot, pdev); +} + +static inline struct cb710_chip *cb710_slot_to_chip(struct cb710_slot *slot) +{ +	return dev_get_drvdata(slot->pdev.dev.parent); +} + +static inline struct device *cb710_slot_dev(struct cb710_slot *slot) +{ +	return &slot->pdev.dev; +} + +static inline struct device *cb710_chip_dev(struct cb710_chip *chip) +{ +	return &chip->pdev->dev; +} + +/* debugging aids */ + +#ifdef CONFIG_CB710_DEBUG +void cb710_dump_regs(struct cb710_chip *chip, unsigned dump); +#else +#define cb710_dump_regs(c, d) do {} while (0) +#endif + +#define CB710_DUMP_REGS_MMC	0x0F +#define CB710_DUMP_REGS_MS	0x30 +#define CB710_DUMP_REGS_SM	0xC0 +#define CB710_DUMP_REGS_ALL	0xFF +#define CB710_DUMP_REGS_MASK	0xFF + +#define CB710_DUMP_ACCESS_8	0x100 +#define CB710_DUMP_ACCESS_16	0x200 +#define CB710_DUMP_ACCESS_32	0x400 +#define CB710_DUMP_ACCESS_ALL	0x700 +#define CB710_DUMP_ACCESS_MASK	0x700 + +#endif /* LINUX_CB710_DRIVER_H */ +/* + *  cb710/sgbuf2.h + * + *  Copyright by Michał Mirosław, 2008-2009 + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License version 2 as + * published by the Free Software Foundation. + */ +#ifndef LINUX_CB710_SG_H +#define LINUX_CB710_SG_H + +#include <linux/highmem.h> +#include <linux/scatterlist.h> + +/** + * cb710_sg_miter_stop_writing - stop mapping iteration after writing + * @miter: sg mapping iter to be stopped + * + * Description: + *   Stops mapping iterator @miter.  @miter should have been started + *   started using sg_miter_start().  A stopped iteration can be + *   resumed by calling sg_miter_next() on it.  This is useful when + *   resources (kmap) need to be released during iteration. + * + *   This is a convenience wrapper that will be optimized out for arches + *   that don't need flush_kernel_dcache_page(). + * + * Context: + *   IRQ disabled if the SG_MITER_ATOMIC is set.  Don't care otherwise. + */ +static inline void cb710_sg_miter_stop_writing(struct sg_mapping_iter *miter) +{ +	if (miter->page) +		flush_kernel_dcache_page(miter->page); +	sg_miter_stop(miter); +} + +/* + * 32-bit PIO mapping sg iterator + * + * Hides scatterlist access issues - fragment boundaries, alignment, page + * mapping - for drivers using 32-bit-word-at-a-time-PIO (ie. PCI devices + * without DMA support). + * + * Best-case reading (transfer from device): + *   sg_miter_start(); + *   cb710_sg_dwiter_write_from_io(); + *   cb710_sg_miter_stop_writing(); + * + * Best-case writing (transfer to device): + *   sg_miter_start(); + *   cb710_sg_dwiter_read_to_io(); + *   sg_miter_stop(); + */ + +uint32_t cb710_sg_dwiter_read_next_block(struct sg_mapping_iter *miter); +void cb710_sg_dwiter_write_next_block(struct sg_mapping_iter *miter, uint32_t data); + +/** + * cb710_sg_dwiter_write_from_io - transfer data to mapped buffer from 32-bit IO port + * @miter: sg mapping iter + * @port: PIO port - IO or MMIO address + * @count: number of 32-bit words to transfer + * + * Description: + *   Reads @count 32-bit words from register @port and stores it in + *   buffer iterated by @miter.  Data that would overflow the buffer + *   is silently ignored.  Iterator is advanced by 4*@count bytes + *   or to the buffer's end whichever is closer. + * + * Context: + *   IRQ disabled if the SG_MITER_ATOMIC is set.  Don't care otherwise. + */ +static inline void cb710_sg_dwiter_write_from_io(struct sg_mapping_iter *miter, +	void __iomem *port, size_t count) +{ +	while (count-- > 0) +		cb710_sg_dwiter_write_next_block(miter, ioread32(port)); +} + +/** + * cb710_sg_dwiter_read_to_io - transfer data to 32-bit IO port from mapped buffer + * @miter: sg mapping iter + * @port: PIO port - IO or MMIO address + * @count: number of 32-bit words to transfer + * + * Description: + *   Writes @count 32-bit words to register @port from buffer iterated + *   through @miter.  If buffer ends before @count words are written + *   missing data is replaced by zeroes. @miter is advanced by 4*@count + *   bytes or to the buffer's end whichever is closer. + * + * Context: + *   IRQ disabled if the SG_MITER_ATOMIC is set.  Don't care otherwise. + */ +static inline void cb710_sg_dwiter_read_to_io(struct sg_mapping_iter *miter, +	void __iomem *port, size_t count) +{ +	while (count-- > 0) +		iowrite32(cb710_sg_dwiter_read_next_block(miter), port); +} + +#endif /* LINUX_CB710_SG_H */ diff --git a/include/linux/cdev.h b/include/linux/cdev.h index fb4591977b0..f389e319a45 100644 --- a/include/linux/cdev.h +++ b/include/linux/cdev.h @@ -28,6 +28,8 @@ int cdev_add(struct cdev *, dev_t, unsigned);  void cdev_del(struct cdev *); +int cdev_index(struct inode *inode); +  void cd_forget(struct inode *);  extern struct backing_dev_info directly_mappable_cdev_bdi; diff --git a/include/linux/clk.h b/include/linux/clk.h index 1db9bbf444a..1d37f42ac29 100644 --- a/include/linux/clk.h +++ b/include/linux/clk.h @@ -142,4 +142,17 @@ struct clk *clk_get_parent(struct clk *clk);   */  struct clk *clk_get_sys(const char *dev_id, const char *con_id); +/** + * clk_add_alias - add a new clock alias + * @alias: name for clock alias + * @alias_dev_name: device name + * @id: platform specific clock name + * @dev: device + * + * Allows using generic clock names for drivers by adding a new alias. + * Assumes clkdev, see clkdev.h for more info. + */ +int clk_add_alias(const char *alias, const char *alias_dev_name, char *id, +			struct device *dev); +  #endif diff --git a/include/linux/clockchips.h b/include/linux/clockchips.h index 3a1dbba4d3a..20a100fe2b4 100644 --- a/include/linux/clockchips.h +++ b/include/linux/clockchips.h @@ -143,3 +143,12 @@ extern void clockevents_notify(unsigned long reason, void *arg);  #endif  #endif + +#ifdef CONFIG_GENERIC_CLOCKEVENTS +extern ktime_t clockevents_get_next_event(int cpu); +#else +static inline ktime_t clockevents_get_next_event(int cpu) +{ +	return (ktime_t) { .tv64 = KTIME_MAX }; +} +#endif diff --git a/include/linux/clocksource.h b/include/linux/clocksource.h index 5a40d14daa9..c56457c8334 100644 --- a/include/linux/clocksource.h +++ b/include/linux/clocksource.h @@ -288,7 +288,15 @@ static inline cycle_t clocksource_read(struct clocksource *cs)   */  static inline int clocksource_enable(struct clocksource *cs)  { -	return cs->enable ? cs->enable(cs) : 0; +	int ret = 0; + +	if (cs->enable) +		ret = cs->enable(cs); + +	/* save mult_orig on enable */ +	cs->mult_orig = cs->mult; + +	return ret;  }  /** diff --git a/include/linux/compat.h b/include/linux/compat.h index f2ded21f9a3..af931ee43dd 100644 --- a/include/linux/compat.h +++ b/include/linux/compat.h @@ -222,6 +222,8 @@ int copy_siginfo_from_user32(siginfo_t *to, struct compat_siginfo __user *from);  int copy_siginfo_to_user32(struct compat_siginfo __user *to, siginfo_t *from);  int get_compat_sigevent(struct sigevent *event,  		const struct compat_sigevent __user *u_event); +long compat_sys_rt_tgsigqueueinfo(compat_pid_t tgid, compat_pid_t pid, int sig, +				  struct compat_siginfo __user *uinfo);  static inline int compat_timeval_compare(struct compat_timeval *lhs,  					struct compat_timeval *rhs) diff --git a/include/linux/compiler.h b/include/linux/compiler.h index 37bcb50a4d7..04fb5135b4e 100644 --- a/include/linux/compiler.h +++ b/include/linux/compiler.h @@ -261,6 +261,11 @@ void ftrace_likely_update(struct ftrace_branch_data *f, int val, int expect);  # define __section(S) __attribute__ ((__section__(#S)))  #endif +/* Are two types/vars the same type (ignoring qualifiers)? */ +#ifndef __same_type +# define __same_type(a, b) __builtin_types_compatible_p(typeof(a), typeof(b)) +#endif +  /*   * Prevent the compiler from merging or refetching accesses.  The compiler   * is also forbidden from reordering successive instances of ACCESS_ONCE(), diff --git a/include/linux/cpumask.h b/include/linux/cpumask.h index 9f315382610..c5ac87ca7bc 100644 --- a/include/linux/cpumask.h +++ b/include/linux/cpumask.h @@ -1022,6 +1022,8 @@ typedef struct cpumask *cpumask_var_t;  bool alloc_cpumask_var_node(cpumask_var_t *mask, gfp_t flags, int node);  bool alloc_cpumask_var(cpumask_var_t *mask, gfp_t flags); +bool zalloc_cpumask_var_node(cpumask_var_t *mask, gfp_t flags, int node); +bool zalloc_cpumask_var(cpumask_var_t *mask, gfp_t flags);  void alloc_bootmem_cpumask_var(cpumask_var_t *mask);  void free_cpumask_var(cpumask_var_t mask);  void free_bootmem_cpumask_var(cpumask_var_t mask); @@ -1040,6 +1042,19 @@ static inline bool alloc_cpumask_var_node(cpumask_var_t *mask, gfp_t flags,  	return true;  } +static inline bool zalloc_cpumask_var(cpumask_var_t *mask, gfp_t flags) +{ +	cpumask_clear(*mask); +	return true; +} + +static inline bool zalloc_cpumask_var_node(cpumask_var_t *mask, gfp_t flags, +					  int node) +{ +	cpumask_clear(*mask); +	return true; +} +  static inline void alloc_bootmem_cpumask_var(cpumask_var_t *mask)  {  } diff --git a/include/linux/cramfs_fs.h b/include/linux/cramfs_fs.h index 3be4e5a27d8..6fc2bed368b 100644 --- a/include/linux/cramfs_fs.h +++ b/include/linux/cramfs_fs.h @@ -2,9 +2,8 @@  #define __CRAMFS_H  #include <linux/types.h> +#include <linux/magic.h> -#define CRAMFS_MAGIC		0x28cd3d45	/* some random number */ -#define CRAMFS_MAGIC_WEND	0x453dcd28	/* magic number with the wrong endianess */  #define CRAMFS_SIGNATURE	"Compressed ROMFS"  /* diff --git a/include/linux/cred.h b/include/linux/cred.h index 3282ee4318e..4fa99969631 100644 --- a/include/linux/cred.h +++ b/include/linux/cred.h @@ -13,6 +13,7 @@  #define _LINUX_CRED_H  #include <linux/capability.h> +#include <linux/init.h>  #include <linux/key.h>  #include <asm/atomic.h> diff --git a/include/linux/cyclades.h b/include/linux/cyclades.h index 788850ba4e7..1fbdea4f08e 100644 --- a/include/linux/cyclades.h +++ b/include/linux/cyclades.h @@ -142,19 +142,6 @@ struct CYZ_BOOT_CTRL {  #ifndef DP_WINDOW_SIZE -/* #include "cyclomz.h" */ -/****************** ****************** *******************/ -/* - *	The data types defined below are used in all ZFIRM interface - *	data structures. They accomodate differences between HW - *	architectures and compilers. - */ - -typedef __u64  ucdouble;		/* 64 bits, unsigned */ -typedef __u32  uclong;			/* 32 bits, unsigned */ -typedef __u16  ucshort;		/* 16 bits, unsigned */ -typedef __u8   ucchar;			/* 8 bits, unsigned */ -  /*   *	Memory Window Sizes   */ @@ -507,16 +494,20 @@ struct ZFW_CTRL {  /* Per card data structure */  struct cyclades_card { -    void __iomem *base_addr; -    void __iomem *ctl_addr; -    int irq; -    unsigned int num_chips;	/* 0 if card absent, -1 if Z/PCI, else Y */ -    unsigned int first_line;	/* minor number of first channel on card */ -    unsigned int nports;	/* Number of ports in the card */ -    int bus_index;		/* address shift - 0 for ISA, 1 for PCI */ -    int intr_enabled;		/* FW Interrupt flag - 0 disabled, 1 enabled */ -    spinlock_t card_lock; -    struct cyclades_port *ports; +	void __iomem *base_addr; +	union { +		void __iomem *p9050; +		struct RUNTIME_9060 __iomem *p9060; +	} ctl_addr; +	int irq; +	unsigned int num_chips;	/* 0 if card absent, -1 if Z/PCI, else Y */ +	unsigned int first_line;	/* minor number of first channel on card */ +	unsigned int nports;	/* Number of ports in the card */ +	int bus_index;		/* address shift - 0 for ISA, 1 for PCI */ +	int intr_enabled;		/* FW Interrupt flag - 0 disabled, 1 enabled */ +	u32 hw_ver; +	spinlock_t card_lock; +	struct cyclades_port *ports;  };  /*************************************** diff --git a/include/linux/dcache.h b/include/linux/dcache.h index 15156364d19..30b93b2a01a 100644 --- a/include/linux/dcache.h +++ b/include/linux/dcache.h @@ -180,10 +180,12 @@ d_iput:		no		no		no       yes  #define DCACHE_REFERENCED	0x0008  /* Recently used, don't discard. */  #define DCACHE_UNHASHED		0x0010	 -#define DCACHE_INOTIFY_PARENT_WATCHED	0x0020 /* Parent inode is watched */ +#define DCACHE_INOTIFY_PARENT_WATCHED	0x0020 /* Parent inode is watched by inotify */  #define DCACHE_COOKIE		0x0040	/* For use by dcookie subsystem */ +#define DCACHE_FSNOTIFY_PARENT_WATCHED	0x0080 /* Parent inode is watched by some fsnotify listener */ +  extern spinlock_t dcache_lock;  extern seqlock_t rename_lock; @@ -351,6 +353,11 @@ static inline int d_unhashed(struct dentry *dentry)  	return (dentry->d_flags & DCACHE_UNHASHED);  } +static inline int d_unlinked(struct dentry *dentry) +{ +	return d_unhashed(dentry) && !IS_ROOT(dentry); +} +  static inline struct dentry *dget_parent(struct dentry *dentry)  {  	struct dentry *ret; @@ -368,7 +375,7 @@ static inline int d_mountpoint(struct dentry *dentry)  	return dentry->d_mounted;  } -extern struct vfsmount *lookup_mnt(struct vfsmount *, struct dentry *); +extern struct vfsmount *lookup_mnt(struct path *);  extern struct dentry *lookup_create(struct nameidata *nd, int is_dir);  extern int sysctl_vfs_cache_pressure; diff --git a/include/linux/device-mapper.h b/include/linux/device-mapper.h index ded2d7c4266..49c2362977f 100644 --- a/include/linux/device-mapper.h +++ b/include/linux/device-mapper.h @@ -149,7 +149,7 @@ struct io_restrictions {  	unsigned max_hw_sectors;  	unsigned max_sectors;  	unsigned max_segment_size; -	unsigned short hardsect_size; +	unsigned short logical_block_size;  	unsigned short max_hw_segments;  	unsigned short max_phys_segments;  	unsigned char no_cluster; /* inverted so that 0 is default */ diff --git a/include/linux/device.h b/include/linux/device.h index 6a69caaac18..a4a7b10aaa4 100644 --- a/include/linux/device.h +++ b/include/linux/device.h @@ -62,8 +62,6 @@ struct bus_type {  	void (*shutdown)(struct device *dev);  	int (*suspend)(struct device *dev, pm_message_t state); -	int (*suspend_late)(struct device *dev, pm_message_t state); -	int (*resume_early)(struct device *dev);  	int (*resume)(struct device *dev);  	struct dev_pm_ops *pm; @@ -291,9 +289,6 @@ struct device_type {  	int (*uevent)(struct device *dev, struct kobj_uevent_env *env);  	void (*release)(struct device *dev); -	int (*suspend)(struct device *dev, pm_message_t state); -	int (*resume)(struct device *dev); -  	struct dev_pm_ops *pm;  }; @@ -384,13 +379,8 @@ struct device {  	struct device_driver *driver;	/* which driver has allocated this  					   device */  	void		*driver_data;	/* data private to the driver */ - -	void		*platform_data;	/* We will remove platform_data -					   field if all platform devices -					   pass its platform specific data -					   from platform_device->platform_data, -					   other kind of devices should not -					   use platform_data. */ +	void		*platform_data;	/* Platform specific data, device +					   core doesn't touch it */  	struct dev_pm_info	power;  #ifdef CONFIG_NUMA diff --git a/include/linux/dlm.h b/include/linux/dlm.h index b9cd38603fd..0b3518c4235 100644 --- a/include/linux/dlm.h +++ b/include/linux/dlm.h @@ -81,8 +81,8 @@ struct dlm_lksb {   * the cluster, the calling node joins it.   */ -int dlm_new_lockspace(char *name, int namelen, dlm_lockspace_t **lockspace, -		      uint32_t flags, int lvblen); +int dlm_new_lockspace(const char *name, int namelen, +		      dlm_lockspace_t **lockspace, uint32_t flags, int lvblen);  /*   * dlm_release_lockspace diff --git a/include/linux/dma-debug.h b/include/linux/dma-debug.h index 28d53cb7b5a..171ad8aedc8 100644 --- a/include/linux/dma-debug.h +++ b/include/linux/dma-debug.h @@ -32,6 +32,8 @@ extern void dma_debug_add_bus(struct bus_type *bus);  extern void dma_debug_init(u32 num_entries); +extern int dma_debug_resize_entries(u32 num_entries); +  extern void debug_dma_map_page(struct device *dev, struct page *page,  			       size_t offset, size_t size,  			       int direction, dma_addr_t dma_addr, @@ -91,6 +93,11 @@ static inline void dma_debug_init(u32 num_entries)  {  } +static inline int dma_debug_resize_entries(u32 num_entries) +{ +	return 0; +} +  static inline void debug_dma_map_page(struct device *dev, struct page *page,  				      size_t offset, size_t size,  				      int direction, dma_addr_t dma_addr, diff --git a/include/linux/dmaengine.h b/include/linux/dmaengine.h index 2e2aa3df170..ffefba81c81 100644 --- a/include/linux/dmaengine.h +++ b/include/linux/dmaengine.h @@ -78,12 +78,18 @@ enum dma_transaction_type {   * 	dependency chains   * @DMA_COMPL_SKIP_SRC_UNMAP - set to disable dma-unmapping the source buffer(s)   * @DMA_COMPL_SKIP_DEST_UNMAP - set to disable dma-unmapping the destination(s) + * @DMA_COMPL_SRC_UNMAP_SINGLE - set to do the source dma-unmapping as single + * 	(if not set, do the source dma-unmapping as page) + * @DMA_COMPL_DEST_UNMAP_SINGLE - set to do the destination dma-unmapping as single + * 	(if not set, do the destination dma-unmapping as page)   */  enum dma_ctrl_flags {  	DMA_PREP_INTERRUPT = (1 << 0),  	DMA_CTRL_ACK = (1 << 1),  	DMA_COMPL_SKIP_SRC_UNMAP = (1 << 2),  	DMA_COMPL_SKIP_DEST_UNMAP = (1 << 3), +	DMA_COMPL_SRC_UNMAP_SINGLE = (1 << 4), +	DMA_COMPL_DEST_UNMAP_SINGLE = (1 << 5),  };  /** diff --git a/include/linux/dmar.h b/include/linux/dmar.h index e397dc342cd..10ff5c49882 100644 --- a/include/linux/dmar.h +++ b/include/linux/dmar.h @@ -108,6 +108,7 @@ struct irte {  };  #ifdef CONFIG_INTR_REMAP  extern int intr_remapping_enabled; +extern int intr_remapping_supported(void);  extern int enable_intr_remapping(int);  extern void disable_intr_remapping(void);  extern int reenable_intr_remapping(int); @@ -157,6 +158,8 @@ static inline struct intel_iommu *map_ioapic_to_ir(int apic)  }  #define irq_remapped(irq)		(0)  #define enable_intr_remapping(mode)	(-1) +#define disable_intr_remapping()	(0) +#define reenable_intr_remapping(mode)	(0)  #define intr_remapping_enabled		(0)  #endif diff --git a/include/linux/dnotify.h b/include/linux/dnotify.h index 102a902b439..ecc06286226 100644 --- a/include/linux/dnotify.h +++ b/include/linux/dnotify.h @@ -10,7 +10,7 @@  struct dnotify_struct {  	struct dnotify_struct *	dn_next; -	unsigned long		dn_mask; +	__u32			dn_mask;  	int			dn_fd;  	struct file *		dn_filp;  	fl_owner_t		dn_owner; @@ -21,23 +21,18 @@ struct dnotify_struct {  #ifdef CONFIG_DNOTIFY -extern void __inode_dir_notify(struct inode *, unsigned long); +#define DNOTIFY_ALL_EVENTS (FS_DELETE | FS_DELETE_CHILD |\ +			    FS_MODIFY | FS_MODIFY_CHILD |\ +			    FS_ACCESS | FS_ACCESS_CHILD |\ +			    FS_ATTRIB | FS_ATTRIB_CHILD |\ +			    FS_CREATE | FS_DN_RENAME |\ +			    FS_MOVED_FROM | FS_MOVED_TO) +  extern void dnotify_flush(struct file *, fl_owner_t);  extern int fcntl_dirnotify(int, struct file *, unsigned long); -extern void dnotify_parent(struct dentry *, unsigned long); - -static inline void inode_dir_notify(struct inode *inode, unsigned long event) -{ -	if (inode->i_dnotify_mask & (event)) -		__inode_dir_notify(inode, event); -}  #else -static inline void __inode_dir_notify(struct inode *inode, unsigned long event) -{ -} -  static inline void dnotify_flush(struct file *filp, fl_owner_t id)  {  } @@ -47,14 +42,6 @@ static inline int fcntl_dirnotify(int fd, struct file *filp, unsigned long arg)  	return -EINVAL;  } -static inline void dnotify_parent(struct dentry *dentry, unsigned long event) -{ -} - -static inline void inode_dir_notify(struct inode *inode, unsigned long event) -{ -} -  #endif /* CONFIG_DNOTIFY */  #endif /* __KERNEL __ */ diff --git a/include/linux/elevator.h b/include/linux/elevator.h index c59b769f62b..1cb3372e65d 100644 --- a/include/linux/elevator.h +++ b/include/linux/elevator.h @@ -103,10 +103,8 @@ extern int elv_merge(struct request_queue *, struct request **, struct bio *);  extern void elv_merge_requests(struct request_queue *, struct request *,  			       struct request *);  extern void elv_merged_request(struct request_queue *, struct request *, int); -extern void elv_dequeue_request(struct request_queue *, struct request *);  extern void elv_requeue_request(struct request_queue *, struct request *);  extern int elv_queue_empty(struct request_queue *); -extern struct request *elv_next_request(struct request_queue *q);  extern struct request *elv_former_request(struct request_queue *, struct request *);  extern struct request *elv_latter_request(struct request_queue *, struct request *);  extern int elv_register_queue(struct request_queue *q); @@ -171,7 +169,7 @@ enum {  	ELV_MQUEUE_MUST,  }; -#define rq_end_sector(rq)	((rq)->sector + (rq)->nr_sectors) +#define rq_end_sector(rq)	(blk_rq_pos(rq) + blk_rq_sectors(rq))  #define rb_entry_rq(node)	rb_entry((node), struct request, rb_node)  /* diff --git a/include/linux/etherdevice.h b/include/linux/etherdevice.h index a1f17abba7d..3d7a6687d24 100644 --- a/include/linux/etherdevice.h +++ b/include/linux/etherdevice.h @@ -182,6 +182,33 @@ static inline unsigned compare_ether_addr_64bits(const u8 addr1[6+2],  	return compare_ether_addr(addr1, addr2);  #endif  } + +/** + * is_etherdev_addr - Tell if given Ethernet address belongs to the device. + * @dev: Pointer to a device structure + * @addr: Pointer to a six-byte array containing the Ethernet address + * + * Compare passed address with all addresses of the device. Return true if the + * address if one of the device addresses. + * + * Note that this function calls compare_ether_addr_64bits() so take care of + * the right padding. + */ +static inline bool is_etherdev_addr(const struct net_device *dev, +				    const u8 addr[6 + 2]) +{ +	struct netdev_hw_addr *ha; +	int res = 1; + +	rcu_read_lock(); +	for_each_dev_addr(dev, ha) { +		res = compare_ether_addr_64bits(addr, ha->addr); +		if (!res) +			break; +	} +	rcu_read_unlock(); +	return !res; +}  #endif	/* __KERNEL__ */  /** diff --git a/include/linux/ethtool.h b/include/linux/ethtool.h index 131b127b70f..9b660bd2e2b 100644 --- a/include/linux/ethtool.h +++ b/include/linux/ethtool.h @@ -26,11 +26,14 @@ struct ethtool_cmd {  	__u8	phy_address;  	__u8	transceiver;	/* Which transceiver to use */  	__u8	autoneg;	/* Enable or disable autonegotiation */ +	__u8	mdio_support;  	__u32	maxtxpkt;	/* Tx pkts before generating tx int */  	__u32	maxrxpkt;	/* Rx pkts before generating rx int */  	__u16	speed_hi; -	__u16	reserved2; -	__u32	reserved[3]; +	__u8	eth_tp_mdix; +	__u8	reserved2; +	__u32	lp_advertising;	/* Features the link partner advertises */ +	__u32	reserved[2];  };  static inline void ethtool_cmd_speed_set(struct ethtool_cmd *ep, @@ -563,6 +566,11 @@ struct ethtool_ops {  #define SUPPORTED_Pause			(1 << 13)  #define SUPPORTED_Asym_Pause		(1 << 14)  #define SUPPORTED_2500baseX_Full	(1 << 15) +#define SUPPORTED_Backplane		(1 << 16) +#define SUPPORTED_1000baseKX_Full	(1 << 17) +#define SUPPORTED_10000baseKX4_Full	(1 << 18) +#define SUPPORTED_10000baseKR_Full	(1 << 19) +#define SUPPORTED_10000baseR_FEC	(1 << 20)  /* Indicates what features are advertised by the interface. */  #define ADVERTISED_10baseT_Half		(1 << 0) @@ -581,6 +589,11 @@ struct ethtool_ops {  #define ADVERTISED_Pause		(1 << 13)  #define ADVERTISED_Asym_Pause		(1 << 14)  #define ADVERTISED_2500baseX_Full	(1 << 15) +#define ADVERTISED_Backplane		(1 << 16) +#define ADVERTISED_1000baseKX_Full	(1 << 17) +#define ADVERTISED_10000baseKX4_Full	(1 << 18) +#define ADVERTISED_10000baseKR_Full	(1 << 19) +#define ADVERTISED_10000baseR_FEC	(1 << 20)  /* The following are all involved in forcing a particular link   * mode for the device for setting things.  When getting the @@ -605,6 +618,7 @@ struct ethtool_ops {  #define PORT_MII		0x02  #define PORT_FIBRE		0x03  #define PORT_BNC		0x04 +#define PORT_OTHER		0xff  /* Which transceiver to use. */  #define XCVR_INTERNAL		0x00 @@ -619,6 +633,11 @@ struct ethtool_ops {  #define AUTONEG_DISABLE		0x00  #define AUTONEG_ENABLE		0x01 +/* Mode MDI or MDI-X */ +#define ETH_TP_MDI_INVALID	0x00 +#define ETH_TP_MDI		0x01 +#define ETH_TP_MDI_X		0x02 +  /* Wake-On-Lan options. */  #define WAKE_PHY		(1 << 0)  #define WAKE_UCAST		(1 << 1) diff --git a/include/linux/fs.h b/include/linux/fs.h index 5bed436f435..ede84fa7da5 100644 --- a/include/linux/fs.h +++ b/include/linux/fs.h @@ -729,8 +729,8 @@ struct inode {  	struct timespec		i_atime;  	struct timespec		i_mtime;  	struct timespec		i_ctime; -	unsigned int		i_blkbits;  	blkcnt_t		i_blocks; +	unsigned int		i_blkbits;  	unsigned short          i_bytes;  	umode_t			i_mode;  	spinlock_t		i_lock;	/* i_blocks, i_bytes, maybe i_size */ @@ -751,13 +751,12 @@ struct inode {  		struct block_device	*i_bdev;  		struct cdev		*i_cdev;  	}; -	int			i_cindex;  	__u32			i_generation; -#ifdef CONFIG_DNOTIFY -	unsigned long		i_dnotify_mask; /* Directory notify events */ -	struct dnotify_struct	*i_dnotify; /* for directory notifications */ +#ifdef CONFIG_FSNOTIFY +	__u32			i_fsnotify_mask; /* all events this inode cares about */ +	struct hlist_head	i_fsnotify_mark_entries; /* fsnotify mark entries */  #endif  #ifdef CONFIG_INOTIFY @@ -1321,7 +1320,7 @@ struct super_block {  	struct rw_semaphore	s_umount;  	struct mutex		s_lock;  	int			s_count; -	int			s_need_sync_fs; +	int			s_need_sync;  	atomic_t		s_active;  #ifdef CONFIG_SECURITY  	void                    *s_security; @@ -1372,11 +1371,6 @@ struct super_block {  	 * generic_show_options()  	 */  	char *s_options; - -	/* -	 * storage for asynchronous operations -	 */ -	struct list_head s_async_list;  };  extern struct timespec current_fs_time(struct super_block *sb); @@ -1775,6 +1769,7 @@ void kill_block_super(struct super_block *sb);  void kill_anon_super(struct super_block *sb);  void kill_litter_super(struct super_block *sb);  void deactivate_super(struct super_block *sb); +void deactivate_locked_super(struct super_block *sb);  int set_anon_super(struct super_block *s, void *data);  struct super_block *sget(struct file_system_type *type,  			int (*test)(struct super_block *,void *), @@ -1799,7 +1794,7 @@ extern struct vfsmount *kern_mount_data(struct file_system_type *, void *data);  extern int may_umount_tree(struct vfsmount *);  extern int may_umount(struct vfsmount *);  extern long do_mount(char *, char *, char *, unsigned long, void *); -extern struct vfsmount *collect_mounts(struct vfsmount *, struct dentry *); +extern struct vfsmount *collect_mounts(struct path *);  extern void drop_collected_mounts(struct vfsmount *);  extern int vfs_statfs(struct dentry *, struct kstatfs *); @@ -1946,8 +1941,6 @@ extern struct super_block *freeze_bdev(struct block_device *);  extern void emergency_thaw_all(void);  extern int thaw_bdev(struct block_device *bdev, struct super_block *sb);  extern int fsync_bdev(struct block_device *); -extern int fsync_super(struct super_block *); -extern int fsync_no_super(struct block_device *);  #else  static inline void bd_forget(struct inode *inode) {}  static inline int sync_blockdev(struct block_device *bdev) { return 0; } @@ -1963,6 +1956,7 @@ static inline int thaw_bdev(struct block_device *bdev, struct super_block *sb)  	return 0;  }  #endif +extern int sync_filesystem(struct super_block *);  extern const struct file_operations def_blk_fops;  extern const struct file_operations def_chr_fops;  extern const struct file_operations bad_sock_fops; @@ -2081,12 +2075,8 @@ extern int filemap_fdatawrite_range(struct address_space *mapping,  extern int vfs_fsync(struct file *file, struct dentry *dentry, int datasync);  extern void sync_supers(void); -extern void sync_filesystems(int wait); -extern void __fsync_super(struct super_block *sb);  extern void emergency_sync(void);  extern void emergency_remount(void); -extern int do_remount_sb(struct super_block *sb, int flags, -			 void *data, int force);  #ifdef CONFIG_BLOCK  extern sector_t bmap(struct inode *, sector_t);  #endif @@ -2117,7 +2107,7 @@ extern struct file *create_write_pipe(int flags);  extern void free_write_pipe(struct file *);  extern struct file *do_filp_open(int dfd, const char *pathname, -		int open_flag, int mode); +		int open_flag, int mode, int acc_mode);  extern int may_open(struct path *, int, int);  extern int kernel_read(struct file *, unsigned long, char *, unsigned long); @@ -2204,6 +2194,8 @@ extern int generic_segment_checks(const struct iovec *iov,  /* fs/splice.c */  extern ssize_t generic_file_splice_read(struct file *, loff_t *,  		struct pipe_inode_info *, size_t, unsigned int); +extern ssize_t default_file_splice_read(struct file *, loff_t *, +		struct pipe_inode_info *, size_t, unsigned int);  extern ssize_t generic_file_splice_write(struct pipe_inode_info *,  		struct file *, loff_t *, size_t, unsigned int);  extern ssize_t generic_splice_sendpage(struct pipe_inode_info *pipe, @@ -2353,6 +2345,8 @@ extern void simple_release_fs(struct vfsmount **mount, int *count);  extern ssize_t simple_read_from_buffer(void __user *to, size_t count,  			loff_t *ppos, const void *from, size_t available); +extern int simple_fsync(struct file *, struct dentry *, int); +  #ifdef CONFIG_MIGRATION  extern int buffer_migrate_page(struct address_space *,  				struct page *, struct page *); @@ -2367,6 +2361,7 @@ extern void file_update_time(struct file *file);  extern int generic_show_options(struct seq_file *m, struct vfsmount *mnt);  extern void save_mount_options(struct super_block *sb, char *options); +extern void replace_mount_options(struct super_block *sb, char *options);  static inline ino_t parent_ino(struct dentry *dentry)  { diff --git a/include/linux/fs_enet_pd.h b/include/linux/fs_enet_pd.h index 8300cab30f9..51b793466ff 100644 --- a/include/linux/fs_enet_pd.h +++ b/include/linux/fs_enet_pd.h @@ -17,6 +17,7 @@  #define FS_ENET_PD_H  #include <linux/string.h> +#include <linux/of_mdio.h>  #include <asm/types.h>  #define FS_ENET_NAME	"fs_enet" @@ -130,10 +131,7 @@ struct fs_platform_info {  	u32 device_flags; -	int phy_addr;		/* the phy address (-1 no phy) */ -	char bus_id[16]; -	int phy_irq;		/* the phy irq (if it exists)  */ - +	struct device_node *phy_node;  	const struct fs_mii_bus_info *bus_info;  	int rx_ring, tx_ring;	/* number of buffers on rx     */ diff --git a/include/linux/fsnotify.h b/include/linux/fsnotify.h index 00fbd5b245c..936f9aa8bb9 100644 --- a/include/linux/fsnotify.h +++ b/include/linux/fsnotify.h @@ -13,6 +13,7 @@  #include <linux/dnotify.h>  #include <linux/inotify.h> +#include <linux/fsnotify_backend.h>  #include <linux/audit.h>  /* @@ -22,19 +23,45 @@  static inline void fsnotify_d_instantiate(struct dentry *entry,  						struct inode *inode)  { +	__fsnotify_d_instantiate(entry, inode); +  	inotify_d_instantiate(entry, inode);  } +/* Notify this dentry's parent about a child's events. */ +static inline void fsnotify_parent(struct dentry *dentry, __u32 mask) +{ +	__fsnotify_parent(dentry, mask); + +	inotify_dentry_parent_queue_event(dentry, mask, 0, dentry->d_name.name); +} +  /*   * fsnotify_d_move - entry has been moved   * Called with dcache_lock and entry->d_lock held.   */  static inline void fsnotify_d_move(struct dentry *entry)  { +	/* +	 * On move we need to update entry->d_flags to indicate if the new parent +	 * cares about events from this entry. +	 */ +	__fsnotify_update_dcache_flags(entry); +  	inotify_d_move(entry);  }  /* + * fsnotify_link_count - inode's link count changed + */ +static inline void fsnotify_link_count(struct inode *inode) +{ +	inotify_inode_queue_event(inode, IN_ATTRIB, 0, NULL, NULL); + +	fsnotify(inode, FS_ATTRIB, inode, FSNOTIFY_EVENT_INODE, NULL, 0); +} + +/*   * fsnotify_move - file old_name at old_dir was moved to new_name at new_dir   */  static inline void fsnotify_move(struct inode *old_dir, struct inode *new_dir, @@ -42,42 +69,62 @@ static inline void fsnotify_move(struct inode *old_dir, struct inode *new_dir,  				 int isdir, struct inode *target, struct dentry *moved)  {  	struct inode *source = moved->d_inode; -	u32 cookie = inotify_get_cookie(); +	u32 in_cookie = inotify_get_cookie(); +	u32 fs_cookie = fsnotify_get_cookie(); +	__u32 old_dir_mask = (FS_EVENT_ON_CHILD | FS_MOVED_FROM); +	__u32 new_dir_mask = (FS_EVENT_ON_CHILD | FS_MOVED_TO);  	if (old_dir == new_dir) -		inode_dir_notify(old_dir, DN_RENAME); -	else { -		inode_dir_notify(old_dir, DN_DELETE); -		inode_dir_notify(new_dir, DN_CREATE); -	} +		old_dir_mask |= FS_DN_RENAME; -	if (isdir) +	if (isdir) {  		isdir = IN_ISDIR; -	inotify_inode_queue_event(old_dir, IN_MOVED_FROM|isdir,cookie,old_name, +		old_dir_mask |= FS_IN_ISDIR; +		new_dir_mask |= FS_IN_ISDIR; +	} + +	inotify_inode_queue_event(old_dir, IN_MOVED_FROM|isdir, in_cookie, old_name,  				  source); -	inotify_inode_queue_event(new_dir, IN_MOVED_TO|isdir, cookie, new_name, +	inotify_inode_queue_event(new_dir, IN_MOVED_TO|isdir, in_cookie, new_name,  				  source); +	fsnotify(old_dir, old_dir_mask, old_dir, FSNOTIFY_EVENT_INODE, old_name, fs_cookie); +	fsnotify(new_dir, new_dir_mask, new_dir, FSNOTIFY_EVENT_INODE, new_name, fs_cookie); +  	if (target) {  		inotify_inode_queue_event(target, IN_DELETE_SELF, 0, NULL, NULL);  		inotify_inode_is_dead(target); + +		/* this is really a link_count change not a removal */ +		fsnotify_link_count(target);  	}  	if (source) {  		inotify_inode_queue_event(source, IN_MOVE_SELF, 0, NULL, NULL); +		fsnotify(source, FS_MOVE_SELF, moved->d_inode, FSNOTIFY_EVENT_INODE, NULL, 0);  	}  	audit_inode_child(new_name, moved, new_dir);  }  /* + * fsnotify_inode_delete - and inode is being evicted from cache, clean up is needed + */ +static inline void fsnotify_inode_delete(struct inode *inode) +{ +	__fsnotify_inode_delete(inode); +} + +/*   * fsnotify_nameremove - a filename was removed from a directory   */  static inline void fsnotify_nameremove(struct dentry *dentry, int isdir)  { +	__u32 mask = FS_DELETE; +  	if (isdir) -		isdir = IN_ISDIR; -	dnotify_parent(dentry, DN_DELETE); -	inotify_dentry_parent_queue_event(dentry, IN_DELETE|isdir, 0, dentry->d_name.name); +		mask |= FS_IN_ISDIR; + +	fsnotify_parent(dentry, mask);  }  /* @@ -87,14 +134,9 @@ static inline void fsnotify_inoderemove(struct inode *inode)  {  	inotify_inode_queue_event(inode, IN_DELETE_SELF, 0, NULL, NULL);  	inotify_inode_is_dead(inode); -} -/* - * fsnotify_link_count - inode's link count changed - */ -static inline void fsnotify_link_count(struct inode *inode) -{ -	inotify_inode_queue_event(inode, IN_ATTRIB, 0, NULL, NULL); +	fsnotify(inode, FS_DELETE_SELF, inode, FSNOTIFY_EVENT_INODE, NULL, 0); +	__fsnotify_inode_delete(inode);  }  /* @@ -102,10 +144,11 @@ static inline void fsnotify_link_count(struct inode *inode)   */  static inline void fsnotify_create(struct inode *inode, struct dentry *dentry)  { -	inode_dir_notify(inode, DN_CREATE);  	inotify_inode_queue_event(inode, IN_CREATE, 0, dentry->d_name.name,  				  dentry->d_inode);  	audit_inode_child(dentry->d_name.name, dentry, inode); + +	fsnotify(inode, FS_CREATE, dentry->d_inode, FSNOTIFY_EVENT_INODE, dentry->d_name.name, 0);  }  /* @@ -115,11 +158,12 @@ static inline void fsnotify_create(struct inode *inode, struct dentry *dentry)   */  static inline void fsnotify_link(struct inode *dir, struct inode *inode, struct dentry *new_dentry)  { -	inode_dir_notify(dir, DN_CREATE);  	inotify_inode_queue_event(dir, IN_CREATE, 0, new_dentry->d_name.name,  				  inode);  	fsnotify_link_count(inode);  	audit_inode_child(new_dentry->d_name.name, new_dentry, dir); + +	fsnotify(dir, FS_CREATE, inode, FSNOTIFY_EVENT_INODE, new_dentry->d_name.name, 0);  }  /* @@ -127,10 +171,13 @@ static inline void fsnotify_link(struct inode *dir, struct inode *inode, struct   */  static inline void fsnotify_mkdir(struct inode *inode, struct dentry *dentry)  { -	inode_dir_notify(inode, DN_CREATE); -	inotify_inode_queue_event(inode, IN_CREATE | IN_ISDIR, 0,  -				  dentry->d_name.name, dentry->d_inode); +	__u32 mask = (FS_CREATE | FS_IN_ISDIR); +	struct inode *d_inode = dentry->d_inode; + +	inotify_inode_queue_event(inode, mask, 0, dentry->d_name.name, d_inode);  	audit_inode_child(dentry->d_name.name, dentry, inode); + +	fsnotify(inode, mask, d_inode, FSNOTIFY_EVENT_INODE, dentry->d_name.name, 0);  }  /* @@ -139,14 +186,15 @@ static inline void fsnotify_mkdir(struct inode *inode, struct dentry *dentry)  static inline void fsnotify_access(struct dentry *dentry)  {  	struct inode *inode = dentry->d_inode; -	u32 mask = IN_ACCESS; +	__u32 mask = FS_ACCESS;  	if (S_ISDIR(inode->i_mode)) -		mask |= IN_ISDIR; +		mask |= FS_IN_ISDIR; -	dnotify_parent(dentry, DN_ACCESS); -	inotify_dentry_parent_queue_event(dentry, mask, 0, dentry->d_name.name);  	inotify_inode_queue_event(inode, mask, 0, NULL, NULL); + +	fsnotify_parent(dentry, mask); +	fsnotify(inode, mask, inode, FSNOTIFY_EVENT_INODE, NULL, 0);  }  /* @@ -155,14 +203,15 @@ static inline void fsnotify_access(struct dentry *dentry)  static inline void fsnotify_modify(struct dentry *dentry)  {  	struct inode *inode = dentry->d_inode; -	u32 mask = IN_MODIFY; +	__u32 mask = FS_MODIFY;  	if (S_ISDIR(inode->i_mode)) -		mask |= IN_ISDIR; +		mask |= FS_IN_ISDIR; -	dnotify_parent(dentry, DN_MODIFY); -	inotify_dentry_parent_queue_event(dentry, mask, 0, dentry->d_name.name);  	inotify_inode_queue_event(inode, mask, 0, NULL, NULL); + +	fsnotify_parent(dentry, mask); +	fsnotify(inode, mask, inode, FSNOTIFY_EVENT_INODE, NULL, 0);  }  /* @@ -171,13 +220,15 @@ static inline void fsnotify_modify(struct dentry *dentry)  static inline void fsnotify_open(struct dentry *dentry)  {  	struct inode *inode = dentry->d_inode; -	u32 mask = IN_OPEN; +	__u32 mask = FS_OPEN;  	if (S_ISDIR(inode->i_mode)) -		mask |= IN_ISDIR; +		mask |= FS_IN_ISDIR; -	inotify_dentry_parent_queue_event(dentry, mask, 0, dentry->d_name.name);  	inotify_inode_queue_event(inode, mask, 0, NULL, NULL); + +	fsnotify_parent(dentry, mask); +	fsnotify(inode, mask, inode, FSNOTIFY_EVENT_INODE, NULL, 0);  }  /* @@ -187,15 +238,16 @@ static inline void fsnotify_close(struct file *file)  {  	struct dentry *dentry = file->f_path.dentry;  	struct inode *inode = dentry->d_inode; -	const char *name = dentry->d_name.name;  	fmode_t mode = file->f_mode; -	u32 mask = (mode & FMODE_WRITE) ? IN_CLOSE_WRITE : IN_CLOSE_NOWRITE; +	__u32 mask = (mode & FMODE_WRITE) ? FS_CLOSE_WRITE : FS_CLOSE_NOWRITE;  	if (S_ISDIR(inode->i_mode)) -		mask |= IN_ISDIR; +		mask |= FS_IN_ISDIR; -	inotify_dentry_parent_queue_event(dentry, mask, 0, name);  	inotify_inode_queue_event(inode, mask, 0, NULL, NULL); + +	fsnotify_parent(dentry, mask); +	fsnotify(inode, mask, file, FSNOTIFY_EVENT_FILE, NULL, 0);  }  /* @@ -204,13 +256,15 @@ static inline void fsnotify_close(struct file *file)  static inline void fsnotify_xattr(struct dentry *dentry)  {  	struct inode *inode = dentry->d_inode; -	u32 mask = IN_ATTRIB; +	__u32 mask = FS_ATTRIB;  	if (S_ISDIR(inode->i_mode)) -		mask |= IN_ISDIR; +		mask |= FS_IN_ISDIR; -	inotify_dentry_parent_queue_event(dentry, mask, 0, dentry->d_name.name);  	inotify_inode_queue_event(inode, mask, 0, NULL, NULL); + +	fsnotify_parent(dentry, mask); +	fsnotify(inode, mask, inode, FSNOTIFY_EVENT_INODE, NULL, 0);  }  /* @@ -220,50 +274,37 @@ static inline void fsnotify_xattr(struct dentry *dentry)  static inline void fsnotify_change(struct dentry *dentry, unsigned int ia_valid)  {  	struct inode *inode = dentry->d_inode; -	int dn_mask = 0; -	u32 in_mask = 0; +	__u32 mask = 0; + +	if (ia_valid & ATTR_UID) +		mask |= FS_ATTRIB; +	if (ia_valid & ATTR_GID) +		mask |= FS_ATTRIB; +	if (ia_valid & ATTR_SIZE) +		mask |= FS_MODIFY; -	if (ia_valid & ATTR_UID) { -		in_mask |= IN_ATTRIB; -		dn_mask |= DN_ATTRIB; -	} -	if (ia_valid & ATTR_GID) { -		in_mask |= IN_ATTRIB; -		dn_mask |= DN_ATTRIB; -	} -	if (ia_valid & ATTR_SIZE) { -		in_mask |= IN_MODIFY; -		dn_mask |= DN_MODIFY; -	}  	/* both times implies a utime(s) call */  	if ((ia_valid & (ATTR_ATIME | ATTR_MTIME)) == (ATTR_ATIME | ATTR_MTIME)) -	{ -		in_mask |= IN_ATTRIB; -		dn_mask |= DN_ATTRIB; -	} else if (ia_valid & ATTR_ATIME) { -		in_mask |= IN_ACCESS; -		dn_mask |= DN_ACCESS; -	} else if (ia_valid & ATTR_MTIME) { -		in_mask |= IN_MODIFY; -		dn_mask |= DN_MODIFY; -	} -	if (ia_valid & ATTR_MODE) { -		in_mask |= IN_ATTRIB; -		dn_mask |= DN_ATTRIB; -	} +		mask |= FS_ATTRIB; +	else if (ia_valid & ATTR_ATIME) +		mask |= FS_ACCESS; +	else if (ia_valid & ATTR_MTIME) +		mask |= FS_MODIFY; + +	if (ia_valid & ATTR_MODE) +		mask |= FS_ATTRIB; -	if (dn_mask) -		dnotify_parent(dentry, dn_mask); -	if (in_mask) { +	if (mask) {  		if (S_ISDIR(inode->i_mode)) -			in_mask |= IN_ISDIR; -		inotify_inode_queue_event(inode, in_mask, 0, NULL, NULL); -		inotify_dentry_parent_queue_event(dentry, in_mask, 0, -						  dentry->d_name.name); +			mask |= FS_IN_ISDIR; +		inotify_inode_queue_event(inode, mask, 0, NULL, NULL); + +		fsnotify_parent(dentry, mask); +		fsnotify(inode, mask, inode, FSNOTIFY_EVENT_INODE, NULL, 0);  	}  } -#ifdef CONFIG_INOTIFY	/* inotify helpers */ +#if defined(CONFIG_INOTIFY) || defined(CONFIG_FSNOTIFY)	/* notify helpers */  /*   * fsnotify_oldname_init - save off the old filename before we change it @@ -281,7 +322,7 @@ static inline void fsnotify_oldname_free(const char *old_name)  	kfree(old_name);  } -#else	/* CONFIG_INOTIFY */ +#else	/* CONFIG_INOTIFY || CONFIG_FSNOTIFY */  static inline const char *fsnotify_oldname_init(const char *name)  { diff --git a/include/linux/fsnotify_backend.h b/include/linux/fsnotify_backend.h new file mode 100644 index 00000000000..44848aa830d --- /dev/null +++ b/include/linux/fsnotify_backend.h @@ -0,0 +1,387 @@ +/* + * Filesystem access notification for Linux + * + *  Copyright (C) 2008 Red Hat, Inc., Eric Paris <eparis@redhat.com> + */ + +#ifndef __LINUX_FSNOTIFY_BACKEND_H +#define __LINUX_FSNOTIFY_BACKEND_H + +#ifdef __KERNEL__ + +#include <linux/idr.h> /* inotify uses this */ +#include <linux/fs.h> /* struct inode */ +#include <linux/list.h> +#include <linux/path.h> /* struct path */ +#include <linux/spinlock.h> +#include <linux/types.h> + +#include <asm/atomic.h> + +/* + * IN_* from inotfy.h lines up EXACTLY with FS_*, this is so we can easily + * convert between them.  dnotify only needs conversion at watch creation + * so no perf loss there.  fanotify isn't defined yet, so it can use the + * wholes if it needs more events. + */ +#define FS_ACCESS		0x00000001	/* File was accessed */ +#define FS_MODIFY		0x00000002	/* File was modified */ +#define FS_ATTRIB		0x00000004	/* Metadata changed */ +#define FS_CLOSE_WRITE		0x00000008	/* Writtable file was closed */ +#define FS_CLOSE_NOWRITE	0x00000010	/* Unwrittable file closed */ +#define FS_OPEN			0x00000020	/* File was opened */ +#define FS_MOVED_FROM		0x00000040	/* File was moved from X */ +#define FS_MOVED_TO		0x00000080	/* File was moved to Y */ +#define FS_CREATE		0x00000100	/* Subfile was created */ +#define FS_DELETE		0x00000200	/* Subfile was deleted */ +#define FS_DELETE_SELF		0x00000400	/* Self was deleted */ +#define FS_MOVE_SELF		0x00000800	/* Self was moved */ + +#define FS_UNMOUNT		0x00002000	/* inode on umount fs */ +#define FS_Q_OVERFLOW		0x00004000	/* Event queued overflowed */ +#define FS_IN_IGNORED		0x00008000	/* last inotify event here */ + +#define FS_IN_ISDIR		0x40000000	/* event occurred against dir */ +#define FS_IN_ONESHOT		0x80000000	/* only send event once */ + +#define FS_DN_RENAME		0x10000000	/* file renamed */ +#define FS_DN_MULTISHOT		0x20000000	/* dnotify multishot */ + +/* This inode cares about things that happen to its children.  Always set for + * dnotify and inotify. */ +#define FS_EVENT_ON_CHILD	0x08000000 + +/* This is a list of all events that may get sent to a parernt based on fs event + * happening to inodes inside that directory */ +#define FS_EVENTS_POSS_ON_CHILD   (FS_ACCESS | FS_MODIFY | FS_ATTRIB |\ +				   FS_CLOSE_WRITE | FS_CLOSE_NOWRITE | FS_OPEN |\ +				   FS_MOVED_FROM | FS_MOVED_TO | FS_CREATE |\ +				   FS_DELETE) + +/* listeners that hard code group numbers near the top */ +#define DNOTIFY_GROUP_NUM	UINT_MAX +#define INOTIFY_GROUP_NUM	(DNOTIFY_GROUP_NUM-1) + +struct fsnotify_group; +struct fsnotify_event; +struct fsnotify_mark_entry; +struct fsnotify_event_private_data; + +/* + * Each group much define these ops.  The fsnotify infrastructure will call + * these operations for each relevant group. + * + * should_send_event - given a group, inode, and mask this function determines + *		if the group is interested in this event. + * handle_event - main call for a group to handle an fs event + * free_group_priv - called when a group refcnt hits 0 to clean up the private union + * freeing-mark - this means that a mark has been flagged to die when everything + *		finishes using it.  The function is supplied with what must be a + *		valid group and inode to use to clean up. + */ +struct fsnotify_ops { +	bool (*should_send_event)(struct fsnotify_group *group, struct inode *inode, __u32 mask); +	int (*handle_event)(struct fsnotify_group *group, struct fsnotify_event *event); +	void (*free_group_priv)(struct fsnotify_group *group); +	void (*freeing_mark)(struct fsnotify_mark_entry *entry, struct fsnotify_group *group); +	void (*free_event_priv)(struct fsnotify_event_private_data *priv); +}; + +/* + * A group is a "thing" that wants to receive notification about filesystem + * events.  The mask holds the subset of event types this group cares about. + * refcnt on a group is up to the implementor and at any moment if it goes 0 + * everything will be cleaned up. + */ +struct fsnotify_group { +	/* +	 * global list of all groups receiving events from fsnotify. +	 * anchored by fsnotify_groups and protected by either fsnotify_grp_mutex +	 * or fsnotify_grp_srcu depending on write vs read. +	 */ +	struct list_head group_list; + +	/* +	 * Defines all of the event types in which this group is interested. +	 * This mask is a bitwise OR of the FS_* events from above.  Each time +	 * this mask changes for a group (if it changes) the correct functions +	 * must be called to update the global structures which indicate global +	 * interest in event types. +	 */ +	__u32 mask; + +	/* +	 * How the refcnt is used is up to each group.  When the refcnt hits 0 +	 * fsnotify will clean up all of the resources associated with this group. +	 * As an example, the dnotify group will always have a refcnt=1 and that +	 * will never change.  Inotify, on the other hand, has a group per +	 * inotify_init() and the refcnt will hit 0 only when that fd has been +	 * closed. +	 */ +	atomic_t refcnt;		/* things with interest in this group */ +	unsigned int group_num;		/* simply prevents accidental group collision */ + +	const struct fsnotify_ops *ops;	/* how this group handles things */ + +	/* needed to send notification to userspace */ +	struct mutex notification_mutex;	/* protect the notification_list */ +	struct list_head notification_list;	/* list of event_holder this group needs to send to userspace */ +	wait_queue_head_t notification_waitq;	/* read() on the notification file blocks on this waitq */ +	unsigned int q_len;			/* events on the queue */ +	unsigned int max_events;		/* maximum events allowed on the list */ + +	/* stores all fastapth entries assoc with this group so they can be cleaned on unregister */ +	spinlock_t mark_lock;		/* protect mark_entries list */ +	atomic_t num_marks;		/* 1 for each mark entry and 1 for not being +					 * past the point of no return when freeing +					 * a group */ +	struct list_head mark_entries;	/* all inode mark entries for this group */ + +	/* prevents double list_del of group_list.  protected by global fsnotify_grp_mutex */ +	bool on_group_list; + +	/* groups can define private fields here or use the void *private */ +	union { +		void *private; +#ifdef CONFIG_INOTIFY_USER +		struct inotify_group_private_data { +			spinlock_t	idr_lock; +			struct idr      idr; +			u32             last_wd; +			struct fasync_struct    *fa;    /* async notification */ +			struct user_struct      *user; +		} inotify_data; +#endif +	}; +}; + +/* + * A single event can be queued in multiple group->notification_lists. + * + * each group->notification_list will point to an event_holder which in turns points + * to the actual event that needs to be sent to userspace. + * + * Seemed cheaper to create a refcnt'd event and a small holder for every group + * than create a different event for every group + * + */ +struct fsnotify_event_holder { +	struct fsnotify_event *event; +	struct list_head event_list; +}; + +/* + * Inotify needs to tack data onto an event.  This struct lets us later find the + * correct private data of the correct group. + */ +struct fsnotify_event_private_data { +	struct fsnotify_group *group; +	struct list_head event_list; +}; + +/* + * all of the information about the original object we want to now send to + * a group.  If you want to carry more info from the accessing task to the + * listener this structure is where you need to be adding fields. + */ +struct fsnotify_event { +	/* +	 * If we create an event we are also likely going to need a holder +	 * to link to a group.  So embed one holder in the event.  Means only +	 * one allocation for the common case where we only have one group +	 */ +	struct fsnotify_event_holder holder; +	spinlock_t lock;	/* protection for the associated event_holder and private_list */ +	/* to_tell may ONLY be dereferenced during handle_event(). */ +	struct inode *to_tell;	/* either the inode the event happened to or its parent */ +	/* +	 * depending on the event type we should have either a path or inode +	 * We hold a reference on path, but NOT on inode.  Since we have the ref on +	 * the path, it may be dereferenced at any point during this object's +	 * lifetime.  That reference is dropped when this object's refcnt hits +	 * 0.  If this event contains an inode instead of a path, the inode may +	 * ONLY be used during handle_event(). +	 */ +	union { +		struct path path; +		struct inode *inode; +	}; +/* when calling fsnotify tell it if the data is a path or inode */ +#define FSNOTIFY_EVENT_NONE	0 +#define FSNOTIFY_EVENT_PATH	1 +#define FSNOTIFY_EVENT_INODE	2 +#define FSNOTIFY_EVENT_FILE	3 +	int data_type;		/* which of the above union we have */ +	atomic_t refcnt;	/* how many groups still are using/need to send this event */ +	__u32 mask;		/* the type of access, bitwise OR for FS_* event types */ + +	u32 sync_cookie;	/* used to corrolate events, namely inotify mv events */ +	char *file_name; +	size_t name_len; + +	struct list_head private_data_list;	/* groups can store private data here */ +}; + +/* + * a mark is simply an entry attached to an in core inode which allows an + * fsnotify listener to indicate they are either no longer interested in events + * of a type matching mask or only interested in those events. + * + * these are flushed when an inode is evicted from core and may be flushed + * when the inode is modified (as seen by fsnotify_access).  Some fsnotify users + * (such as dnotify) will flush these when the open fd is closed and not at + * inode eviction or modification. + */ +struct fsnotify_mark_entry { +	__u32 mask;			/* mask this mark entry is for */ +	/* we hold ref for each i_list and g_list.  also one ref for each 'thing' +	 * in kernel that found and may be using this mark. */ +	atomic_t refcnt;		/* active things looking at this mark */ +	struct inode *inode;		/* inode this entry is associated with */ +	struct fsnotify_group *group;	/* group this mark entry is for */ +	struct hlist_node i_list;	/* list of mark_entries by inode->i_fsnotify_mark_entries */ +	struct list_head g_list;	/* list of mark_entries by group->i_fsnotify_mark_entries */ +	spinlock_t lock;		/* protect group, inode, and killme */ +	struct list_head free_i_list;	/* tmp list used when freeing this mark */ +	struct list_head free_g_list;	/* tmp list used when freeing this mark */ +	void (*free_mark)(struct fsnotify_mark_entry *entry); /* called on final put+free */ +}; + +#ifdef CONFIG_FSNOTIFY + +/* called from the vfs helpers */ + +/* main fsnotify call to send events */ +extern void fsnotify(struct inode *to_tell, __u32 mask, void *data, int data_is, +		     const char *name, u32 cookie); +extern void __fsnotify_parent(struct dentry *dentry, __u32 mask); +extern void __fsnotify_inode_delete(struct inode *inode); +extern u32 fsnotify_get_cookie(void); + +static inline int fsnotify_inode_watches_children(struct inode *inode) +{ +	/* FS_EVENT_ON_CHILD is set if the inode may care */ +	if (!(inode->i_fsnotify_mask & FS_EVENT_ON_CHILD)) +		return 0; +	/* this inode might care about child events, does it care about the +	 * specific set of events that can happen on a child? */ +	return inode->i_fsnotify_mask & FS_EVENTS_POSS_ON_CHILD; +} + +/* + * Update the dentry with a flag indicating the interest of its parent to receive + * filesystem events when those events happens to this dentry->d_inode. + */ +static inline void __fsnotify_update_dcache_flags(struct dentry *dentry) +{ +	struct dentry *parent; + +	assert_spin_locked(&dcache_lock); +	assert_spin_locked(&dentry->d_lock); + +	parent = dentry->d_parent; +	if (fsnotify_inode_watches_children(parent->d_inode)) +		dentry->d_flags |= DCACHE_FSNOTIFY_PARENT_WATCHED; +	else +		dentry->d_flags &= ~DCACHE_FSNOTIFY_PARENT_WATCHED; +} + +/* + * fsnotify_d_instantiate - instantiate a dentry for inode + * Called with dcache_lock held. + */ +static inline void __fsnotify_d_instantiate(struct dentry *dentry, struct inode *inode) +{ +	if (!inode) +		return; + +	assert_spin_locked(&dcache_lock); + +	spin_lock(&dentry->d_lock); +	__fsnotify_update_dcache_flags(dentry); +	spin_unlock(&dentry->d_lock); +} + +/* called from fsnotify listeners, such as fanotify or dnotify */ + +/* must call when a group changes its ->mask */ +extern void fsnotify_recalc_global_mask(void); +/* get a reference to an existing or create a new group */ +extern struct fsnotify_group *fsnotify_obtain_group(unsigned int group_num, +						    __u32 mask, +						    const struct fsnotify_ops *ops); +/* run all marks associated with this group and update group->mask */ +extern void fsnotify_recalc_group_mask(struct fsnotify_group *group); +/* drop reference on a group from fsnotify_obtain_group */ +extern void fsnotify_put_group(struct fsnotify_group *group); + +/* take a reference to an event */ +extern void fsnotify_get_event(struct fsnotify_event *event); +extern void fsnotify_put_event(struct fsnotify_event *event); +/* find private data previously attached to an event and unlink it */ +extern struct fsnotify_event_private_data *fsnotify_remove_priv_from_event(struct fsnotify_group *group, +									   struct fsnotify_event *event); + +/* attach the event to the group notification queue */ +extern int fsnotify_add_notify_event(struct fsnotify_group *group, struct fsnotify_event *event, +				     struct fsnotify_event_private_data *priv); +/* true if the group notification queue is empty */ +extern bool fsnotify_notify_queue_is_empty(struct fsnotify_group *group); +/* return, but do not dequeue the first event on the notification queue */ +extern struct fsnotify_event *fsnotify_peek_notify_event(struct fsnotify_group *group); +/* return AND dequeue the first event on the notification queue */ +extern struct fsnotify_event *fsnotify_remove_notify_event(struct fsnotify_group *group); + +/* functions used to manipulate the marks attached to inodes */ + +/* run all marks associated with an inode and update inode->i_fsnotify_mask */ +extern void fsnotify_recalc_inode_mask(struct inode *inode); +extern void fsnotify_init_mark(struct fsnotify_mark_entry *entry, void (*free_mark)(struct fsnotify_mark_entry *entry)); +/* find (and take a reference) to a mark associated with group and inode */ +extern struct fsnotify_mark_entry *fsnotify_find_mark_entry(struct fsnotify_group *group, struct inode *inode); +/* attach the mark to both the group and the inode */ +extern int fsnotify_add_mark(struct fsnotify_mark_entry *entry, struct fsnotify_group *group, struct inode *inode); +/* given a mark, flag it to be freed when all references are dropped */ +extern void fsnotify_destroy_mark_by_entry(struct fsnotify_mark_entry *entry); +/* run all the marks in a group, and flag them to be freed */ +extern void fsnotify_clear_marks_by_group(struct fsnotify_group *group); +extern void fsnotify_get_mark(struct fsnotify_mark_entry *entry); +extern void fsnotify_put_mark(struct fsnotify_mark_entry *entry); +extern void fsnotify_unmount_inodes(struct list_head *list); + +/* put here because inotify does some weird stuff when destroying watches */ +extern struct fsnotify_event *fsnotify_create_event(struct inode *to_tell, __u32 mask, +						    void *data, int data_is, const char *name, +						    u32 cookie); + +#else + +static inline void fsnotify(struct inode *to_tell, __u32 mask, void *data, int data_is, +			    const char *name, u32 cookie) +{} + +static inline void __fsnotify_parent(struct dentry *dentry, __u32 mask) +{} + +static inline void __fsnotify_inode_delete(struct inode *inode) +{} + +static inline void __fsnotify_update_dcache_flags(struct dentry *dentry) +{} + +static inline void __fsnotify_d_instantiate(struct dentry *dentry, struct inode *inode) +{} + +static inline u32 fsnotify_get_cookie(void) +{ +	return 0; +} + +static inline void fsnotify_unmount_inodes(struct list_head *list) +{} + +#endif	/* CONFIG_FSNOTIFY */ + +#endif	/* __KERNEL __ */ + +#endif	/* __LINUX_FSNOTIFY_BACKEND_H */ diff --git a/include/linux/ftrace.h b/include/linux/ftrace.h index 8a0c2f221e6..39b95c56587 100644 --- a/include/linux/ftrace.h +++ b/include/linux/ftrace.h @@ -233,8 +233,6 @@ extern int ftrace_arch_read_dyn_info(char *buf, int size);  extern int skip_trace(unsigned long ip); -extern void ftrace_release(void *start, unsigned long size); -  extern void ftrace_disable_daemon(void);  extern void ftrace_enable_daemon(void);  #else @@ -325,13 +323,8 @@ static inline void __ftrace_enabled_restore(int enabled)  #ifdef CONFIG_FTRACE_MCOUNT_RECORD  extern void ftrace_init(void); -extern void ftrace_init_module(struct module *mod, -			       unsigned long *start, unsigned long *end);  #else  static inline void ftrace_init(void) { } -static inline void -ftrace_init_module(struct module *mod, -		   unsigned long *start, unsigned long *end) { }  #endif  /* @@ -368,6 +361,7 @@ struct ftrace_ret_stack {  	unsigned long ret;  	unsigned long func;  	unsigned long long calltime; +	unsigned long long subtime;  };  /* @@ -379,8 +373,6 @@ extern void return_to_handler(void);  extern int  ftrace_push_return_trace(unsigned long ret, unsigned long func, int *depth); -extern void -ftrace_pop_return_trace(struct ftrace_graph_ret *trace, unsigned long *ret);  /*   * Sometimes we don't want to trace a function with the function @@ -496,8 +488,15 @@ static inline int test_tsk_trace_graph(struct task_struct *tsk)  extern int ftrace_dump_on_oops; +#ifdef CONFIG_PREEMPT +#define INIT_TRACE_RECURSION		.trace_recursion = 0, +#endif +  #endif /* CONFIG_TRACING */ +#ifndef INIT_TRACE_RECURSION +#define INIT_TRACE_RECURSION +#endif  #ifdef CONFIG_HW_BRANCH_TRACER diff --git a/include/linux/ftrace_event.h b/include/linux/ftrace_event.h new file mode 100644 index 00000000000..5c093ffc655 --- /dev/null +++ b/include/linux/ftrace_event.h @@ -0,0 +1,172 @@ +#ifndef _LINUX_FTRACE_EVENT_H +#define _LINUX_FTRACE_EVENT_H + +#include <linux/trace_seq.h> +#include <linux/ring_buffer.h> +#include <linux/percpu.h> + +struct trace_array; +struct tracer; +struct dentry; + +DECLARE_PER_CPU(struct trace_seq, ftrace_event_seq); + +struct trace_print_flags { +	unsigned long		mask; +	const char		*name; +}; + +const char *ftrace_print_flags_seq(struct trace_seq *p, const char *delim, +				   unsigned long flags, +				   const struct trace_print_flags *flag_array); + +const char *ftrace_print_symbols_seq(struct trace_seq *p, unsigned long val, +				     const struct trace_print_flags *symbol_array); + +/* + * The trace entry - the most basic unit of tracing. This is what + * is printed in the end as a single line in the trace output, such as: + * + *     bash-15816 [01]   235.197585: idle_cpu <- irq_enter + */ +struct trace_entry { +	unsigned short		type; +	unsigned char		flags; +	unsigned char		preempt_count; +	int			pid; +	int			tgid; +}; + +#define FTRACE_MAX_EVENT						\ +	((1 << (sizeof(((struct trace_entry *)0)->type) * 8)) - 1) + +/* + * Trace iterator - used by printout routines who present trace + * results to users and which routines might sleep, etc: + */ +struct trace_iterator { +	struct trace_array	*tr; +	struct tracer		*trace; +	void			*private; +	int			cpu_file; +	struct mutex		mutex; +	struct ring_buffer_iter	*buffer_iter[NR_CPUS]; +	unsigned long		iter_flags; + +	/* The below is zeroed out in pipe_read */ +	struct trace_seq	seq; +	struct trace_entry	*ent; +	int			cpu; +	u64			ts; + +	loff_t			pos; +	long			idx; + +	cpumask_var_t		started; +}; + + +typedef enum print_line_t (*trace_print_func)(struct trace_iterator *iter, +					      int flags); +struct trace_event { +	struct hlist_node	node; +	struct list_head	list; +	int			type; +	trace_print_func	trace; +	trace_print_func	raw; +	trace_print_func	hex; +	trace_print_func	binary; +}; + +extern int register_ftrace_event(struct trace_event *event); +extern int unregister_ftrace_event(struct trace_event *event); + +/* Return values for print_line callback */ +enum print_line_t { +	TRACE_TYPE_PARTIAL_LINE	= 0,	/* Retry after flushing the seq */ +	TRACE_TYPE_HANDLED	= 1, +	TRACE_TYPE_UNHANDLED	= 2,	/* Relay to other output functions */ +	TRACE_TYPE_NO_CONSUME	= 3	/* Handled but ask to not consume */ +}; + + +struct ring_buffer_event * +trace_current_buffer_lock_reserve(int type, unsigned long len, +				  unsigned long flags, int pc); +void trace_current_buffer_unlock_commit(struct ring_buffer_event *event, +					unsigned long flags, int pc); +void trace_nowake_buffer_unlock_commit(struct ring_buffer_event *event, +					unsigned long flags, int pc); +void trace_current_buffer_discard_commit(struct ring_buffer_event *event); + +void tracing_record_cmdline(struct task_struct *tsk); + +struct ftrace_event_call { +	struct list_head	list; +	char			*name; +	char			*system; +	struct dentry		*dir; +	struct trace_event	*event; +	int			enabled; +	int			(*regfunc)(void); +	void			(*unregfunc)(void); +	int			id; +	int			(*raw_init)(void); +	int			(*show_format)(struct trace_seq *s); +	int			(*define_fields)(void); +	struct list_head	fields; +	int			filter_active; +	void			*filter; +	void			*mod; + +#ifdef CONFIG_EVENT_PROFILE +	atomic_t	profile_count; +	int		(*profile_enable)(struct ftrace_event_call *); +	void		(*profile_disable)(struct ftrace_event_call *); +#endif +}; + +#define MAX_FILTER_PRED		32 +#define MAX_FILTER_STR_VAL	128 + +extern int init_preds(struct ftrace_event_call *call); +extern void destroy_preds(struct ftrace_event_call *call); +extern int filter_match_preds(struct ftrace_event_call *call, void *rec); +extern int filter_current_check_discard(struct ftrace_event_call *call, +					void *rec, +					struct ring_buffer_event *event); + +extern int trace_define_field(struct ftrace_event_call *call, char *type, +			      char *name, int offset, int size, int is_signed); + +#define is_signed_type(type)	(((type)(-1)) < 0) + +int trace_set_clr_event(const char *system, const char *event, int set); + +/* + * The double __builtin_constant_p is because gcc will give us an error + * if we try to allocate the static variable to fmt if it is not a + * constant. Even with the outer if statement optimizing out. + */ +#define event_trace_printk(ip, fmt, args...)				\ +do {									\ +	__trace_printk_check_format(fmt, ##args);			\ +	tracing_record_cmdline(current);				\ +	if (__builtin_constant_p(fmt)) {				\ +		static const char *trace_printk_fmt			\ +		  __attribute__((section("__trace_printk_fmt"))) =	\ +			__builtin_constant_p(fmt) ? fmt : NULL;		\ +									\ +		__trace_bprintk(ip, trace_printk_fmt, ##args);		\ +	} else								\ +		__trace_printk(ip, fmt, ##args);			\ +} while (0) + +#define __common_field(type, item, is_signed)				\ +	ret = trace_define_field(event_call, #type, "common_" #item,	\ +				 offsetof(typeof(field.ent), item),	\ +				 sizeof(field.ent.item), is_signed);	\ +	if (ret)							\ +		return ret; + +#endif /* _LINUX_FTRACE_EVENT_H */ diff --git a/include/linux/fuse.h b/include/linux/fuse.h index 162e5defe68..d41ed593f79 100644 --- a/include/linux/fuse.h +++ b/include/linux/fuse.h @@ -121,6 +121,13 @@ struct fuse_file_lock {  #define FUSE_BIG_WRITES		(1 << 5)  /** + * CUSE INIT request/reply flags + * + * CUSE_UNRESTRICTED_IOCTL:  use unrestricted ioctl + */ +#define CUSE_UNRESTRICTED_IOCTL	(1 << 0) + +/**   * Release flags   */  #define FUSE_RELEASE_FLUSH	(1 << 0) @@ -210,6 +217,9 @@ enum fuse_opcode {  	FUSE_DESTROY       = 38,  	FUSE_IOCTL         = 39,  	FUSE_POLL          = 40, + +	/* CUSE specific operations */ +	CUSE_INIT          = 4096,  };  enum fuse_notify_code { @@ -401,6 +411,27 @@ struct fuse_init_out {  	__u32	max_write;  }; +#define CUSE_INIT_INFO_MAX 4096 + +struct cuse_init_in { +	__u32	major; +	__u32	minor; +	__u32	unused; +	__u32	flags; +}; + +struct cuse_init_out { +	__u32	major; +	__u32	minor; +	__u32	unused; +	__u32	flags; +	__u32	max_read; +	__u32	max_write; +	__u32	dev_major;		/* chardev major */ +	__u32	dev_minor;		/* chardev minor */ +	__u32	spare[10]; +}; +  struct fuse_interrupt_in {  	__u64	unique;  }; diff --git a/include/linux/futex.h b/include/linux/futex.h index 3bf5bb5a34f..34956c8fdeb 100644 --- a/include/linux/futex.h +++ b/include/linux/futex.h @@ -23,6 +23,8 @@ union ktime;  #define FUTEX_TRYLOCK_PI	8  #define FUTEX_WAIT_BITSET	9  #define FUTEX_WAKE_BITSET	10 +#define FUTEX_WAIT_REQUEUE_PI	11 +#define FUTEX_CMP_REQUEUE_PI	12  #define FUTEX_PRIVATE_FLAG	128  #define FUTEX_CLOCK_REALTIME	256 @@ -38,6 +40,10 @@ union ktime;  #define FUTEX_TRYLOCK_PI_PRIVATE (FUTEX_TRYLOCK_PI | FUTEX_PRIVATE_FLAG)  #define FUTEX_WAIT_BITSET_PRIVATE	(FUTEX_WAIT_BITS | FUTEX_PRIVATE_FLAG)  #define FUTEX_WAKE_BITSET_PRIVATE	(FUTEX_WAKE_BITS | FUTEX_PRIVATE_FLAG) +#define FUTEX_WAIT_REQUEUE_PI_PRIVATE	(FUTEX_WAIT_REQUEUE_PI | \ +					 FUTEX_PRIVATE_FLAG) +#define FUTEX_CMP_REQUEUE_PI_PRIVATE	(FUTEX_CMP_REQUEUE_PI | \ +					 FUTEX_PRIVATE_FLAG)  /*   * Support for robust futexes: the kernel cleans up held futexes at diff --git a/include/linux/genhd.h b/include/linux/genhd.h index a1a28caed23..7cbd38d363a 100644 --- a/include/linux/genhd.h +++ b/include/linux/genhd.h @@ -90,6 +90,7 @@ struct disk_stats {  struct hd_struct {  	sector_t start_sect;  	sector_t nr_sects; +	sector_t alignment_offset;  	struct device __dev;  	struct kobject *holder_dir;  	int policy, partno; @@ -113,6 +114,7 @@ struct hd_struct {  #define GENHD_FL_UP				16  #define GENHD_FL_SUPPRESS_PARTITION_INFO	32  #define GENHD_FL_EXT_DEVT			64 /* allow extended devt */ +#define GENHD_FL_NATIVE_CAPACITY		128  #define BLK_SCSI_MAX_CMDS	(256)  #define BLK_SCSI_CMD_PER_LONG	(BLK_SCSI_MAX_CMDS / (sizeof(long) * 8)) diff --git a/include/linux/gfp.h b/include/linux/gfp.h index 0bbc15f5453..3760e7c5de0 100644 --- a/include/linux/gfp.h +++ b/include/linux/gfp.h @@ -85,6 +85,9 @@ struct vm_area_struct;  			__GFP_NOWARN|__GFP_REPEAT|__GFP_NOFAIL|\  			__GFP_NORETRY|__GFP_NOMEMALLOC) +/* Control slab gfp mask during early boot */ +#define SLAB_GFP_BOOT_MASK __GFP_BITS_MASK & ~(__GFP_WAIT|__GFP_IO|__GFP_FS) +  /* Control allocation constraints */  #define GFP_CONSTRAINT_MASK (__GFP_HARDWALL|__GFP_THISNODE) diff --git a/include/linux/hid.h b/include/linux/hid.h index a72876e4358..53489fd4d70 100644 --- a/include/linux/hid.h +++ b/include/linux/hid.h @@ -238,6 +238,42 @@ struct hid_item {  #define HID_GD_RIGHT		0x00010092  #define HID_GD_LEFT		0x00010093 +#define HID_DG_DIGITIZER	0x000d0001 +#define HID_DG_PEN		0x000d0002 +#define HID_DG_LIGHTPEN		0x000d0003 +#define HID_DG_TOUCHSCREEN	0x000d0004 +#define HID_DG_TOUCHPAD		0x000d0005 +#define HID_DG_STYLUS		0x000d0020 +#define HID_DG_PUCK		0x000d0021 +#define HID_DG_FINGER		0x000d0022 +#define HID_DG_TIPPRESSURE	0x000d0030 +#define HID_DG_BARRELPRESSURE	0x000d0031 +#define HID_DG_INRANGE		0x000d0032 +#define HID_DG_TOUCH		0x000d0033 +#define HID_DG_UNTOUCH		0x000d0034 +#define HID_DG_TAP		0x000d0035 +#define HID_DG_TABLETFUNCTIONKEY	0x000d0039 +#define HID_DG_PROGRAMCHANGEKEY	0x000d003a +#define HID_DG_INVERT		0x000d003c +#define HID_DG_TIPSWITCH	0x000d0042 +#define HID_DG_TIPSWITCH2	0x000d0043 +#define HID_DG_BARRELSWITCH	0x000d0044 +#define HID_DG_ERASER		0x000d0045 +#define HID_DG_TABLETPICK	0x000d0046 +/* + * as of May 20, 2009 the usages below are not yet in the official USB spec + * but are being pushed by Microsft as described in their paper "Digitizer + * Drivers for Windows Touch and Pen-Based Computers" + */ +#define HID_DG_CONFIDENCE	0x000d0047 +#define HID_DG_WIDTH		0x000d0048 +#define HID_DG_HEIGHT		0x000d0049 +#define HID_DG_CONTACTID	0x000d0051 +#define HID_DG_INPUTMODE	0x000d0052 +#define HID_DG_DEVICEINDEX	0x000d0053 +#define HID_DG_CONTACTCOUNT	0x000d0054 +#define HID_DG_CONTACTMAX	0x000d0055 +  /*   * HID report types --- Ouch! HID spec says 1 2 3!   */ diff --git a/include/linux/hrtimer.h b/include/linux/hrtimer.h index 0d2f7c8a33d..7400900de94 100644 --- a/include/linux/hrtimer.h +++ b/include/linux/hrtimer.h @@ -30,8 +30,11 @@ struct hrtimer_cpu_base;   * Mode arguments of xxx_hrtimer functions:   */  enum hrtimer_mode { -	HRTIMER_MODE_ABS,	/* Time value is absolute */ -	HRTIMER_MODE_REL,	/* Time value is relative to now */ +	HRTIMER_MODE_ABS = 0x0,		/* Time value is absolute */ +	HRTIMER_MODE_REL = 0x1,		/* Time value is relative to now */ +	HRTIMER_MODE_PINNED = 0x02,	/* Timer is bound to CPU */ +	HRTIMER_MODE_ABS_PINNED = 0x02, +	HRTIMER_MODE_REL_PINNED = 0x03,  };  /* diff --git a/include/linux/i2c-ocores.h b/include/linux/i2c-ocores.h index 8ed591b0887..4d5e57ff661 100644 --- a/include/linux/i2c-ocores.h +++ b/include/linux/i2c-ocores.h @@ -14,6 +14,8 @@  struct ocores_i2c_platform_data {  	u32 regstep;   /* distance between registers */  	u32 clock_khz; /* input clock in kHz */ +	u8 num_devices; /* number of devices in the devices list */ +	struct i2c_board_info const *devices; /* devices connected to the bus */  };  #endif /* _LINUX_I2C_OCORES_H */ diff --git a/include/linux/i7300_idle.h b/include/linux/i7300_idle.h index 05a80c44513..1587b7dec50 100644 --- a/include/linux/i7300_idle.h +++ b/include/linux/i7300_idle.h @@ -16,35 +16,33 @@  struct fbd_ioat {  	unsigned int vendor;  	unsigned int ioat_dev; +	unsigned int enabled;  };  /*   * The i5000 chip-set has the same hooks as the i7300 - * but support is disabled by default because this driver - * has not been validated on that platform. + * but it is not enabled by default and must be manually + * manually enabled with "forceload=1" because it is + * only lightly validated.   */ -#define SUPPORT_I5000 0  static const struct fbd_ioat fbd_ioat_list[] = { -	{PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_IOAT_CNB}, -#if SUPPORT_I5000 -	{PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_IOAT}, -#endif +	{PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_IOAT_CNB, 1}, +	{PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_IOAT, 0},  	{0, 0}  };  /* table of devices that work with this driver */  static const struct pci_device_id pci_tbl[] = {  	{ PCI_DEVICE(PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_FBD_CNB) }, -#if SUPPORT_I5000  	{ PCI_DEVICE(PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_5000_ERR) }, -#endif  	{ } /* Terminating entry */  };  /* Check for known platforms with I/O-AT */  static inline int i7300_idle_platform_probe(struct pci_dev **fbd_dev, -						struct pci_dev **ioat_dev) +						struct pci_dev **ioat_dev, +						int enable_all)  {  	int i;  	struct pci_dev *memdev, *dmadev; @@ -69,6 +67,8 @@ static inline int i7300_idle_platform_probe(struct pci_dev **fbd_dev,  	for (i = 0; fbd_ioat_list[i].vendor != 0; i++) {  		if (dmadev->vendor == fbd_ioat_list[i].vendor &&  		    dmadev->device == fbd_ioat_list[i].ioat_dev) { +			if (!(fbd_ioat_list[i].enabled || enable_all)) +				continue;  			if (fbd_dev)  				*fbd_dev = memdev;  			if (ioat_dev) diff --git a/include/linux/ide.h b/include/linux/ide.h index ff65fffb078..a6c6a2fad7c 100644 --- a/include/linux/ide.h +++ b/include/linux/ide.h @@ -26,6 +26,9 @@  #include <asm/io.h>  #include <asm/mutex.h> +/* for request_sense */ +#include <linux/cdrom.h> +  #if defined(CONFIG_CRIS) || defined(CONFIG_FRV) || defined(CONFIG_MN10300)  # define SUPPORT_VLB_SYNC 0  #else @@ -175,7 +178,7 @@ typedef u8 hwif_chipset_t;  /*   * Structure to hold all information about the location of this port   */ -typedef struct hw_regs_s { +struct ide_hw {  	union {  		struct ide_io_ports	io_ports;  		unsigned long		io_ports_array[IDE_NR_PORTS]; @@ -183,12 +186,11 @@ typedef struct hw_regs_s {  	int		irq;			/* our irq number */  	ide_ack_intr_t	*ack_intr;		/* acknowledge interrupt */ -	hwif_chipset_t  chipset;  	struct device	*dev, *parent;  	unsigned long	config; -} hw_regs_t; +}; -static inline void ide_std_init_ports(hw_regs_t *hw, +static inline void ide_std_init_ports(struct ide_hw *hw,  				      unsigned long io_addr,  				      unsigned long ctl_addr)  { @@ -215,21 +217,12 @@ static inline void ide_std_init_ports(hw_regs_t *hw,  /*   * Special Driver Flags - * - * set_geometry	: respecify drive geometry - * recalibrate	: seek to cyl 0 - * set_multmode	: set multmode count - * reserved	: unused   */ -typedef union { -	unsigned all			: 8; -	struct { -		unsigned set_geometry	: 1; -		unsigned recalibrate	: 1; -		unsigned set_multmode	: 1; -		unsigned reserved	: 5; -	} b; -} special_t; +enum { +	IDE_SFLAG_SET_GEOMETRY		= (1 << 0), +	IDE_SFLAG_RECALIBRATE		= (1 << 1), +	IDE_SFLAG_SET_MULTMODE		= (1 << 2), +};  /*   * Status returned from various ide_ functions @@ -324,7 +317,6 @@ struct ide_cmd {  	unsigned int		cursg_ofs;  	struct request		*rq;		/* copy of request */ -	void			*special;	/* valid_t generally */  };  /* ATAPI packet command flags */ @@ -360,11 +352,7 @@ struct ide_atapi_pc {  	/* data buffer */  	u8 *buf; -	/* current buffer position */ -	u8 *cur_pos;  	int buf_size; -	/* missing/available data on the current buffer */ -	int b_count;  	/* the corresponding request */  	struct request *rq; @@ -377,10 +365,6 @@ struct ide_atapi_pc {  	 */  	u8 pc_buf[IDE_PC_BUFFER_SIZE]; -	/* idetape only */ -	struct idetape_bh *bh; -	char *b_data; -  	unsigned long timeout;  }; @@ -397,6 +381,7 @@ struct ide_drive_s;  struct ide_disk_ops {  	int		(*check)(struct ide_drive_s *, const char *);  	int		(*get_capacity)(struct ide_drive_s *); +	u64		(*set_capacity)(struct ide_drive_s *, u64);  	void		(*setup)(struct ide_drive_s *);  	void		(*flush)(struct ide_drive_s *);  	int		(*init_media)(struct ide_drive_s *, struct gendisk *); @@ -474,6 +459,8 @@ enum {  	IDE_DFLAG_NICE1			= (1 << 5),  	/* device is physically present */  	IDE_DFLAG_PRESENT		= (1 << 6), +	/* disable Host Protected Area */ +	IDE_DFLAG_NOHPA			= (1 << 7),  	/* id read from device (synthetic if not set) */  	IDE_DFLAG_ID_READ		= (1 << 8),  	IDE_DFLAG_NOPROBE		= (1 << 9), @@ -512,6 +499,7 @@ enum {  	/* write protect */  	IDE_DFLAG_WP			= (1 << 29),  	IDE_DFLAG_FORMAT_IN_PROGRESS	= (1 << 30), +	IDE_DFLAG_NIEN_QUIRK		= (1 << 31),  };  struct ide_drive_s { @@ -536,14 +524,13 @@ struct ide_drive_s {  	unsigned long sleep;		/* sleep until this time */  	unsigned long timeout;		/* max time to wait for irq */ -	special_t	special;	/* special action flags */ +	u8	special_flags;		/* special action flags */  	u8	select;			/* basic drive/head select reg value */  	u8	retry_pio;		/* retrying dma capable host in pio */  	u8	waiting_for_dma;	/* dma currently in progress */  	u8	dma;			/* atapi dma flag */ -        u8	quirk_list;	/* considered quirky, set for a specific host */          u8	init_speed;	/* transfer rate set at boot */          u8	current_speed;	/* current transfer rate set */  	u8	desired_speed;	/* desired transfer rate set */ @@ -568,8 +555,7 @@ struct ide_drive_s {  	unsigned int	drive_data;	/* used by set_pio_mode/dev_select() */  	unsigned int	failures;	/* current failure count */  	unsigned int	max_failures;	/* maximum allowed failure count */ -	u64		probed_capacity;/* initial reported media capacity (ide-cd only currently) */ - +	u64		probed_capacity;/* initial/native media capacity */  	u64		capacity64;	/* total number of sectors */  	int		lun;		/* logical unit */ @@ -593,16 +579,16 @@ struct ide_drive_s {  	/* callback for packet commands */  	int  (*pc_callback)(struct ide_drive_s *, int); -	void (*pc_update_buffers)(struct ide_drive_s *, struct ide_atapi_pc *); -	int  (*pc_io_buffers)(struct ide_drive_s *, struct ide_atapi_pc *, -			      unsigned int, int); -  	ide_startstop_t (*irq_handler)(struct ide_drive_s *);  	unsigned long atapi_flags;  	struct ide_atapi_pc request_sense_pc; -	struct request request_sense_rq; + +	/* current sense rq and buffer */ +	bool sense_rq_armed; +	struct request sense_rq; +	struct request_sense sense_data;  };  typedef struct ide_drive_s ide_drive_t; @@ -1109,7 +1095,7 @@ void ide_fix_driveid(u16 *);  extern void ide_fixstring(u8 *, const int, const int); -int ide_busy_sleep(ide_hwif_t *, unsigned long, int); +int ide_busy_sleep(ide_drive_t *, unsigned long, int);  int ide_wait_stat(ide_startstop_t *, ide_drive_t *, u8, u8, unsigned long); @@ -1174,7 +1160,10 @@ int ide_do_test_unit_ready(ide_drive_t *, struct gendisk *);  int ide_do_start_stop(ide_drive_t *, struct gendisk *, int);  int ide_set_media_lock(ide_drive_t *, struct gendisk *, int);  void ide_create_request_sense_cmd(ide_drive_t *, struct ide_atapi_pc *); -void ide_retry_pc(ide_drive_t *, struct gendisk *); +void ide_retry_pc(ide_drive_t *drive); + +void ide_prep_sense(ide_drive_t *drive, struct request *rq); +int ide_queue_sense_rq(ide_drive_t *drive, void *special);  int ide_cd_expiry(ide_drive_t *); @@ -1225,7 +1214,7 @@ static inline int ide_pci_is_in_compatibility_mode(struct pci_dev *dev)  }  void ide_pci_setup_ports(struct pci_dev *, const struct ide_port_info *, -			 hw_regs_t *, hw_regs_t **); +			 struct ide_hw *, struct ide_hw **);  void ide_setup_pci_noise(struct pci_dev *, const struct ide_port_info *);  #ifdef CONFIG_BLK_DEV_IDEDMA_PCI @@ -1464,16 +1453,18 @@ static inline void ide_acpi_set_state(ide_hwif_t *hwif, int on) {}  void ide_register_region(struct gendisk *);  void ide_unregister_region(struct gendisk *); +void ide_check_nien_quirk_list(ide_drive_t *);  void ide_undecoded_slave(ide_drive_t *);  void ide_port_apply_params(ide_hwif_t *);  int ide_sysfs_register_port(ide_hwif_t *); -struct ide_host *ide_host_alloc(const struct ide_port_info *, hw_regs_t **); +struct ide_host *ide_host_alloc(const struct ide_port_info *, struct ide_hw **, +				unsigned int);  void ide_host_free(struct ide_host *);  int ide_host_register(struct ide_host *, const struct ide_port_info *, -		      hw_regs_t **); -int ide_host_add(const struct ide_port_info *, hw_regs_t **, +		      struct ide_hw **); +int ide_host_add(const struct ide_port_info *, struct ide_hw **, unsigned int,  		 struct ide_host **);  void ide_host_remove(struct ide_host *);  int ide_legacy_device_add(const struct ide_port_info *, unsigned long); diff --git a/include/linux/ieee80211.h b/include/linux/ieee80211.h index 4b501b48ce8..a9173d5434d 100644 --- a/include/linux/ieee80211.h +++ b/include/linux/ieee80211.h @@ -493,6 +493,7 @@ struct ieee80211s_hdr {  /* Mesh flags */  #define MESH_FLAGS_AE_A4 	0x1  #define MESH_FLAGS_AE_A5_A6	0x2 +#define MESH_FLAGS_AE		0x3  #define MESH_FLAGS_PS_DEEP	0x4  /** @@ -540,10 +541,10 @@ struct ieee80211_tim_ie {  	u8 dtim_period;  	u8 bitmap_ctrl;  	/* variable size: 1 - 251 bytes */ -	u8 virtual_map[0]; +	u8 virtual_map[1];  } __attribute__ ((packed)); -#define WLAN_SA_QUERY_TR_ID_LEN 16 +#define WLAN_SA_QUERY_TR_ID_LEN 2  struct ieee80211_mgmt {  	__le16 frame_control; @@ -1068,8 +1069,12 @@ enum ieee80211_category {  	WLAN_CATEGORY_DLS = 2,  	WLAN_CATEGORY_BACK = 3,  	WLAN_CATEGORY_PUBLIC = 4, +	WLAN_CATEGORY_HT = 7,  	WLAN_CATEGORY_SA_QUERY = 8, +	WLAN_CATEGORY_PROTECTED_DUAL_OF_ACTION = 9,  	WLAN_CATEGORY_WMM = 17, +	WLAN_CATEGORY_VENDOR_SPECIFIC_PROTECTED = 126, +	WLAN_CATEGORY_VENDOR_SPECIFIC = 127,  };  /* SPECTRUM_MGMT action code */ @@ -1081,6 +1086,15 @@ enum ieee80211_spectrum_mgmt_actioncode {  	WLAN_ACTION_SPCT_CHL_SWITCH = 4,  }; +/* Security key length */ +enum ieee80211_key_len { +	WLAN_KEY_LEN_WEP40 = 5, +	WLAN_KEY_LEN_WEP104 = 13, +	WLAN_KEY_LEN_CCMP = 16, +	WLAN_KEY_LEN_TKIP = 32, +	WLAN_KEY_LEN_AES_CMAC = 16, +}; +  /*   * IEEE 802.11-2007 7.3.2.9 Country information element   * @@ -1261,7 +1275,9 @@ static inline bool ieee80211_is_robust_mgmt_frame(struct ieee80211_hdr *hdr)  		if (ieee80211_has_protected(hdr->frame_control))  			return true;  		category = ((u8 *) hdr) + 24; -		return *category != WLAN_CATEGORY_PUBLIC; +		return *category != WLAN_CATEGORY_PUBLIC && +			*category != WLAN_CATEGORY_HT && +			*category != WLAN_CATEGORY_VENDOR_SPECIFIC;  	}  	return false; @@ -1383,4 +1399,43 @@ static inline int ieee80211_freq_to_ofdm_chan(int s_freq, int freq)  		return -1;  } +/** + * ieee80211_tu_to_usec - convert time units (TU) to microseconds + * @tu: the TUs + */ +static inline unsigned long ieee80211_tu_to_usec(unsigned long tu) +{ +	return 1024 * tu; +} + +/** + * ieee80211_check_tim - check if AID bit is set in TIM + * @tim: the TIM IE + * @tim_len: length of the TIM IE + * @aid: the AID to look for + */ +static inline bool ieee80211_check_tim(struct ieee80211_tim_ie *tim, +				       u8 tim_len, u16 aid) +{ +	u8 mask; +	u8 index, indexn1, indexn2; + +	if (unlikely(!tim || tim_len < sizeof(*tim))) +		return false; + +	aid &= 0x3fff; +	index = aid / 8; +	mask  = 1 << (aid & 7); + +	indexn1 = tim->bitmap_ctrl & 0xfe; +	indexn2 = tim_len + indexn1 - 4; + +	if (index < indexn1 || index > indexn2) +		return false; + +	index -= indexn1; + +	return !!(tim->virtual_map[index] & mask); +} +  #endif /* LINUX_IEEE80211_H */ diff --git a/include/linux/if.h b/include/linux/if.h index 1108f3e099e..b9a6229f3be 100644 --- a/include/linux/if.h +++ b/include/linux/if.h @@ -67,6 +67,9 @@  #define IFF_ISATAP	0x80		/* ISATAP interface (RFC4214)	*/  #define IFF_MASTER_ARPMON 0x100		/* bonding master, ARP mon in use */  #define IFF_WAN_HDLC	0x200		/* WAN HDLC device		*/ +#define IFF_XMIT_DST_RELEASE 0x400	/* dev_hard_start_xmit() is allowed to +					 * release skb->dst +					 */  #define IF_GET_IFACE	0x0001		/* for querying only */  #define IF_GET_PROTO	0x0002 diff --git a/include/linux/if_arp.h b/include/linux/if_arp.h index 5ff89809a58..b554300ef8b 100644 --- a/include/linux/if_arp.h +++ b/include/linux/if_arp.h @@ -86,6 +86,8 @@  #define ARPHRD_IEEE80211 801		/* IEEE 802.11			*/  #define ARPHRD_IEEE80211_PRISM 802	/* IEEE 802.11 + Prism2 header  */  #define ARPHRD_IEEE80211_RADIOTAP 803	/* IEEE 802.11 + radiotap header */ +#define ARPHRD_IEEE802154	  804 +#define ARPHRD_IEEE802154_PHY	  805  #define ARPHRD_PHONET	820		/* PhoNet media type		*/  #define ARPHRD_PHONET_PIPE 821		/* PhoNet pipe header		*/ diff --git a/include/linux/if_ether.h b/include/linux/if_ether.h index cfe4fe1b713..ae3a1871413 100644 --- a/include/linux/if_ether.h +++ b/include/linux/if_ether.h @@ -79,6 +79,7 @@  #define ETH_P_AOE	0x88A2		/* ATA over Ethernet		*/  #define ETH_P_TIPC	0x88CA		/* TIPC 			*/  #define ETH_P_FCOE	0x8906		/* Fibre Channel over Ethernet  */ +#define ETH_P_FIP	0x8914		/* FCoE Initialization Protocol */  #define ETH_P_EDSA	0xDADA		/* Ethertype DSA [ NOT AN OFFICIALLY REGISTERED ID ] */  /* @@ -106,6 +107,7 @@  #define ETH_P_DSA	0x001B		/* Distributed Switch Arch.	*/  #define ETH_P_TRAILER	0x001C		/* Trailer switch tagging	*/  #define ETH_P_PHONET	0x00F5		/* Nokia Phonet frames          */ +#define ETH_P_IEEE802154 0x00F6		/* IEEE802.15.4 frame		*/  /*   *	This is an Ethernet frame header. diff --git a/include/linux/if_packet.h b/include/linux/if_packet.h index 18db0668065..dea7d6b7cf9 100644 --- a/include/linux/if_packet.h +++ b/include/linux/if_packet.h @@ -46,6 +46,8 @@ struct sockaddr_ll  #define PACKET_VERSION			10  #define PACKET_HDRLEN			11  #define PACKET_RESERVE			12 +#define PACKET_TX_RING			13 +#define PACKET_LOSS			14  struct tpacket_stats  { @@ -63,14 +65,22 @@ struct tpacket_auxdata  	__u16		tp_vlan_tci;  }; +/* Rx ring - header status */ +#define TP_STATUS_KERNEL	0x0 +#define TP_STATUS_USER		0x1 +#define TP_STATUS_COPY		0x2 +#define TP_STATUS_LOSING	0x4 +#define TP_STATUS_CSUMNOTREADY	0x8 + +/* Tx ring - header status */ +#define TP_STATUS_AVAILABLE	0x0 +#define TP_STATUS_SEND_REQUEST	0x1 +#define TP_STATUS_SENDING	0x2 +#define TP_STATUS_WRONG_FORMAT	0x4 +  struct tpacket_hdr  {  	unsigned long	tp_status; -#define TP_STATUS_KERNEL	0 -#define TP_STATUS_USER		1 -#define TP_STATUS_COPY		2 -#define TP_STATUS_LOSING	4 -#define TP_STATUS_CSUMNOTREADY	8  	unsigned int	tp_len;  	unsigned int	tp_snaplen;  	unsigned short	tp_mac; @@ -135,5 +145,6 @@ struct packet_mreq  #define PACKET_MR_MULTICAST	0  #define PACKET_MR_PROMISC	1  #define PACKET_MR_ALLMULTI	2 +#define PACKET_MR_UNICAST	3  #endif diff --git a/include/linux/if_tun.h b/include/linux/if_tun.h index 049d6c9428d..915ba5789f0 100644 --- a/include/linux/if_tun.h +++ b/include/linux/if_tun.h @@ -55,6 +55,7 @@  #define IFF_NO_PI	0x1000  #define IFF_ONE_QUEUE	0x2000  #define IFF_VNET_HDR	0x4000 +#define IFF_TUN_EXCL	0x8000  /* Features for GSO (TUNSETOFFLOAD). */  #define TUN_F_CSUM	0x01	/* You can hand me unchecksummed packets. */ diff --git a/include/linux/if_tunnel.h b/include/linux/if_tunnel.h index 5a9aae4adb4..5eb9b0f857e 100644 --- a/include/linux/if_tunnel.h +++ b/include/linux/if_tunnel.h @@ -44,7 +44,7 @@ struct ip_tunnel_prl {  	__u16			flags;  	__u16			__reserved;  	__u32			datalen; -	__u32			__reserved2; +	__u32			rs_delay;  	/* data follows */  }; diff --git a/include/linux/if_vlan.h b/include/linux/if_vlan.h index e1ff5b14310..7ff9af1d0f0 100644 --- a/include/linux/if_vlan.h +++ b/include/linux/if_vlan.h @@ -118,8 +118,7 @@ extern int vlan_hwaccel_do_receive(struct sk_buff *skb);  extern int vlan_gro_receive(struct napi_struct *napi, struct vlan_group *grp,  			    unsigned int vlan_tci, struct sk_buff *skb);  extern int vlan_gro_frags(struct napi_struct *napi, struct vlan_group *grp, -			  unsigned int vlan_tci, -			  struct napi_gro_fraginfo *info); +			  unsigned int vlan_tci);  #else  static inline struct net_device *vlan_dev_real_dev(const struct net_device *dev) @@ -154,8 +153,7 @@ static inline int vlan_gro_receive(struct napi_struct *napi,  }  static inline int vlan_gro_frags(struct napi_struct *napi, -				 struct vlan_group *grp, unsigned int vlan_tci, -				 struct napi_gro_fraginfo *info) +				 struct vlan_group *grp, unsigned int vlan_tci)  {  	return NET_RX_DROP;  } diff --git a/include/linux/ima.h b/include/linux/ima.h index 0e2aa45cb0c..b1b827d091a 100644 --- a/include/linux/ima.h +++ b/include/linux/ima.h @@ -13,14 +13,17 @@  #include <linux/fs.h>  struct linux_binprm; +#define IMA_COUNT_UPDATE 1 +#define IMA_COUNT_LEAVE 0 +  #ifdef CONFIG_IMA  extern int ima_bprm_check(struct linux_binprm *bprm);  extern int ima_inode_alloc(struct inode *inode);  extern void ima_inode_free(struct inode *inode); -extern int ima_path_check(struct path *path, int mask); +extern int ima_path_check(struct path *path, int mask, int update_counts);  extern void ima_file_free(struct file *file);  extern int ima_file_mmap(struct file *file, unsigned long prot); -extern void ima_shm_check(struct file *file); +extern void ima_counts_get(struct file *file);  #else  static inline int ima_bprm_check(struct linux_binprm *bprm) @@ -38,7 +41,7 @@ static inline void ima_inode_free(struct inode *inode)  	return;  } -static inline int ima_path_check(struct path *path, int mask) +static inline int ima_path_check(struct path *path, int mask, int update_counts)  {  	return 0;  } @@ -53,7 +56,7 @@ static inline int ima_file_mmap(struct file *file, unsigned long prot)  	return 0;  } -static inline void ima_shm_check(struct file *file) +static inline void ima_counts_get(struct file *file)  {  	return;  } diff --git a/include/linux/in.h b/include/linux/in.h index d60122a3a08..cf196da04ec 100644 --- a/include/linux/in.h +++ b/include/linux/in.h @@ -107,6 +107,7 @@ struct in_addr {  #define MCAST_JOIN_SOURCE_GROUP		46  #define MCAST_LEAVE_SOURCE_GROUP	47  #define MCAST_MSFILTER			48 +#define IP_MULTICAST_ALL		49  #define MCAST_EXCLUDE	0  #define MCAST_INCLUDE	1 diff --git a/include/linux/init.h b/include/linux/init.h index 0e06c176f18..b2189803f19 100644 --- a/include/linux/init.h +++ b/include/linux/init.h @@ -2,8 +2,6 @@  #define _LINUX_INIT_H  #include <linux/compiler.h> -#include <linux/section-names.h> -#include <linux/stringify.h>  /* These macros are used to mark some functions or    * initialized data (doesn't apply to uninitialized data) @@ -101,7 +99,7 @@  #define __memexitconst   __section(.memexit.rodata)  /* For assembly routines */ -#define __HEAD		.section	__stringify(HEAD_TEXT_SECTION),"ax" +#define __HEAD		.section	".head.text","ax"  #define __INIT		.section	".init.text","ax"  #define __FINIT		.previous @@ -225,7 +223,8 @@ struct obs_kernel_param {   * obs_kernel_param "array" too far apart in .init.setup.   */  #define __setup_param(str, unique_id, fn, early)			\ -	static char __setup_str_##unique_id[] __initdata __aligned(1) = str; \ +	static const char __setup_str_##unique_id[] __initconst	\ +		__aligned(1) = str; \  	static struct obs_kernel_param __setup_##unique_id	\  		__used __section(.init.setup)			\  		__attribute__((aligned((sizeof(long)))))	\ diff --git a/include/linux/init_task.h b/include/linux/init_task.h index d87247d2641..28b1f30601b 100644 --- a/include/linux/init_task.h +++ b/include/linux/init_task.h @@ -108,6 +108,15 @@ extern struct group_info init_groups;  extern struct cred init_cred; +#ifdef CONFIG_PERF_COUNTERS +# define INIT_PERF_COUNTERS(tsk)					\ +	.perf_counter_mutex = 						\ +		 __MUTEX_INITIALIZER(tsk.perf_counter_mutex),		\ +	.perf_counter_list = LIST_HEAD_INIT(tsk.perf_counter_list), +#else +# define INIT_PERF_COUNTERS(tsk) +#endif +  /*   *  INIT_TASK is used to set up the first task table, touch at   * your own risk!. Base=0, limit=0x1fffff (=2MB) @@ -145,8 +154,8 @@ extern struct cred init_cred;  	.group_leader	= &tsk,						\  	.real_cred	= &init_cred,					\  	.cred		= &init_cred,					\ -	.cred_exec_mutex =						\ -		 __MUTEX_INITIALIZER(tsk.cred_exec_mutex),		\ +	.cred_guard_mutex =						\ +		 __MUTEX_INITIALIZER(tsk.cred_guard_mutex),		\  	.comm		= "swapper",					\  	.thread		= INIT_THREAD,					\  	.fs		= &init_fs,					\ @@ -171,9 +180,11 @@ extern struct cred init_cred;  	},								\  	.dirties = INIT_PROP_LOCAL_SINGLE(dirties),			\  	INIT_IDS							\ +	INIT_PERF_COUNTERS(tsk)						\  	INIT_TRACE_IRQFLAGS						\  	INIT_LOCKDEP							\  	INIT_FTRACE_GRAPH						\ +	INIT_TRACE_RECURSION						\  } diff --git a/include/linux/input.h b/include/linux/input.h index 0e6ff5de358..6fed4f6a9c9 100644 --- a/include/linux/input.h +++ b/include/linux/input.h @@ -656,6 +656,7 @@ struct input_absinfo {  #define ABS_MT_POSITION_Y	0x36	/* Center Y ellipse position */  #define ABS_MT_TOOL_TYPE	0x37	/* Type of touching device */  #define ABS_MT_BLOB_ID		0x38	/* Group a set of packets as a blob */ +#define ABS_MT_TRACKING_ID	0x39	/* Unique ID of initiated contact */  #define ABS_MAX			0x3f  #define ABS_CNT			(ABS_MAX+1) diff --git a/include/linux/interrupt.h b/include/linux/interrupt.h index 91bb76f44f1..c41e812e9d5 100644 --- a/include/linux/interrupt.h +++ b/include/linux/interrupt.h @@ -183,6 +183,7 @@ extern void disable_irq(unsigned int irq);  extern void enable_irq(unsigned int irq);  /* The following three functions are for the core kernel use only. */ +#ifdef CONFIG_GENERIC_HARDIRQS  extern void suspend_device_irqs(void);  extern void resume_device_irqs(void);  #ifdef CONFIG_PM_SLEEP @@ -190,6 +191,11 @@ extern int check_wakeup_irqs(void);  #else  static inline int check_wakeup_irqs(void) { return 0; }  #endif +#else +static inline void suspend_device_irqs(void) { }; +static inline void resume_device_irqs(void) { }; +static inline int check_wakeup_irqs(void) { return 0; } +#endif  #if defined(CONFIG_SMP) && defined(CONFIG_GENERIC_HARDIRQS) @@ -566,6 +572,6 @@ struct irq_desc;  extern int early_irq_init(void);  extern int arch_probe_nr_irqs(void);  extern int arch_early_irq_init(void); -extern int arch_init_chip_data(struct irq_desc *desc, int cpu); +extern int arch_init_chip_data(struct irq_desc *desc, int node);  #endif diff --git a/include/linux/iocontext.h b/include/linux/iocontext.h index 08b987bccf8..dd05434fa45 100644 --- a/include/linux/iocontext.h +++ b/include/linux/iocontext.h @@ -64,7 +64,7 @@ struct cfq_io_context {   * and kmalloc'ed. These could be shared between processes.   */  struct io_context { -	atomic_t refcount; +	atomic_long_t refcount;  	atomic_t nr_tasks;  	/* all the fields below are protected by this lock */ @@ -91,8 +91,8 @@ static inline struct io_context *ioc_task_link(struct io_context *ioc)  	 * if ref count is zero, don't allow sharing (ioc is going away, it's  	 * a race).  	 */ -	if (ioc && atomic_inc_not_zero(&ioc->refcount)) { -		atomic_inc(&ioc->nr_tasks); +	if (ioc && atomic_long_inc_not_zero(&ioc->refcount)) { +		atomic_long_inc(&ioc->refcount);  		return ioc;  	} diff --git a/include/linux/ipv6.h b/include/linux/ipv6.h index 476d9464ac8..c662efa6828 100644 --- a/include/linux/ipv6.h +++ b/include/linux/ipv6.h @@ -169,6 +169,12 @@ struct ipv6_devconf {  	__s32		accept_dad;  	void		*sysctl;  }; + +struct ipv6_params { +	__s32 disable_ipv6; +	__s32 autoconf; +}; +extern struct ipv6_params ipv6_defaults;  #endif  /* index values for the variables in ipv6_devconf */ diff --git a/include/linux/irq.h b/include/linux/irq.h index b7cbeed972e..1e50c34f006 100644 --- a/include/linux/irq.h +++ b/include/linux/irq.h @@ -117,7 +117,7 @@ struct irq_chip {  	void		(*eoi)(unsigned int irq);  	void		(*end)(unsigned int irq); -	void		(*set_affinity)(unsigned int irq, +	int		(*set_affinity)(unsigned int irq,  					const struct cpumask *dest);  	int		(*retrigger)(unsigned int irq);  	int		(*set_type)(unsigned int irq, unsigned int flow_type); @@ -187,7 +187,7 @@ struct irq_desc {  	spinlock_t		lock;  #ifdef CONFIG_SMP  	cpumask_var_t		affinity; -	unsigned int		cpu; +	unsigned int		node;  #ifdef CONFIG_GENERIC_PENDING_IRQ  	cpumask_var_t		pending_mask;  #endif @@ -201,26 +201,23 @@ struct irq_desc {  } ____cacheline_internodealigned_in_smp;  extern void arch_init_copy_chip_data(struct irq_desc *old_desc, -					struct irq_desc *desc, int cpu); +					struct irq_desc *desc, int node);  extern void arch_free_chip_data(struct irq_desc *old_desc, struct irq_desc *desc);  #ifndef CONFIG_SPARSE_IRQ  extern struct irq_desc irq_desc[NR_IRQS]; -#else /* CONFIG_SPARSE_IRQ */ -extern struct irq_desc *move_irq_desc(struct irq_desc *old_desc, int cpu); -#endif /* CONFIG_SPARSE_IRQ */ - -extern struct irq_desc *irq_to_desc_alloc_cpu(unsigned int irq, int cpu); +#endif -static inline struct irq_desc * -irq_remap_to_desc(unsigned int irq, struct irq_desc *desc) -{ -#ifdef CONFIG_NUMA_MIGRATE_IRQ_DESC -	return irq_to_desc(irq); +#ifdef CONFIG_NUMA_IRQ_DESC +extern struct irq_desc *move_irq_desc(struct irq_desc *old_desc, int node);  #else +static inline struct irq_desc *move_irq_desc(struct irq_desc *desc, int node) +{  	return desc; -#endif  } +#endif + +extern struct irq_desc *irq_to_desc_alloc_node(unsigned int irq, int node);  /*   * Migration helpers for obsolete names, they will go away: @@ -386,7 +383,7 @@ extern void set_irq_noprobe(unsigned int irq);  extern void set_irq_probe(unsigned int irq);  /* Handle dynamic irq creation and destruction */ -extern unsigned int create_irq_nr(unsigned int irq_want); +extern unsigned int create_irq_nr(unsigned int irq_want, int node);  extern int create_irq(void);  extern void destroy_irq(unsigned int irq); @@ -424,47 +421,44 @@ extern int set_irq_msi(unsigned int irq, struct msi_desc *entry);  #ifdef CONFIG_SMP  /** - * init_alloc_desc_masks - allocate cpumasks for irq_desc + * alloc_desc_masks - allocate cpumasks for irq_desc   * @desc:	pointer to irq_desc struct   * @cpu:	cpu which will be handling the cpumasks   * @boot:	true if need bootmem   *   * Allocates affinity and pending_mask cpumask if required.   * Returns true if successful (or not required). - * Side effect: affinity has all bits set, pending_mask has all bits clear.   */ -static inline bool init_alloc_desc_masks(struct irq_desc *desc, int cpu, -								bool boot) +static inline bool alloc_desc_masks(struct irq_desc *desc, int node, +							bool boot)  { -	int node; - -	if (boot) { -		alloc_bootmem_cpumask_var(&desc->affinity); -		cpumask_setall(desc->affinity); - -#ifdef CONFIG_GENERIC_PENDING_IRQ -		alloc_bootmem_cpumask_var(&desc->pending_mask); -		cpumask_clear(desc->pending_mask); -#endif -		return true; -	} +	gfp_t gfp = GFP_ATOMIC; -	node = cpu_to_node(cpu); +	if (boot) +		gfp = GFP_NOWAIT; -	if (!alloc_cpumask_var_node(&desc->affinity, GFP_ATOMIC, node)) +#ifdef CONFIG_CPUMASK_OFFSTACK +	if (!alloc_cpumask_var_node(&desc->affinity, gfp, node))  		return false; -	cpumask_setall(desc->affinity);  #ifdef CONFIG_GENERIC_PENDING_IRQ -	if (!alloc_cpumask_var_node(&desc->pending_mask, GFP_ATOMIC, node)) { +	if (!alloc_cpumask_var_node(&desc->pending_mask, gfp, node)) {  		free_cpumask_var(desc->affinity);  		return false;  	} -	cpumask_clear(desc->pending_mask); +#endif  #endif  	return true;  } +static inline void init_desc_masks(struct irq_desc *desc) +{ +	cpumask_setall(desc->affinity); +#ifdef CONFIG_GENERIC_PENDING_IRQ +	cpumask_clear(desc->pending_mask); +#endif +} +  /**   * init_copy_desc_masks - copy cpumasks for irq_desc   * @old_desc:	pointer to old irq_desc struct @@ -478,7 +472,7 @@ static inline bool init_alloc_desc_masks(struct irq_desc *desc, int cpu,  static inline void init_copy_desc_masks(struct irq_desc *old_desc,  					struct irq_desc *new_desc)  { -#ifdef CONFIG_CPUMASKS_OFFSTACK +#ifdef CONFIG_CPUMASK_OFFSTACK  	cpumask_copy(new_desc->affinity, old_desc->affinity);  #ifdef CONFIG_GENERIC_PENDING_IRQ @@ -499,12 +493,16 @@ static inline void free_desc_masks(struct irq_desc *old_desc,  #else /* !CONFIG_SMP */ -static inline bool init_alloc_desc_masks(struct irq_desc *desc, int cpu, +static inline bool alloc_desc_masks(struct irq_desc *desc, int node,  								bool boot)  {  	return true;  } +static inline void init_desc_masks(struct irq_desc *desc) +{ +} +  static inline void init_copy_desc_masks(struct irq_desc *old_desc,  					struct irq_desc *new_desc)  { diff --git a/include/linux/isdn/capilli.h b/include/linux/isdn/capilli.h index 35e9b0fd014..7acb87a4487 100644 --- a/include/linux/isdn/capilli.h +++ b/include/linux/isdn/capilli.h @@ -79,7 +79,7 @@ int attach_capi_ctr(struct capi_ctr *);  int detach_capi_ctr(struct capi_ctr *);  void capi_ctr_ready(struct capi_ctr * card); -void capi_ctr_reseted(struct capi_ctr * card); +void capi_ctr_down(struct capi_ctr * card);  void capi_ctr_suspend_output(struct capi_ctr * card);  void capi_ctr_resume_output(struct capi_ctr * card);  void capi_ctr_handle_message(struct capi_ctr * card, u16 appl, struct sk_buff *skb); diff --git a/include/linux/kernel.h b/include/linux/kernel.h index 883cd44ff76..1b2e1747df1 100644 --- a/include/linux/kernel.h +++ b/include/linux/kernel.h @@ -97,12 +97,14 @@ extern const char linux_proc_banner[];  #define	KERN_INFO	"<6>"	/* informational			*/  #define	KERN_DEBUG	"<7>"	/* debug-level messages			*/ +/* Use the default kernel loglevel */ +#define KERN_DEFAULT	"<d>"  /*   * Annotation for a "continued" line of log printout (only done after a   * line that had no enclosing \n). Only to be used by core/arch code   * during early bootup (a continued line is not SMP-safe otherwise).   */ -#define	KERN_CONT	"" +#define	KERN_CONT	"<c>"  extern int console_printk[]; diff --git a/include/linux/kernel_stat.h b/include/linux/kernel_stat.h index 0c8b89f28a9..a77c6007dc9 100644 --- a/include/linux/kernel_stat.h +++ b/include/linux/kernel_stat.h @@ -81,7 +81,12 @@ static inline unsigned int kstat_irqs(unsigned int irq)  	return sum;  } + +/* + * Lock/unlock the current runqueue - to extract task statistics: + */  extern unsigned long long task_delta_exec(struct task_struct *); +  extern void account_user_time(struct task_struct *, cputime_t, cputime_t);  extern void account_system_time(struct task_struct *, int, cputime_t, cputime_t);  extern void account_steal_time(cputime_t); diff --git a/include/linux/keyboard.h b/include/linux/keyboard.h index a3c984d780f..33a63f62d57 100644 --- a/include/linux/keyboard.h +++ b/include/linux/keyboard.h @@ -56,6 +56,7 @@ extern int unregister_keyboard_notifier(struct notifier_block *nb);  #define KT_ASCII	9  #define KT_LOCK		10  #define KT_SLOCK	12 +#define KT_DEAD2	13  #define KT_BRL		14  #define K(t,v)		(((t)<<8)|(v)) diff --git a/include/linux/kmemleak.h b/include/linux/kmemleak.h new file mode 100644 index 00000000000..7796aed6cdd --- /dev/null +++ b/include/linux/kmemleak.h @@ -0,0 +1,96 @@ +/* + * include/linux/kmemleak.h + * + * Copyright (C) 2008 ARM Limited + * Written by Catalin Marinas <catalin.marinas@arm.com> + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License 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. + * + * You should have received a copy of the GNU General Public License + * along with this program; if not, write to the Free Software + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA + */ + +#ifndef __KMEMLEAK_H +#define __KMEMLEAK_H + +#ifdef CONFIG_DEBUG_KMEMLEAK + +extern void kmemleak_init(void); +extern void kmemleak_alloc(const void *ptr, size_t size, int min_count, +			   gfp_t gfp); +extern void kmemleak_free(const void *ptr); +extern void kmemleak_padding(const void *ptr, unsigned long offset, +			     size_t size); +extern void kmemleak_not_leak(const void *ptr); +extern void kmemleak_ignore(const void *ptr); +extern void kmemleak_scan_area(const void *ptr, unsigned long offset, +			       size_t length, gfp_t gfp); +extern void kmemleak_no_scan(const void *ptr); + +static inline void kmemleak_alloc_recursive(const void *ptr, size_t size, +					    int min_count, unsigned long flags, +					    gfp_t gfp) +{ +	if (!(flags & SLAB_NOLEAKTRACE)) +		kmemleak_alloc(ptr, size, min_count, gfp); +} + +static inline void kmemleak_free_recursive(const void *ptr, unsigned long flags) +{ +	if (!(flags & SLAB_NOLEAKTRACE)) +		kmemleak_free(ptr); +} + +static inline void kmemleak_erase(void **ptr) +{ +	*ptr = NULL; +} + +#else + +static inline void kmemleak_init(void) +{ +} +static inline void kmemleak_alloc(const void *ptr, size_t size, int min_count, +				  gfp_t gfp) +{ +} +static inline void kmemleak_alloc_recursive(const void *ptr, size_t size, +					    int min_count, unsigned long flags, +					    gfp_t gfp) +{ +} +static inline void kmemleak_free(const void *ptr) +{ +} +static inline void kmemleak_free_recursive(const void *ptr, unsigned long flags) +{ +} +static inline void kmemleak_not_leak(const void *ptr) +{ +} +static inline void kmemleak_ignore(const void *ptr) +{ +} +static inline void kmemleak_scan_area(const void *ptr, unsigned long offset, +				      size_t length, gfp_t gfp) +{ +} +static inline void kmemleak_erase(void **ptr) +{ +} +static inline void kmemleak_no_scan(const void *ptr) +{ +} + +#endif	/* CONFIG_DEBUG_KMEMLEAK */ + +#endif	/* __KMEMLEAK_H */ diff --git a/include/linux/kmemtrace.h b/include/linux/kmemtrace.h new file mode 100644 index 00000000000..b616d3930c3 --- /dev/null +++ b/include/linux/kmemtrace.h @@ -0,0 +1,25 @@ +/* + * Copyright (C) 2008 Eduard - Gabriel Munteanu + * + * This file is released under GPL version 2. + */ + +#ifndef _LINUX_KMEMTRACE_H +#define _LINUX_KMEMTRACE_H + +#ifdef __KERNEL__ + +#include <trace/events/kmem.h> + +#ifdef CONFIG_KMEMTRACE +extern void kmemtrace_init(void); +#else +static inline void kmemtrace_init(void) +{ +} +#endif + +#endif /* __KERNEL__ */ + +#endif /* _LINUX_KMEMTRACE_H */ + diff --git a/include/linux/kvm.h b/include/linux/kvm.h index 8cc137911b3..3db5d8d3748 100644 --- a/include/linux/kvm.h +++ b/include/linux/kvm.h @@ -119,7 +119,7 @@ struct kvm_run {  			__u32 error_code;  		} ex;  		/* KVM_EXIT_IO */ -		struct kvm_io { +		struct {  #define KVM_EXIT_IO_IN  0  #define KVM_EXIT_IO_OUT 1  			__u8 direction; @@ -224,10 +224,10 @@ struct kvm_interrupt {  /* for KVM_GET_DIRTY_LOG */  struct kvm_dirty_log {  	__u32 slot; -	__u32 padding; +	__u32 padding1;  	union {  		void __user *dirty_bitmap; /* one bit per page */ -		__u64 padding; +		__u64 padding2;  	};  }; @@ -409,6 +409,10 @@ struct kvm_trace_rec {  #ifdef __KVM_HAVE_DEVICE_ASSIGNMENT  #define KVM_CAP_DEVICE_DEASSIGNMENT 27  #endif +#ifdef __KVM_HAVE_MSIX +#define KVM_CAP_DEVICE_MSIX 28 +#endif +#define KVM_CAP_ASSIGN_DEV_IRQ 29  /* Another bug in KVM_SET_USER_MEMORY_REGION fixed: */  #define KVM_CAP_JOIN_MEMORY_REGIONS_WORKS 30 @@ -482,11 +486,18 @@ struct kvm_irq_routing {  #define KVM_ASSIGN_PCI_DEVICE _IOR(KVMIO, 0x69, \  				   struct kvm_assigned_pci_dev)  #define KVM_SET_GSI_ROUTING       _IOW(KVMIO, 0x6a, struct kvm_irq_routing) +/* deprecated, replaced by KVM_ASSIGN_DEV_IRQ */  #define KVM_ASSIGN_IRQ _IOR(KVMIO, 0x70, \  			    struct kvm_assigned_irq) +#define KVM_ASSIGN_DEV_IRQ        _IOW(KVMIO, 0x70, struct kvm_assigned_irq)  #define KVM_REINJECT_CONTROL      _IO(KVMIO, 0x71)  #define KVM_DEASSIGN_PCI_DEVICE _IOW(KVMIO, 0x72, \  				     struct kvm_assigned_pci_dev) +#define KVM_ASSIGN_SET_MSIX_NR \ +			_IOW(KVMIO, 0x73, struct kvm_assigned_msix_nr) +#define KVM_ASSIGN_SET_MSIX_ENTRY \ +			_IOW(KVMIO, 0x74, struct kvm_assigned_msix_entry) +#define KVM_DEASSIGN_DEV_IRQ       _IOW(KVMIO, 0x75, struct kvm_assigned_irq)  /*   * ioctls for vcpu fds @@ -577,6 +588,8 @@ struct kvm_debug_guest {  #define KVM_TRC_STLB_INVAL       (KVM_TRC_HANDLER + 0x18)  #define KVM_TRC_PPC_INSTR        (KVM_TRC_HANDLER + 0x19) +#define KVM_DEV_ASSIGN_ENABLE_IOMMU	(1 << 0) +  struct kvm_assigned_pci_dev {  	__u32 assigned_dev_id;  	__u32 busnr; @@ -587,6 +600,17 @@ struct kvm_assigned_pci_dev {  	};  }; +#define KVM_DEV_IRQ_HOST_INTX    (1 << 0) +#define KVM_DEV_IRQ_HOST_MSI     (1 << 1) +#define KVM_DEV_IRQ_HOST_MSIX    (1 << 2) + +#define KVM_DEV_IRQ_GUEST_INTX   (1 << 8) +#define KVM_DEV_IRQ_GUEST_MSI    (1 << 9) +#define KVM_DEV_IRQ_GUEST_MSIX   (1 << 10) + +#define KVM_DEV_IRQ_HOST_MASK	 0x00ff +#define KVM_DEV_IRQ_GUEST_MASK   0xff00 +  struct kvm_assigned_irq {  	__u32 assigned_dev_id;  	__u32 host_irq; @@ -602,9 +626,19 @@ struct kvm_assigned_irq {  	};  }; -#define KVM_DEV_ASSIGN_ENABLE_IOMMU	(1 << 0) -#define KVM_DEV_IRQ_ASSIGN_MSI_ACTION	KVM_DEV_IRQ_ASSIGN_ENABLE_MSI -#define KVM_DEV_IRQ_ASSIGN_ENABLE_MSI	(1 << 0) +struct kvm_assigned_msix_nr { +	__u32 assigned_dev_id; +	__u16 entry_nr; +	__u16 padding; +}; + +#define KVM_MAX_MSIX_PER_DEV		512 +struct kvm_assigned_msix_entry { +	__u32 assigned_dev_id; +	__u32 gsi; +	__u16 entry; /* The index of entry in the MSI-X table */ +	__u16 padding[3]; +};  #endif diff --git a/include/linux/kvm_host.h b/include/linux/kvm_host.h index 894a56e365e..aacc5449f58 100644 --- a/include/linux/kvm_host.h +++ b/include/linux/kvm_host.h @@ -38,6 +38,7 @@  #define KVM_REQ_UNHALT             6  #define KVM_REQ_MMU_SYNC           7  #define KVM_REQ_KVMCLOCK_UPDATE    8 +#define KVM_REQ_KICK               9  #define KVM_USERSPACE_IRQ_SOURCE_ID	0 @@ -72,7 +73,6 @@ struct kvm_vcpu {  	struct mutex mutex;  	int   cpu;  	struct kvm_run *run; -	int guest_mode;  	unsigned long requests;  	unsigned long guest_debug;  	int fpu_active; @@ -298,6 +298,7 @@ int kvm_arch_hardware_setup(void);  void kvm_arch_hardware_unsetup(void);  void kvm_arch_check_processor_compat(void *rtn);  int kvm_arch_vcpu_runnable(struct kvm_vcpu *vcpu); +int kvm_arch_interrupt_allowed(struct kvm_vcpu *vcpu);  void kvm_free_physmem(struct kvm *kvm); @@ -319,6 +320,13 @@ struct kvm_irq_ack_notifier {  	void (*irq_acked)(struct kvm_irq_ack_notifier *kian);  }; +#define KVM_ASSIGNED_MSIX_PENDING		0x1 +struct kvm_guest_msix_entry { +	u32 vector; +	u16 entry; +	u16 flags; +}; +  struct kvm_assigned_dev_kernel {  	struct kvm_irq_ack_notifier ack_notifier;  	struct work_struct interrupt_work; @@ -326,18 +334,18 @@ struct kvm_assigned_dev_kernel {  	int assigned_dev_id;  	int host_busnr;  	int host_devfn; +	unsigned int entries_nr;  	int host_irq;  	bool host_irq_disabled; +	struct msix_entry *host_msix_entries;  	int guest_irq; -#define KVM_ASSIGNED_DEV_GUEST_INTX	(1 << 0) -#define KVM_ASSIGNED_DEV_GUEST_MSI	(1 << 1) -#define KVM_ASSIGNED_DEV_HOST_INTX	(1 << 8) -#define KVM_ASSIGNED_DEV_HOST_MSI	(1 << 9) +	struct kvm_guest_msix_entry *guest_msix_entries;  	unsigned long irq_requested_type;  	int irq_source_id;  	int flags;  	struct pci_dev *dev;  	struct kvm *kvm; +	spinlock_t assigned_dev_lock;  };  struct kvm_irq_mask_notifier { @@ -360,6 +368,9 @@ void kvm_unregister_irq_ack_notifier(struct kvm_irq_ack_notifier *kian);  int kvm_request_irq_source_id(struct kvm *kvm);  void kvm_free_irq_source_id(struct kvm *kvm, int irq_source_id); +/* For vcpu->arch.iommu_flags */ +#define KVM_IOMMU_CACHE_COHERENCY	0x1 +  #ifdef CONFIG_IOMMU_API  int kvm_iommu_map_pages(struct kvm *kvm, gfn_t base_gfn,  			unsigned long npages); diff --git a/include/linux/kvm_types.h b/include/linux/kvm_types.h index 2b8318c83e5..fb46efbeabe 100644 --- a/include/linux/kvm_types.h +++ b/include/linux/kvm_types.h @@ -40,4 +40,31 @@ typedef unsigned long  hfn_t;  typedef hfn_t pfn_t; +union kvm_ioapic_redirect_entry { +	u64 bits; +	struct { +		u8 vector; +		u8 delivery_mode:3; +		u8 dest_mode:1; +		u8 delivery_status:1; +		u8 polarity:1; +		u8 remote_irr:1; +		u8 trig_mode:1; +		u8 mask:1; +		u8 reserve:7; +		u8 reserved[4]; +		u8 dest_id; +	} fields; +}; + +struct kvm_lapic_irq { +	u32 vector; +	u32 delivery_mode; +	u32 dest_mode; +	u32 level; +	u32 trig_mode; +	u32 shorthand; +	u32 dest_id; +}; +  #endif /* __KVM_TYPES_H__ */ diff --git a/include/linux/lguest.h b/include/linux/lguest.h index 175e63f4a8c..7bc1440fc47 100644 --- a/include/linux/lguest.h +++ b/include/linux/lguest.h @@ -30,6 +30,10 @@ struct lguest_data  	/* Wallclock time set by the Host. */  	struct timespec time; +	/* Interrupt pending set by the Host.  The Guest should do a hypercall +	 * if it re-enables interrupts and sees this set (to X86_EFLAGS_IF). */ +	int irq_pending; +  	/* Async hypercall ring.  Instead of directly making hypercalls, we can  	 * place them in here for processing the next time the Host wants.  	 * This batching can be quite efficient. */ diff --git a/include/linux/lguest_launcher.h b/include/linux/lguest_launcher.h index a53407a4165..bfefbdf7498 100644 --- a/include/linux/lguest_launcher.h +++ b/include/linux/lguest_launcher.h @@ -57,7 +57,8 @@ enum lguest_req  	LHREQ_INITIALIZE, /* + base, pfnlimit, start */  	LHREQ_GETDMA, /* No longer used */  	LHREQ_IRQ, /* + irq */ -	LHREQ_BREAK, /* + on/off flag (on blocks until someone does off) */ +	LHREQ_BREAK, /* No longer used */ +	LHREQ_EVENTFD, /* + address, fd. */  };  /* The alignment to use between consumer and producer parts of vring. diff --git a/include/linux/list_nulls.h b/include/linux/list_nulls.h index 93150ecf3ea..5d10ae364b5 100644 --- a/include/linux/list_nulls.h +++ b/include/linux/list_nulls.h @@ -56,6 +56,18 @@ static inline int hlist_nulls_empty(const struct hlist_nulls_head *h)  	return is_a_nulls(h->first);  } +static inline void hlist_nulls_add_head(struct hlist_nulls_node *n, +					struct hlist_nulls_head *h) +{ +	struct hlist_nulls_node *first = h->first; + +	n->next = first; +	n->pprev = &h->first; +	h->first = n; +	if (!is_a_nulls(first)) +		first->pprev = &n->next; +} +  static inline void __hlist_nulls_del(struct hlist_nulls_node *n)  {  	struct hlist_nulls_node *next = n->next; @@ -65,6 +77,12 @@ static inline void __hlist_nulls_del(struct hlist_nulls_node *n)  		next->pprev = pprev;  } +static inline void hlist_nulls_del(struct hlist_nulls_node *n) +{ +	__hlist_nulls_del(n); +	n->pprev = LIST_POISON2; +} +  /**   * hlist_nulls_for_each_entry	- iterate over list of given type   * @tpos:	the type * to use as a loop cursor. diff --git a/include/linux/loop.h b/include/linux/loop.h index 40725447f5e..66c194e2d9b 100644 --- a/include/linux/loop.h +++ b/include/linux/loop.h @@ -56,8 +56,7 @@ struct loop_device {  	gfp_t		old_gfp_mask;  	spinlock_t		lo_lock; -	struct bio 		*lo_bio; -	struct bio		*lo_biotail; +	struct bio_list		lo_bio_list;  	int			lo_state;  	struct mutex		lo_ctl_mutex;  	struct task_struct	*lo_thread; diff --git a/include/linux/lsm_audit.h b/include/linux/lsm_audit.h new file mode 100644 index 00000000000..e461b2c3d71 --- /dev/null +++ b/include/linux/lsm_audit.h @@ -0,0 +1,111 @@ +/* + * Common LSM logging functions + * Heavily borrowed from selinux/avc.h + * + * Author : Etienne BASSET  <etienne.basset@ensta.org> + * + * All credits to : Stephen Smalley, <sds@epoch.ncsc.mil> + * All BUGS to : Etienne BASSET  <etienne.basset@ensta.org> + */ +#ifndef _LSM_COMMON_LOGGING_ +#define _LSM_COMMON_LOGGING_ + +#include <linux/stddef.h> +#include <linux/errno.h> +#include <linux/kernel.h> +#include <linux/kdev_t.h> +#include <linux/spinlock.h> +#include <linux/init.h> +#include <linux/audit.h> +#include <linux/in6.h> +#include <linux/path.h> +#include <linux/key.h> +#include <linux/skbuff.h> +#include <asm/system.h> + + +/* Auxiliary data to use in generating the audit record. */ +struct common_audit_data { +	char    type; +#define LSM_AUDIT_DATA_FS      1 +#define LSM_AUDIT_DATA_NET     2 +#define LSM_AUDIT_DATA_CAP     3 +#define LSM_AUDIT_DATA_IPC     4 +#define LSM_AUDIT_DATA_TASK    5 +#define LSM_AUDIT_DATA_KEY     6 +	struct task_struct *tsk; +	union 	{ +		struct { +			struct path path; +			struct inode *inode; +		} fs; +		struct { +			int netif; +			struct sock *sk; +			u16 family; +			__be16 dport; +			__be16 sport; +			union { +				struct { +					__be32 daddr; +					__be32 saddr; +				} v4; +				struct { +					struct in6_addr daddr; +					struct in6_addr saddr; +				} v6; +			} fam; +		} net; +		int cap; +		int ipc_id; +		struct task_struct *tsk; +#ifdef CONFIG_KEYS +		struct { +			key_serial_t key; +			char *key_desc; +		} key_struct; +#endif +	} u; +	const char *function; +	/* this union contains LSM specific data */ +	union { +		/* SMACK data */ +		struct smack_audit_data { +			char *subject; +			char *object; +			char *request; +			int result; +		} smack_audit_data; +		/* SELinux data */ +		struct { +			u32 ssid; +			u32 tsid; +			u16 tclass; +			u32 requested; +			u32 audited; +			struct av_decision *avd; +			int result; +		} selinux_audit_data; +	} lsm_priv; +	/* these callback will be implemented by a specific LSM */ +	void (*lsm_pre_audit)(struct audit_buffer *, void *); +	void (*lsm_post_audit)(struct audit_buffer *, void *); +}; + +#define v4info fam.v4 +#define v6info fam.v6 + +int ipv4_skb_to_auditdata(struct sk_buff *skb, +		struct common_audit_data *ad, u8 *proto); + +int ipv6_skb_to_auditdata(struct sk_buff *skb, +		struct common_audit_data *ad, u8 *proto); + +/* Initialize an LSM audit data structure. */ +#define COMMON_AUDIT_DATA_INIT(_d, _t) \ +	{ memset((_d), 0, sizeof(struct common_audit_data)); \ +	 (_d)->type = LSM_AUDIT_DATA_##_t; (_d)->function = __func__; } + +void common_lsm_audit(struct common_audit_data *a); + +#endif diff --git a/include/linux/mISDNdsp.h b/include/linux/mISDNdsp.h index 6b71d2dce50..41d1eeb9b3b 100644 --- a/include/linux/mISDNdsp.h +++ b/include/linux/mISDNdsp.h @@ -12,7 +12,8 @@ struct mISDN_dsp_element {  	void	*(*new)(const char *arg);  	void	(*free)(void *p);  	void	(*process_tx)(void *p, unsigned char *data, int len); -	void	(*process_rx)(void *p, unsigned char *data, int len); +	void	(*process_rx)(void *p, unsigned char *data, int len, +			unsigned int txlen);  	int	num_args;  	struct mISDN_dsp_element_arg  		*args; @@ -24,6 +25,7 @@ extern void mISDN_dsp_element_unregister(struct mISDN_dsp_element *elem);  struct dsp_features {  	int	hfc_id; /* unique id to identify the chip (or -1) */  	int	hfc_dtmf; /* set if HFCmulti card supports dtmf */ +	int	hfc_conf; /* set if HFCmulti card supports conferences */  	int	hfc_loops; /* set if card supports tone loops */  	int	hfc_echocanhw; /* set if card supports echocancelation*/  	int	pcm_id; /* unique id to identify the pcm bus (or -1) */ diff --git a/include/linux/mISDNhw.h b/include/linux/mISDNhw.h index 97ffdc1d344..7f9831da847 100644 --- a/include/linux/mISDNhw.h +++ b/include/linux/mISDNhw.h @@ -89,11 +89,6 @@ struct dchannel {  	void			(*phfunc) (struct dchannel *);  	u_int			state;  	void			*l1; -	/* HW access */ -	u_char			(*read_reg) (void *, u_char); -	void			(*write_reg) (void *, u_char, u_char); -	void			(*read_fifo) (void *, u_char *, int); -	void			(*write_fifo) (void *, u_char *, int);  	void			*hw;  	int			slot;	/* multiport card channel slot */  	struct timer_list	timer; @@ -151,11 +146,6 @@ struct bchannel {  	u_long			Flags;  	struct work_struct	workq;  	u_int			state; -	/* HW access */ -	u_char			(*read_reg) (void *, u_char); -	void			(*write_reg) (void *, u_char, u_char); -	void			(*read_fifo) (void *, u_char *, int); -	void			(*write_fifo) (void *, u_char *, int);  	void			*hw;  	int			slot;	/* multiport card channel slot */  	struct timer_list	timer; @@ -185,7 +175,7 @@ extern int	dchannel_senddata(struct dchannel *, struct sk_buff *);  extern int	bchannel_senddata(struct bchannel *, struct sk_buff *);  extern void	recv_Dchannel(struct dchannel *);  extern void	recv_Echannel(struct dchannel *, struct dchannel *); -extern void	recv_Bchannel(struct bchannel *); +extern void	recv_Bchannel(struct bchannel *, unsigned int id);  extern void	recv_Dchannel_skb(struct dchannel *, struct sk_buff *);  extern void	recv_Bchannel_skb(struct bchannel *, struct sk_buff *);  extern void	confirm_Bsend(struct bchannel *bch); diff --git a/include/linux/mISDNif.h b/include/linux/mISDNif.h index 5da3d95b27f..45100b39a7c 100644 --- a/include/linux/mISDNif.h +++ b/include/linux/mISDNif.h @@ -229,6 +229,7 @@  #define OPTION_L2_PTP		2  #define OPTION_L2_FIXEDTEI	3  #define OPTION_L2_CLEANUP	4 +#define OPTION_L1_HOLD		5  /* should be in sync with linux/kobject.h:KOBJ_NAME_LEN */  #define MISDN_MAX_IDLEN		20 @@ -291,19 +292,19 @@ struct mISDN_devrename {  /* MPH_INFORMATION_REQ payload */  struct ph_info_ch { -        __u32 protocol; -        __u64 Flags; +	__u32 protocol; +	__u64 Flags;  };  struct ph_info_dch { -        struct ph_info_ch ch; -        __u16 state; -        __u16 num_bch; +	struct ph_info_ch ch; +	__u16 state; +	__u16 num_bch;  };  struct ph_info { -        struct ph_info_dch dch; -        struct ph_info_ch  bch[]; +	struct ph_info_dch dch; +	struct ph_info_ch  bch[];  };  /* timer device ioctl */ @@ -317,6 +318,7 @@ struct ph_info {  #define IMCTRLREQ	_IOR('I', 69, int)  #define IMCLEAR_L2	_IOR('I', 70, int)  #define IMSETDEVNAME	_IOR('I', 71, struct mISDN_devrename) +#define IMHOLD_L1	_IOR('I', 72, int)  static inline int  test_channelmap(u_int nr, u_char *map) @@ -362,7 +364,8 @@ clear_channelmap(u_int nr, u_char *map)  #define MISDN_CTRL_HFC_RECEIVE_ON	0x4006  #define MISDN_CTRL_HFC_ECHOCAN_ON 	0x4007  #define MISDN_CTRL_HFC_ECHOCAN_OFF 	0x4008 - +#define MISDN_CTRL_HFC_WD_INIT		0x4009 +#define MISDN_CTRL_HFC_WD_RESET		0x400A  /* socket options */  #define MISDN_TIME_STAMP		0x0001 diff --git a/include/linux/magic.h b/include/linux/magic.h index 5b4e28bcb78..1923327b986 100644 --- a/include/linux/magic.h +++ b/include/linux/magic.h @@ -6,9 +6,12 @@  #define AFS_SUPER_MAGIC                0x5346414F  #define AUTOFS_SUPER_MAGIC	0x0187  #define CODA_SUPER_MAGIC	0x73757245 +#define CRAMFS_MAGIC		0x28cd3d45	/* some random number */ +#define CRAMFS_MAGIC_WEND	0x453dcd28	/* magic number with the wrong endianess */  #define DEBUGFS_MAGIC          0x64626720  #define SYSFS_MAGIC		0x62656572  #define SECURITYFS_MAGIC	0x73636673 +#define SELINUX_MAGIC		0xf97cff8c  #define TMPFS_MAGIC		0x01021994  #define SQUASHFS_MAGIC		0x73717368  #define EFS_SUPER_MAGIC		0x414A53 diff --git a/include/linux/mdio.h b/include/linux/mdio.h new file mode 100644 index 00000000000..cfdf1df2875 --- /dev/null +++ b/include/linux/mdio.h @@ -0,0 +1,356 @@ +/* + * linux/mdio.h: definitions for MDIO (clause 45) transceivers + * Copyright 2006-2009 Solarflare Communications Inc. + * + * This program is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 as published + * by the Free Software Foundation, incorporated herein by reference. + */ + +#ifndef __LINUX_MDIO_H__ +#define __LINUX_MDIO_H__ + +#include <linux/mii.h> + +/* MDIO Manageable Devices (MMDs). */ +#define MDIO_MMD_PMAPMD		1	/* Physical Medium Attachment/ +					 * Physical Medium Dependent */ +#define MDIO_MMD_WIS		2	/* WAN Interface Sublayer */ +#define MDIO_MMD_PCS		3	/* Physical Coding Sublayer */ +#define MDIO_MMD_PHYXS		4	/* PHY Extender Sublayer */ +#define MDIO_MMD_DTEXS		5	/* DTE Extender Sublayer */ +#define MDIO_MMD_TC		6	/* Transmission Convergence */ +#define MDIO_MMD_AN		7	/* Auto-Negotiation */ +#define MDIO_MMD_C22EXT		29	/* Clause 22 extension */ +#define MDIO_MMD_VEND1		30	/* Vendor specific 1 */ +#define MDIO_MMD_VEND2		31	/* Vendor specific 2 */ + +/* Generic MDIO registers. */ +#define MDIO_CTRL1		MII_BMCR +#define MDIO_STAT1		MII_BMSR +#define MDIO_DEVID1		MII_PHYSID1 +#define MDIO_DEVID2		MII_PHYSID2 +#define MDIO_SPEED		4	/* Speed ability */ +#define MDIO_DEVS1		5	/* Devices in package */ +#define MDIO_DEVS2		6 +#define MDIO_CTRL2		7	/* 10G control 2 */ +#define MDIO_STAT2		8	/* 10G status 2 */ +#define MDIO_PMA_TXDIS		9	/* 10G PMA/PMD transmit disable */ +#define MDIO_PMA_RXDET		10	/* 10G PMA/PMD receive signal detect */ +#define MDIO_PMA_EXTABLE	11	/* 10G PMA/PMD extended ability */ +#define MDIO_PKGID1		14	/* Package identifier */ +#define MDIO_PKGID2		15 +#define MDIO_AN_ADVERTISE	16	/* AN advertising (base page) */ +#define MDIO_AN_LPA		19	/* AN LP abilities (base page) */ +#define MDIO_PHYXS_LNSTAT	24	/* PHY XGXS lane state */ + +/* Media-dependent registers. */ +#define MDIO_PMA_10GBT_SWAPPOL	130	/* 10GBASE-T pair swap & polarity */ +#define MDIO_PMA_10GBT_TXPWR	131	/* 10GBASE-T TX power control */ +#define MDIO_PMA_10GBT_SNR	133	/* 10GBASE-T SNR margin, lane A. +					 * Lanes B-D are numbered 134-136. */ +#define MDIO_PMA_10GBR_FECABLE	170	/* 10GBASE-R FEC ability */ +#define MDIO_PCS_10GBX_STAT1	24	/* 10GBASE-X PCS status 1 */ +#define MDIO_PCS_10GBRT_STAT1	32	/* 10GBASE-R/-T PCS status 1 */ +#define MDIO_PCS_10GBRT_STAT2	33	/* 10GBASE-R/-T PCS status 2 */ +#define MDIO_AN_10GBT_CTRL	32	/* 10GBASE-T auto-negotiation control */ +#define MDIO_AN_10GBT_STAT	33	/* 10GBASE-T auto-negotiation status */ + +/* LASI (Link Alarm Status Interrupt) registers, defined by XENPAK MSA. */ +#define MDIO_PMA_LASI_RXCTRL	0x9000	/* RX_ALARM control */ +#define MDIO_PMA_LASI_TXCTRL	0x9001	/* TX_ALARM control */ +#define MDIO_PMA_LASI_CTRL	0x9002	/* LASI control */ +#define MDIO_PMA_LASI_RXSTAT	0x9003	/* RX_ALARM status */ +#define MDIO_PMA_LASI_TXSTAT	0x9004	/* TX_ALARM status */ +#define MDIO_PMA_LASI_STAT	0x9005	/* LASI status */ + +/* Control register 1. */ +/* Enable extended speed selection */ +#define MDIO_CTRL1_SPEEDSELEXT		(BMCR_SPEED1000 | BMCR_SPEED100) +/* All speed selection bits */ +#define MDIO_CTRL1_SPEEDSEL		(MDIO_CTRL1_SPEEDSELEXT | 0x003c) +#define MDIO_CTRL1_FULLDPLX		BMCR_FULLDPLX +#define MDIO_CTRL1_LPOWER		BMCR_PDOWN +#define MDIO_CTRL1_RESET		BMCR_RESET +#define MDIO_PMA_CTRL1_LOOPBACK		0x0001 +#define MDIO_PMA_CTRL1_SPEED1000	BMCR_SPEED1000 +#define MDIO_PMA_CTRL1_SPEED100		BMCR_SPEED100 +#define MDIO_PCS_CTRL1_LOOPBACK		BMCR_LOOPBACK +#define MDIO_PHYXS_CTRL1_LOOPBACK	BMCR_LOOPBACK +#define MDIO_AN_CTRL1_RESTART		BMCR_ANRESTART +#define MDIO_AN_CTRL1_ENABLE		BMCR_ANENABLE +#define MDIO_AN_CTRL1_XNP		0x2000	/* Enable extended next page */ + +/* 10 Gb/s */ +#define MDIO_CTRL1_SPEED10G		(MDIO_CTRL1_SPEEDSELEXT | 0x00) +/* 10PASS-TS/2BASE-TL */ +#define MDIO_CTRL1_SPEED10P2B		(MDIO_CTRL1_SPEEDSELEXT | 0x04) + +/* Status register 1. */ +#define MDIO_STAT1_LPOWERABLE		0x0002	/* Low-power ability */ +#define MDIO_STAT1_LSTATUS		BMSR_LSTATUS +#define MDIO_STAT1_FAULT		0x0080	/* Fault */ +#define MDIO_AN_STAT1_LPABLE		0x0001	/* Link partner AN ability */ +#define MDIO_AN_STAT1_ABLE		BMSR_ANEGCAPABLE +#define MDIO_AN_STAT1_RFAULT		BMSR_RFAULT +#define MDIO_AN_STAT1_COMPLETE		BMSR_ANEGCOMPLETE +#define MDIO_AN_STAT1_PAGE		0x0040	/* Page received */ +#define MDIO_AN_STAT1_XNP		0x0080	/* Extended next page status */ + +/* Speed register. */ +#define MDIO_SPEED_10G			0x0001	/* 10G capable */ +#define MDIO_PMA_SPEED_2B		0x0002	/* 2BASE-TL capable */ +#define MDIO_PMA_SPEED_10P		0x0004	/* 10PASS-TS capable */ +#define MDIO_PMA_SPEED_1000		0x0010	/* 1000M capable */ +#define MDIO_PMA_SPEED_100		0x0020	/* 100M capable */ +#define MDIO_PMA_SPEED_10		0x0040	/* 10M capable */ +#define MDIO_PCS_SPEED_10P2B		0x0002	/* 10PASS-TS/2BASE-TL capable */ + +/* Device present registers. */ +#define MDIO_DEVS_PRESENT(devad)	(1 << (devad)) +#define MDIO_DEVS_PMAPMD		MDIO_DEVS_PRESENT(MDIO_MMD_PMAPMD) +#define MDIO_DEVS_WIS			MDIO_DEVS_PRESENT(MDIO_MMD_WIS) +#define MDIO_DEVS_PCS			MDIO_DEVS_PRESENT(MDIO_MMD_PCS) +#define MDIO_DEVS_PHYXS			MDIO_DEVS_PRESENT(MDIO_MMD_PHYXS) +#define MDIO_DEVS_DTEXS			MDIO_DEVS_PRESENT(MDIO_MMD_DTEXS) +#define MDIO_DEVS_TC			MDIO_DEVS_PRESENT(MDIO_MMD_TC) +#define MDIO_DEVS_AN			MDIO_DEVS_PRESENT(MDIO_MMD_AN) +#define MDIO_DEVS_C22EXT		MDIO_DEVS_PRESENT(MDIO_MMD_C22EXT) + +/* Control register 2. */ +#define MDIO_PMA_CTRL2_TYPE		0x000f	/* PMA/PMD type selection */ +#define MDIO_PMA_CTRL2_10GBCX4		0x0000	/* 10GBASE-CX4 type */ +#define MDIO_PMA_CTRL2_10GBEW		0x0001	/* 10GBASE-EW type */ +#define MDIO_PMA_CTRL2_10GBLW		0x0002	/* 10GBASE-LW type */ +#define MDIO_PMA_CTRL2_10GBSW		0x0003	/* 10GBASE-SW type */ +#define MDIO_PMA_CTRL2_10GBLX4		0x0004	/* 10GBASE-LX4 type */ +#define MDIO_PMA_CTRL2_10GBER		0x0005	/* 10GBASE-ER type */ +#define MDIO_PMA_CTRL2_10GBLR		0x0006	/* 10GBASE-LR type */ +#define MDIO_PMA_CTRL2_10GBSR		0x0007	/* 10GBASE-SR type */ +#define MDIO_PMA_CTRL2_10GBLRM		0x0008	/* 10GBASE-LRM type */ +#define MDIO_PMA_CTRL2_10GBT		0x0009	/* 10GBASE-T type */ +#define MDIO_PMA_CTRL2_10GBKX4		0x000a	/* 10GBASE-KX4 type */ +#define MDIO_PMA_CTRL2_10GBKR		0x000b	/* 10GBASE-KR type */ +#define MDIO_PMA_CTRL2_1000BT		0x000c	/* 1000BASE-T type */ +#define MDIO_PMA_CTRL2_1000BKX		0x000d	/* 1000BASE-KX type */ +#define MDIO_PMA_CTRL2_100BTX		0x000e	/* 100BASE-TX type */ +#define MDIO_PMA_CTRL2_10BT		0x000f	/* 10BASE-T type */ +#define MDIO_PCS_CTRL2_TYPE		0x0003	/* PCS type selection */ +#define MDIO_PCS_CTRL2_10GBR		0x0000	/* 10GBASE-R type */ +#define MDIO_PCS_CTRL2_10GBX		0x0001	/* 10GBASE-X type */ +#define MDIO_PCS_CTRL2_10GBW		0x0002	/* 10GBASE-W type */ +#define MDIO_PCS_CTRL2_10GBT		0x0003	/* 10GBASE-T type */ + +/* Status register 2. */ +#define MDIO_STAT2_RXFAULT		0x0400	/* Receive fault */ +#define MDIO_STAT2_TXFAULT		0x0800	/* Transmit fault */ +#define MDIO_STAT2_DEVPRST		0xc000	/* Device present */ +#define MDIO_STAT2_DEVPRST_VAL		0x8000	/* Device present value */ +#define MDIO_PMA_STAT2_LBABLE		0x0001	/* PMA loopback ability */ +#define MDIO_PMA_STAT2_10GBEW		0x0002	/* 10GBASE-EW ability */ +#define MDIO_PMA_STAT2_10GBLW		0x0004	/* 10GBASE-LW ability */ +#define MDIO_PMA_STAT2_10GBSW		0x0008	/* 10GBASE-SW ability */ +#define MDIO_PMA_STAT2_10GBLX4		0x0010	/* 10GBASE-LX4 ability */ +#define MDIO_PMA_STAT2_10GBER		0x0020	/* 10GBASE-ER ability */ +#define MDIO_PMA_STAT2_10GBLR		0x0040	/* 10GBASE-LR ability */ +#define MDIO_PMA_STAT2_10GBSR		0x0080	/* 10GBASE-SR ability */ +#define MDIO_PMD_STAT2_TXDISAB		0x0100	/* PMD TX disable ability */ +#define MDIO_PMA_STAT2_EXTABLE		0x0200	/* Extended abilities */ +#define MDIO_PMA_STAT2_RXFLTABLE	0x1000	/* Receive fault ability */ +#define MDIO_PMA_STAT2_TXFLTABLE	0x2000	/* Transmit fault ability */ +#define MDIO_PCS_STAT2_10GBR		0x0001	/* 10GBASE-R capable */ +#define MDIO_PCS_STAT2_10GBX		0x0002	/* 10GBASE-X capable */ +#define MDIO_PCS_STAT2_10GBW		0x0004	/* 10GBASE-W capable */ +#define MDIO_PCS_STAT2_RXFLTABLE	0x1000	/* Receive fault ability */ +#define MDIO_PCS_STAT2_TXFLTABLE	0x2000	/* Transmit fault ability */ + +/* Transmit disable register. */ +#define MDIO_PMD_TXDIS_GLOBAL		0x0001	/* Global PMD TX disable */ +#define MDIO_PMD_TXDIS_0		0x0002	/* PMD TX disable 0 */ +#define MDIO_PMD_TXDIS_1		0x0004	/* PMD TX disable 1 */ +#define MDIO_PMD_TXDIS_2		0x0008	/* PMD TX disable 2 */ +#define MDIO_PMD_TXDIS_3		0x0010	/* PMD TX disable 3 */ + +/* Receive signal detect register. */ +#define MDIO_PMD_RXDET_GLOBAL		0x0001	/* Global PMD RX signal detect */ +#define MDIO_PMD_RXDET_0		0x0002	/* PMD RX signal detect 0 */ +#define MDIO_PMD_RXDET_1		0x0004	/* PMD RX signal detect 1 */ +#define MDIO_PMD_RXDET_2		0x0008	/* PMD RX signal detect 2 */ +#define MDIO_PMD_RXDET_3		0x0010	/* PMD RX signal detect 3 */ + +/* Extended abilities register. */ +#define MDIO_PMA_EXTABLE_10GCX4		0x0001	/* 10GBASE-CX4 ability */ +#define MDIO_PMA_EXTABLE_10GBLRM	0x0002	/* 10GBASE-LRM ability */ +#define MDIO_PMA_EXTABLE_10GBT		0x0004	/* 10GBASE-T ability */ +#define MDIO_PMA_EXTABLE_10GBKX4	0x0008	/* 10GBASE-KX4 ability */ +#define MDIO_PMA_EXTABLE_10GBKR		0x0010	/* 10GBASE-KR ability */ +#define MDIO_PMA_EXTABLE_1000BT		0x0020	/* 1000BASE-T ability */ +#define MDIO_PMA_EXTABLE_1000BKX	0x0040	/* 1000BASE-KX ability */ +#define MDIO_PMA_EXTABLE_100BTX		0x0080	/* 100BASE-TX ability */ +#define MDIO_PMA_EXTABLE_10BT		0x0100	/* 10BASE-T ability */ + +/* PHY XGXS lane state register. */ +#define MDIO_PHYXS_LNSTAT_SYNC0		0x0001 +#define MDIO_PHYXS_LNSTAT_SYNC1		0x0002 +#define MDIO_PHYXS_LNSTAT_SYNC2		0x0004 +#define MDIO_PHYXS_LNSTAT_SYNC3		0x0008 +#define MDIO_PHYXS_LNSTAT_ALIGN		0x1000 + +/* PMA 10GBASE-T pair swap & polarity */ +#define MDIO_PMA_10GBT_SWAPPOL_ABNX	0x0001	/* Pair A/B uncrossed */ +#define MDIO_PMA_10GBT_SWAPPOL_CDNX	0x0002	/* Pair C/D uncrossed */ +#define MDIO_PMA_10GBT_SWAPPOL_AREV	0x0100	/* Pair A polarity reversed */ +#define MDIO_PMA_10GBT_SWAPPOL_BREV	0x0200	/* Pair B polarity reversed */ +#define MDIO_PMA_10GBT_SWAPPOL_CREV	0x0400	/* Pair C polarity reversed */ +#define MDIO_PMA_10GBT_SWAPPOL_DREV	0x0800	/* Pair D polarity reversed */ + +/* PMA 10GBASE-T TX power register. */ +#define MDIO_PMA_10GBT_TXPWR_SHORT	0x0001	/* Short-reach mode */ + +/* PMA 10GBASE-T SNR registers. */ +/* Value is SNR margin in dB, clamped to range [-127, 127], plus 0x8000. */ +#define MDIO_PMA_10GBT_SNR_BIAS		0x8000 +#define MDIO_PMA_10GBT_SNR_MAX		127 + +/* PMA 10GBASE-R FEC ability register. */ +#define MDIO_PMA_10GBR_FECABLE_ABLE	0x0001	/* FEC ability */ +#define MDIO_PMA_10GBR_FECABLE_ERRABLE	0x0002	/* FEC error indic. ability */ + +/* PCS 10GBASE-R/-T status register 1. */ +#define MDIO_PCS_10GBRT_STAT1_BLKLK	0x0001	/* Block lock attained */ + +/* PCS 10GBASE-R/-T status register 2. */ +#define MDIO_PCS_10GBRT_STAT2_ERR	0x00ff +#define MDIO_PCS_10GBRT_STAT2_BER	0x3f00 + +/* AN 10GBASE-T control register. */ +#define MDIO_AN_10GBT_CTRL_ADV10G	0x1000	/* Advertise 10GBASE-T */ + +/* AN 10GBASE-T status register. */ +#define MDIO_AN_10GBT_STAT_LPTRR	0x0200	/* LP training reset req. */ +#define MDIO_AN_10GBT_STAT_LPLTABLE	0x0400	/* LP loop timing ability */ +#define MDIO_AN_10GBT_STAT_LP10G	0x0800	/* LP is 10GBT capable */ +#define MDIO_AN_10GBT_STAT_REMOK	0x1000	/* Remote OK */ +#define MDIO_AN_10GBT_STAT_LOCOK	0x2000	/* Local OK */ +#define MDIO_AN_10GBT_STAT_MS		0x4000	/* Master/slave config */ +#define MDIO_AN_10GBT_STAT_MSFLT	0x8000	/* Master/slave config fault */ + +/* LASI RX_ALARM control/status registers. */ +#define MDIO_PMA_LASI_RX_PHYXSLFLT	0x0001	/* PHY XS RX local fault */ +#define MDIO_PMA_LASI_RX_PCSLFLT	0x0008	/* PCS RX local fault */ +#define MDIO_PMA_LASI_RX_PMALFLT	0x0010	/* PMA/PMD RX local fault */ +#define MDIO_PMA_LASI_RX_OPTICPOWERFLT	0x0020	/* RX optical power fault */ +#define MDIO_PMA_LASI_RX_WISLFLT	0x0200	/* WIS local fault */ + +/* LASI TX_ALARM control/status registers. */ +#define MDIO_PMA_LASI_TX_PHYXSLFLT	0x0001	/* PHY XS TX local fault */ +#define MDIO_PMA_LASI_TX_PCSLFLT	0x0008	/* PCS TX local fault */ +#define MDIO_PMA_LASI_TX_PMALFLT	0x0010	/* PMA/PMD TX local fault */ +#define MDIO_PMA_LASI_TX_LASERPOWERFLT	0x0080	/* Laser output power fault */ +#define MDIO_PMA_LASI_TX_LASERTEMPFLT	0x0100	/* Laser temperature fault */ +#define MDIO_PMA_LASI_TX_LASERBICURRFLT	0x0200	/* Laser bias current fault */ + +/* LASI control/status registers. */ +#define MDIO_PMA_LASI_LSALARM		0x0001	/* LS_ALARM enable/status */ +#define MDIO_PMA_LASI_TXALARM		0x0002	/* TX_ALARM enable/status */ +#define MDIO_PMA_LASI_RXALARM		0x0004	/* RX_ALARM enable/status */ + +/* Mapping between MDIO PRTAD/DEVAD and mii_ioctl_data::phy_id */ + +#define MDIO_PHY_ID_C45			0x8000 +#define MDIO_PHY_ID_PRTAD		0x03e0 +#define MDIO_PHY_ID_DEVAD		0x001f +#define MDIO_PHY_ID_C45_MASK						\ +	(MDIO_PHY_ID_C45 | MDIO_PHY_ID_PRTAD | MDIO_PHY_ID_DEVAD) + +static inline __u16 mdio_phy_id_c45(int prtad, int devad) +{ +	return MDIO_PHY_ID_C45 | (prtad << 5) | devad; +} + +static inline bool mdio_phy_id_is_c45(int phy_id) +{ +	return (phy_id & MDIO_PHY_ID_C45) && !(phy_id & ~MDIO_PHY_ID_C45_MASK); +} + +static inline __u16 mdio_phy_id_prtad(int phy_id) +{ +	return (phy_id & MDIO_PHY_ID_PRTAD) >> 5; +} + +static inline __u16 mdio_phy_id_devad(int phy_id) +{ +	return phy_id & MDIO_PHY_ID_DEVAD; +} + +#define MDIO_SUPPORTS_C22		1 +#define MDIO_SUPPORTS_C45		2 + +#ifdef __KERNEL__  + +/** + * struct mdio_if_info - Ethernet controller MDIO interface + * @prtad: PRTAD of the PHY (%MDIO_PRTAD_NONE if not present/unknown) + * @mmds: Mask of MMDs expected to be present in the PHY.  This must be + *	non-zero unless @prtad = %MDIO_PRTAD_NONE. + * @mode_support: MDIO modes supported.  If %MDIO_SUPPORTS_C22 is set then + *	MII register access will be passed through with @devad = + *	%MDIO_DEVAD_NONE.  If %MDIO_EMULATE_C22 is set then access to + *	commonly used clause 22 registers will be translated into + *	clause 45 registers. + * @dev: Net device structure + * @mdio_read: Register read function; returns value or negative error code + * @mdio_write: Register write function; returns 0 or negative error code + */ +struct mdio_if_info { +	int prtad; +	u32 __bitwise mmds; +	unsigned mode_support; + +	struct net_device *dev; +	int (*mdio_read)(struct net_device *dev, int prtad, int devad, +			 u16 addr); +	int (*mdio_write)(struct net_device *dev, int prtad, int devad, +			  u16 addr, u16 val); +}; + +#define MDIO_PRTAD_NONE			(-1) +#define MDIO_DEVAD_NONE			(-1) +#define MDIO_EMULATE_C22		4 + +struct ethtool_cmd; +struct ethtool_pauseparam; +extern int mdio45_probe(struct mdio_if_info *mdio, int prtad); +extern int mdio_set_flag(const struct mdio_if_info *mdio, +			 int prtad, int devad, u16 addr, int mask, +			 bool sense); +extern int mdio45_links_ok(const struct mdio_if_info *mdio, u32 mmds); +extern int mdio45_nway_restart(const struct mdio_if_info *mdio); +extern void mdio45_ethtool_gset_npage(const struct mdio_if_info *mdio, +				      struct ethtool_cmd *ecmd, +				      u32 npage_adv, u32 npage_lpa); +extern void +mdio45_ethtool_spauseparam_an(const struct mdio_if_info *mdio, +			      const struct ethtool_pauseparam *ecmd); + +/** + * mdio45_ethtool_gset - get settings for ETHTOOL_GSET + * @mdio: MDIO interface + * @ecmd: Ethtool request structure + * + * Since the CSRs for auto-negotiation using next pages are not fully + * standardised, this function does not attempt to decode them.  Use + * mdio45_ethtool_gset_npage() to specify advertisement bits from next + * pages. + */ +static inline void mdio45_ethtool_gset(const struct mdio_if_info *mdio, +				       struct ethtool_cmd *ecmd) +{ +	mdio45_ethtool_gset_npage(mdio, ecmd, 0, 0); +} + +extern int mdio_mii_ioctl(const struct mdio_if_info *mdio, +			  struct mii_ioctl_data *mii_data, int cmd); + +#endif /* __KERNEL__ */ +#endif /* __LINUX_MDIO_H__ */ diff --git a/include/linux/mfd/tmio.h b/include/linux/mfd/tmio.h index 516d955ab8a..c377118884e 100644 --- a/include/linux/mfd/tmio.h +++ b/include/linux/mfd/tmio.h @@ -19,6 +19,13 @@  	} while (0)  /* + * data for the MMC controller + */ +struct tmio_mmc_data { +	unsigned int		hclk; +}; + +/*   * data for the NAND controller   */  struct tmio_nand_data { diff --git a/include/linux/mg_disk.h b/include/linux/mg_disk.h index 1f76b1ebf62..e11f4d9f1c2 100644 --- a/include/linux/mg_disk.h +++ b/include/linux/mg_disk.h @@ -1,8 +1,7 @@  /*   *  include/linux/mg_disk.c   * - *  Support for the mGine m[g]flash IO mode. - *  Based on legacy hd.c + *  Private data for mflash platform driver   *   * (c) 2008 mGine Co.,LTD   * (c) 2008 unsik Kim <donari75@gmail.com> @@ -15,127 +14,13 @@  #ifndef __MG_DISK_H__  #define __MG_DISK_H__ -#include <linux/blkdev.h> -#include <linux/ata.h> - -/* name for block device */ -#define MG_DISK_NAME "mgd"  /* name for platform device */  #define MG_DEV_NAME "mg_disk" -#define MG_DISK_MAJ 0 -#define MG_DISK_MAX_PART 16 -#define MG_SECTOR_SIZE 512 -#define MG_MAX_SECTS 256 - -/* Register offsets */ -#define MG_BUFF_OFFSET			0x8000 -#define MG_STORAGE_BUFFER_SIZE		0x200 -#define MG_REG_OFFSET			0xC000 -#define MG_REG_FEATURE			(MG_REG_OFFSET + 2)	/* write case */ -#define MG_REG_ERROR			(MG_REG_OFFSET + 2)	/* read case */ -#define MG_REG_SECT_CNT			(MG_REG_OFFSET + 4) -#define MG_REG_SECT_NUM			(MG_REG_OFFSET + 6) -#define MG_REG_CYL_LOW			(MG_REG_OFFSET + 8) -#define MG_REG_CYL_HIGH			(MG_REG_OFFSET + 0xA) -#define MG_REG_DRV_HEAD			(MG_REG_OFFSET + 0xC) -#define MG_REG_COMMAND			(MG_REG_OFFSET + 0xE)	/* write case */ -#define MG_REG_STATUS			(MG_REG_OFFSET + 0xE)	/* read  case */ -#define MG_REG_DRV_CTRL			(MG_REG_OFFSET + 0x10) -#define MG_REG_BURST_CTRL		(MG_REG_OFFSET + 0x12) - -/* "Drive Select/Head Register" bit values */ -#define MG_REG_HEAD_MUST_BE_ON		0xA0 /* These 2 bits are always on */ -#define MG_REG_HEAD_DRIVE_MASTER	(0x00 | MG_REG_HEAD_MUST_BE_ON) -#define MG_REG_HEAD_DRIVE_SLAVE		(0x10 | MG_REG_HEAD_MUST_BE_ON) -#define MG_REG_HEAD_LBA_MODE		(0x40 | MG_REG_HEAD_MUST_BE_ON) - - -/* "Device Control Register" bit values */ -#define MG_REG_CTRL_INTR_ENABLE			0x0 -#define MG_REG_CTRL_INTR_DISABLE		(0x1<<1) -#define MG_REG_CTRL_RESET			(0x1<<2) -#define MG_REG_CTRL_INTR_POLA_ACTIVE_HIGH	0x0 -#define MG_REG_CTRL_INTR_POLA_ACTIVE_LOW	(0x1<<4) -#define MG_REG_CTRL_DPD_POLA_ACTIVE_LOW		0x0 -#define MG_REG_CTRL_DPD_POLA_ACTIVE_HIGH	(0x1<<5) -#define MG_REG_CTRL_DPD_DISABLE			0x0 -#define MG_REG_CTRL_DPD_ENABLE			(0x1<<6) - -/* Status register bit */ -/* error bit in status register */ -#define MG_REG_STATUS_BIT_ERROR			0x01 -/* corrected error in status register */ -#define MG_REG_STATUS_BIT_CORRECTED_ERROR	0x04 -/* data request bit in status register */ -#define MG_REG_STATUS_BIT_DATA_REQ		0x08 -/* DSC - Drive Seek Complete */ -#define MG_REG_STATUS_BIT_SEEK_DONE		0x10 -/* DWF - Drive Write Fault */ -#define MG_REG_STATUS_BIT_WRITE_FAULT		0x20 -#define MG_REG_STATUS_BIT_READY			0x40 -#define MG_REG_STATUS_BIT_BUSY			0x80 - -/* handy status */ -#define MG_STAT_READY	(MG_REG_STATUS_BIT_READY | MG_REG_STATUS_BIT_SEEK_DONE) -#define MG_READY_OK(s)	(((s) & (MG_STAT_READY | \ -				(MG_REG_STATUS_BIT_BUSY | \ -				 MG_REG_STATUS_BIT_WRITE_FAULT | \ -				 MG_REG_STATUS_BIT_ERROR))) == MG_STAT_READY) - -/* Error register */ -#define MG_REG_ERR_AMNF		0x01 -#define MG_REG_ERR_ABRT		0x04 -#define MG_REG_ERR_IDNF		0x10 -#define MG_REG_ERR_UNC		0x40 -#define MG_REG_ERR_BBK		0x80 - -/* error code for others */ -#define MG_ERR_NONE		0 -#define MG_ERR_TIMEOUT		0x100 -#define MG_ERR_INIT_STAT	0x101 -#define MG_ERR_TRANSLATION	0x102 -#define MG_ERR_CTRL_RST		0x103 -#define MG_ERR_INV_STAT		0x104 -#define MG_ERR_RSTOUT		0x105 - -#define MG_MAX_ERRORS	6	/* Max read/write errors */ - -/* command */ -#define MG_CMD_RD 0x20 -#define MG_CMD_WR 0x30 -#define MG_CMD_SLEEP 0x99 -#define MG_CMD_WAKEUP 0xC3 -#define MG_CMD_ID 0xEC -#define MG_CMD_WR_CONF 0x3C -#define MG_CMD_RD_CONF 0x40 - -/* operation mode */ -#define MG_OP_CASCADE (1 << 0) -#define MG_OP_CASCADE_SYNC_RD (1 << 1) -#define MG_OP_CASCADE_SYNC_WR (1 << 2) -#define MG_OP_INTERLEAVE (1 << 3) - -/* synchronous */ -#define MG_BURST_LAT_4 (3 << 4) -#define MG_BURST_LAT_5 (4 << 4) -#define MG_BURST_LAT_6 (5 << 4) -#define MG_BURST_LAT_7 (6 << 4) -#define MG_BURST_LAT_8 (7 << 4) -#define MG_BURST_LEN_4 (1 << 1) -#define MG_BURST_LEN_8 (2 << 1) -#define MG_BURST_LEN_16 (3 << 1) -#define MG_BURST_LEN_32 (4 << 1) -#define MG_BURST_LEN_CONT (0 << 1) - -/* timeout value (unit: ms) */ -#define MG_TMAX_CONF_TO_CMD	1 -#define MG_TMAX_WAIT_RD_DRQ	10 -#define MG_TMAX_WAIT_WR_DRQ	500 -#define MG_TMAX_RST_TO_BUSY	10 -#define MG_TMAX_HDRST_TO_RDY	500 -#define MG_TMAX_SWRST_TO_RDY	500 -#define MG_TMAX_RSTOUT		3000 +/* names of GPIO resource */ +#define MG_RST_PIN	"mg_rst" +/* except MG_BOOT_DEV, reset-out pin should be assigned */ +#define MG_RSTOUT_PIN	"mg_rstout"  /* device attribution */  /* use mflash as boot device */ @@ -145,13 +30,6 @@  /* same as MG_STORAGE_DEV, but bootloader already done reset sequence */  #define MG_STORAGE_DEV_SKIP_RST	(1 << 2) -#define MG_DEV_MASK (MG_BOOT_DEV | MG_STORAGE_DEV | MG_STORAGE_DEV_SKIP_RST) - -/* names of GPIO resource */ -#define MG_RST_PIN	"mg_rst" -/* except MG_BOOT_DEV, reset-out pin should be assigned */ -#define MG_RSTOUT_PIN	"mg_rstout" -  /* private driver data */  struct mg_drv_data {  	/* disk resource */ @@ -161,46 +39,7 @@ struct mg_drv_data {  	u32 dev_attr;  	/* internally used */ -	struct mg_host *host; +	void *host;  }; -/* main structure for mflash driver */ -struct mg_host { -	struct device *dev; - -	struct request_queue *breq; -	spinlock_t lock; -	struct gendisk *gd; - -	struct timer_list timer; -	void (*mg_do_intr) (struct mg_host *); - -	u16 id[ATA_ID_WORDS]; - -	u16 cyls; -	u16 heads; -	u16 sectors; -	u32 n_sectors; -	u32 nres_sectors; - -	void __iomem *dev_base; -	unsigned int irq; -	unsigned int rst; -	unsigned int rstout; - -	u32 major; -	u32 error; -}; - -/* - * Debugging macro and defines - */ -#undef DO_MG_DEBUG -#ifdef DO_MG_DEBUG -#  define MG_DBG(fmt, args...) \ -	printk(KERN_DEBUG "%s:%d "fmt, __func__, __LINE__, ##args) -#else /* CONFIG_MG_DEBUG */ -#  define MG_DBG(fmt, args...) do { } while (0) -#endif /* CONFIG_MG_DEBUG */ -  #endif diff --git a/include/linux/mii.h b/include/linux/mii.h index ad748588faf..359fba88027 100644 --- a/include/linux/mii.h +++ b/include/linux/mii.h @@ -240,6 +240,22 @@ static inline unsigned int mii_duplex (unsigned int duplex_lock,  }  /** + * mii_advertise_flowctrl - get flow control advertisement flags + * @cap: Flow control capabilities (FLOW_CTRL_RX, FLOW_CTRL_TX or both) + */ +static inline u16 mii_advertise_flowctrl(int cap) +{ +	u16 adv = 0; + +	if (cap & FLOW_CTRL_RX) +		adv = ADVERTISE_PAUSE_CAP | ADVERTISE_PAUSE_ASYM; +	if (cap & FLOW_CTRL_TX) +		adv ^= ADVERTISE_PAUSE_ASYM; + +	return adv; +} + +/**   * mii_resolve_flowctrl_fdx   * @lcladv: value of MII ADVERTISE register   * @rmtadv: value of MII LPA register @@ -250,18 +266,12 @@ static inline u8 mii_resolve_flowctrl_fdx(u16 lcladv, u16 rmtadv)  {  	u8 cap = 0; -	if (lcladv & ADVERTISE_PAUSE_CAP) { -		if (lcladv & ADVERTISE_PAUSE_ASYM) { -			if (rmtadv & LPA_PAUSE_CAP) -				cap = FLOW_CTRL_TX | FLOW_CTRL_RX; -			else if (rmtadv & LPA_PAUSE_ASYM) -				cap = FLOW_CTRL_RX; -		} else { -			if (rmtadv & LPA_PAUSE_CAP) -				cap = FLOW_CTRL_TX | FLOW_CTRL_RX; -		} -	} else if (lcladv & ADVERTISE_PAUSE_ASYM) { -		if ((rmtadv & LPA_PAUSE_CAP) && (rmtadv & LPA_PAUSE_ASYM)) +	if (lcladv & rmtadv & ADVERTISE_PAUSE_CAP) { +		cap = FLOW_CTRL_TX | FLOW_CTRL_RX; +	} else if (lcladv & rmtadv & ADVERTISE_PAUSE_ASYM) { +		if (lcladv & ADVERTISE_PAUSE_CAP) +			cap = FLOW_CTRL_RX; +		else if (rmtadv & ADVERTISE_PAUSE_CAP)  			cap = FLOW_CTRL_TX;  	} diff --git a/include/linux/mlx4/device.h b/include/linux/mlx4/device.h index 3aff8a6a389..ce7cc6c7bcb 100644 --- a/include/linux/mlx4/device.h +++ b/include/linux/mlx4/device.h @@ -210,6 +210,7 @@ struct mlx4_caps {  	int			num_comp_vectors;  	int			num_mpts;  	int			num_mtt_segs; +	int			mtts_per_seg;  	int			fmr_reserved_mtts;  	int			reserved_mtts;  	int			reserved_mrws; diff --git a/include/linux/mlx4/qp.h b/include/linux/mlx4/qp.h index bf8f11982da..9f29d86e5dc 100644 --- a/include/linux/mlx4/qp.h +++ b/include/linux/mlx4/qp.h @@ -165,6 +165,7 @@ enum {  	MLX4_WQE_CTRL_IP_CSUM		= 1 << 4,  	MLX4_WQE_CTRL_TCP_UDP_CSUM	= 1 << 5,  	MLX4_WQE_CTRL_INS_VLAN		= 1 << 6, +	MLX4_WQE_CTRL_STRONG_ORDER	= 1 << 7,  };  struct mlx4_wqe_ctrl_seg { diff --git a/include/linux/mm.h b/include/linux/mm.h index bff1f0d475c..ad613ed66ab 100644 --- a/include/linux/mm.h +++ b/include/linux/mm.h @@ -19,6 +19,7 @@ struct anon_vma;  struct file_ra_state;  struct user_struct;  struct writeback_control; +struct rlimit;  #ifndef CONFIG_DISCONTIGMEM          /* Don't use mapnrs, do it properly */  extern unsigned long max_mapnr; @@ -580,12 +581,10 @@ static inline void set_page_links(struct page *page, enum zone_type zone,   */  static inline unsigned long round_hint_to_min(unsigned long hint)  { -#ifdef CONFIG_SECURITY  	hint &= PAGE_MASK;  	if (((void *)hint != NULL) &&  	    (hint < mmap_min_addr))  		return PAGE_ALIGN(mmap_min_addr); -#endif  	return hint;  } @@ -1031,8 +1030,6 @@ extern void add_active_range(unsigned int nid, unsigned long start_pfn,  					unsigned long end_pfn);  extern void remove_active_range(unsigned int nid, unsigned long start_pfn,  					unsigned long end_pfn); -extern void push_node_boundaries(unsigned int nid, unsigned long start_pfn, -					unsigned long end_pfn);  extern void remove_all_active_ranges(void);  extern unsigned long absent_pages_in_range(unsigned long start_pfn,  						unsigned long end_pfn); @@ -1319,8 +1316,8 @@ int vmemmap_populate_basepages(struct page *start_page,  int vmemmap_populate(struct page *start_page, unsigned long pages, int node);  void vmemmap_populate_print_last(void); -extern void *alloc_locked_buffer(size_t size); -extern void free_locked_buffer(void *buffer, size_t size); -extern void release_locked_buffer(void *buffer, size_t size); +extern int account_locked_memory(struct mm_struct *mm, struct rlimit *rlim, +				 size_t size); +extern void refund_locked_memory(struct mm_struct *mm, size_t size);  #endif /* __KERNEL__ */  #endif /* _LINUX_MM_H */ diff --git a/include/linux/mmc/sdio_ids.h b/include/linux/mmc/sdio_ids.h index ea1bf5ba092..c7211ab6dd4 100644 --- a/include/linux/mmc/sdio_ids.h +++ b/include/linux/mmc/sdio_ids.h @@ -25,5 +25,7 @@  #define SDIO_VENDOR_ID_MARVELL			0x02df  #define SDIO_DEVICE_ID_MARVELL_LIBERTAS		0x9103 +#define SDIO_DEVICE_ID_MARVELL_8688WLAN		0x9104 +#define SDIO_DEVICE_ID_MARVELL_8688BT		0x9105  #endif diff --git a/include/linux/mmiotrace.h b/include/linux/mmiotrace.h index 3d1b7bde128..97491f78b08 100644 --- a/include/linux/mmiotrace.h +++ b/include/linux/mmiotrace.h @@ -30,6 +30,8 @@ extern unsigned int kmmio_count;  extern int register_kmmio_probe(struct kmmio_probe *p);  extern void unregister_kmmio_probe(struct kmmio_probe *p); +extern int kmmio_init(void); +extern void kmmio_cleanup(void);  #ifdef CONFIG_MMIOTRACE  /* kmmio is active by some kmmio_probes? */ diff --git a/include/linux/mmzone.h b/include/linux/mmzone.h index 186ec6ab334..a47c879e130 100644 --- a/include/linux/mmzone.h +++ b/include/linux/mmzone.h @@ -1097,6 +1097,32 @@ unsigned long __init node_memmap_size_bytes(int, unsigned long, unsigned long);  #define pfn_valid_within(pfn) (1)  #endif +#ifdef CONFIG_ARCH_HAS_HOLES_MEMORYMODEL +/* + * pfn_valid() is meant to be able to tell if a given PFN has valid memmap + * associated with it or not. In FLATMEM, it is expected that holes always + * have valid memmap as long as there is valid PFNs either side of the hole. + * In SPARSEMEM, it is assumed that a valid section has a memmap for the + * entire section. + * + * However, an ARM, and maybe other embedded architectures in the future + * free memmap backing holes to save memory on the assumption the memmap is + * never used. The page_zone linkages are then broken even though pfn_valid() + * returns true. A walker of the full memmap must then do this additional + * check to ensure the memmap they are looking at is sane by making sure + * the zone and PFN linkages are still valid. This is expensive, but walkers + * of the full memmap are extremely rare. + */ +int memmap_valid_within(unsigned long pfn, +					struct page *page, struct zone *zone); +#else +static inline int memmap_valid_within(unsigned long pfn, +					struct page *page, struct zone *zone) +{ +	return 1; +} +#endif /* CONFIG_ARCH_HAS_HOLES_MEMORYMODEL */ +  #endif /* !__GENERATING_BOUNDS.H */  #endif /* !__ASSEMBLY__ */  #endif /* _LINUX_MMZONE_H */ diff --git a/include/linux/module.h b/include/linux/module.h index 627ac082e2a..a7bc6e7b43a 100644 --- a/include/linux/module.h +++ b/include/linux/module.h @@ -77,6 +77,7 @@ search_extable(const struct exception_table_entry *first,  void sort_extable(struct exception_table_entry *start,  		  struct exception_table_entry *finish);  void sort_main_extable(void); +void trim_init_extable(struct module *m);  #ifdef MODULE  #define MODULE_GENERIC_TABLE(gtype,name)			\ @@ -337,6 +338,14 @@ struct module  	const char **trace_bprintk_fmt_start;  	unsigned int num_trace_bprintk_fmt;  #endif +#ifdef CONFIG_EVENT_TRACING +	struct ftrace_event_call *trace_events; +	unsigned int num_trace_events; +#endif +#ifdef CONFIG_FTRACE_MCOUNT_RECORD +	unsigned long *ftrace_callsites; +	unsigned int num_ftrace_callsites; +#endif  #ifdef CONFIG_MODULE_UNLOAD  	/* What modules depend on me? */ diff --git a/include/linux/moduleparam.h b/include/linux/moduleparam.h index a4f0b931846..6547c3cdbc4 100644 --- a/include/linux/moduleparam.h +++ b/include/linux/moduleparam.h @@ -36,9 +36,14 @@ typedef int (*param_set_fn)(const char *val, struct kernel_param *kp);  /* Returns length written or -errno.  Buffer is 4k (ie. be short!) */  typedef int (*param_get_fn)(char *buffer, struct kernel_param *kp); +/* Flag bits for kernel_param.flags */ +#define KPARAM_KMALLOCED	1 +#define KPARAM_ISBOOL		2 +  struct kernel_param {  	const char *name; -	unsigned int perm; +	u16 perm; +	u16 flags;  	param_set_fn set;  	param_get_fn get;  	union { @@ -79,7 +84,7 @@ struct kparam_array     parameters.  perm sets the visibility in sysfs: 000 means it's     not there, read bits mean it's readable, write bits mean it's     writable. */ -#define __module_param_call(prefix, name, set, get, arg, perm)		\ +#define __module_param_call(prefix, name, set, get, arg, isbool, perm)	\  	/* Default value instead of permissions? */			\  	static int __param_perm_check_##name __attribute__((unused)) =	\  	BUILD_BUG_ON_ZERO((perm) < 0 || (perm) > 0777 || ((perm) & 2))	\ @@ -88,10 +93,13 @@ struct kparam_array  	static struct kernel_param __moduleparam_const __param_##name	\  	__used								\      __attribute__ ((unused,__section__ ("__param"),aligned(sizeof(void *)))) \ -	= { __param_str_##name, perm, set, get, { arg } } +	= { __param_str_##name, perm, isbool ? KPARAM_ISBOOL : 0,	\ +	    set, get, { arg } }  #define module_param_call(name, set, get, arg, perm)			      \ -	__module_param_call(MODULE_PARAM_PREFIX, name, set, get, arg, perm) +	__module_param_call(MODULE_PARAM_PREFIX,			      \ +			    name, set, get, arg,			      \ +			    __same_type(*(arg), bool), perm)  /* Helper functions: type is byte, short, ushort, int, uint, long,     ulong, charp, bool or invbool, or XXX if you define param_get_XXX, @@ -120,15 +128,16 @@ struct kparam_array  #define core_param(name, var, type, perm)				\  	param_check_##type(name, &(var));				\  	__module_param_call("", name, param_set_##type, param_get_##type, \ -			    &var, perm) +			    &var, __same_type(var, bool), perm)  #endif /* !MODULE */  /* Actually copy string: maxlen param is usually sizeof(string). */  #define module_param_string(name, string, len, perm)			\  	static const struct kparam_string __param_string_##name		\  		= { len, string };					\ -	module_param_call(name, param_set_copystring, param_get_string,	\ -			  .str = &__param_string_##name, perm);		\ +	__module_param_call(MODULE_PARAM_PREFIX, name,			\ +			    param_set_copystring, param_get_string,	\ +			    .str = &__param_string_##name, 0, perm);	\  	__MODULE_PARM_TYPE(name, "string")  /* Called on module insert or kernel boot */ @@ -186,21 +195,30 @@ extern int param_set_charp(const char *val, struct kernel_param *kp);  extern int param_get_charp(char *buffer, struct kernel_param *kp);  #define param_check_charp(name, p) __param_check(name, p, char *) +/* For historical reasons "bool" parameters can be (unsigned) "int". */  extern int param_set_bool(const char *val, struct kernel_param *kp);  extern int param_get_bool(char *buffer, struct kernel_param *kp); -#define param_check_bool(name, p) __param_check(name, p, int) +#define param_check_bool(name, p)					\ +	static inline void __check_##name(void)				\ +	{								\ +		BUILD_BUG_ON(!__same_type(*(p), bool) &&		\ +			     !__same_type(*(p), unsigned int) &&	\ +			     !__same_type(*(p), int));			\ +	}  extern int param_set_invbool(const char *val, struct kernel_param *kp);  extern int param_get_invbool(char *buffer, struct kernel_param *kp); -#define param_check_invbool(name, p) __param_check(name, p, int) +#define param_check_invbool(name, p) __param_check(name, p, bool)  /* Comma-separated array: *nump is set to number they actually specified. */  #define module_param_array_named(name, array, type, nump, perm)		\  	static const struct kparam_array __param_arr_##name		\  	= { ARRAY_SIZE(array), nump, param_set_##type, param_get_##type,\  	    sizeof(array[0]), array };					\ -	module_param_call(name, param_array_set, param_array_get, 	\ -			  .arr = &__param_arr_##name, perm);		\ +	__module_param_call(MODULE_PARAM_PREFIX, name,			\ +			    param_array_set, param_array_get,		\ +			    .arr = &__param_arr_##name,			\ +			    __same_type(array[0], bool), perm);		\  	__MODULE_PARM_TYPE(name, "array of " #type)  #define module_param_array(name, type, nump, perm)		\ diff --git a/include/linux/mount.h b/include/linux/mount.h index 51f55f903af..5d527536486 100644 --- a/include/linux/mount.h +++ b/include/linux/mount.h @@ -30,7 +30,7 @@ struct mnt_namespace;  #define MNT_STRICTATIME 0x80  #define MNT_SHRINKABLE	0x100 -#define MNT_IMBALANCED_WRITE_COUNT	0x200 /* just for debugging */ +#define MNT_WRITE_HOLD	0x200  #define MNT_SHARED	0x1000	/* if the vfsmount is a shared mount */  #define MNT_UNBINDABLE	0x2000	/* if the vfsmount is a unbindable mount */ @@ -65,13 +65,22 @@ struct vfsmount {  	int mnt_expiry_mark;		/* true if marked for expiry */  	int mnt_pinned;  	int mnt_ghosts; -	/* -	 * This value is not stable unless all of the mnt_writers[] spinlocks -	 * are held, and all mnt_writer[]s on this mount have 0 as their ->count -	 */ -	atomic_t __mnt_writers; +#ifdef CONFIG_SMP +	int *mnt_writers; +#else +	int mnt_writers; +#endif  }; +static inline int *get_mnt_writers_ptr(struct vfsmount *mnt) +{ +#ifdef CONFIG_SMP +	return mnt->mnt_writers; +#else +	return &mnt->mnt_writers; +#endif +} +  static inline struct vfsmount *mntget(struct vfsmount *mnt)  {  	if (mnt) @@ -79,7 +88,11 @@ static inline struct vfsmount *mntget(struct vfsmount *mnt)  	return mnt;  } +struct file; /* forward dec */ +  extern int mnt_want_write(struct vfsmount *mnt); +extern int mnt_want_write_file(struct file *file); +extern int mnt_clone_write(struct vfsmount *mnt);  extern void mnt_drop_write(struct vfsmount *mnt);  extern void mntput_no_expire(struct vfsmount *mnt);  extern void mnt_pin(struct vfsmount *mnt); diff --git a/include/linux/mutex.h b/include/linux/mutex.h index 3069ec7e0ab..878cab4f5fc 100644 --- a/include/linux/mutex.h +++ b/include/linux/mutex.h @@ -150,5 +150,6 @@ extern int __must_check mutex_lock_killable(struct mutex *lock);   */  extern int mutex_trylock(struct mutex *lock);  extern void mutex_unlock(struct mutex *lock); +extern int atomic_dec_and_mutex_lock(atomic_t *cnt, struct mutex *lock);  #endif diff --git a/include/linux/namei.h b/include/linux/namei.h index fc2e0357987..d870ae2faed 100644 --- a/include/linux/namei.h +++ b/include/linux/namei.h @@ -18,6 +18,7 @@ enum { MAX_NESTED_LINKS = 8 };  struct nameidata {  	struct path	path;  	struct qstr	last; +	struct path	root;  	unsigned int	flags;  	int		last_type;  	unsigned	depth; @@ -69,7 +70,6 @@ extern int path_lookup(const char *, unsigned, struct nameidata *);  extern int vfs_path_lookup(struct dentry *, struct vfsmount *,  			   const char *, unsigned int, struct nameidata *); -extern int path_lookup_open(int dfd, const char *name, unsigned lookup_flags, struct nameidata *, int open_flags);  extern struct file *lookup_instantiate_filp(struct nameidata *nd, struct dentry *dentry,  		int (*open)(struct inode *, struct file *));  extern struct file *nameidata_to_filp(struct nameidata *nd, int flags); @@ -78,8 +78,8 @@ extern void release_open_intent(struct nameidata *);  extern struct dentry *lookup_one_len(const char *, struct dentry *, int);  extern struct dentry *lookup_one_noperm(const char *, struct dentry *); -extern int follow_down(struct vfsmount **, struct dentry **); -extern int follow_up(struct vfsmount **, struct dentry **); +extern int follow_down(struct path *); +extern int follow_up(struct path *);  extern struct dentry *lock_rename(struct dentry *, struct dentry *);  extern void unlock_rename(struct dentry *, struct dentry *); diff --git a/include/linux/net_dropmon.h b/include/linux/net_dropmon.h index 0217fb81a63..3ceb0cc1bc7 100644 --- a/include/linux/net_dropmon.h +++ b/include/linux/net_dropmon.h @@ -1,13 +1,22 @@  #ifndef __NET_DROPMON_H  #define __NET_DROPMON_H +#include <linux/types.h>  #include <linux/netlink.h> +#include <linux/types.h>  struct net_dm_drop_point {  	__u8 pc[8];  	__u32 count;  }; +#define is_drop_point_hw(x) do {\ +	int ____i, ____j;\ +	for (____i = 0; ____i < 8; i ____i++)\ +		____j |= x[____i];\ +	____j;\ +} while (0) +  #define NET_DM_CFG_VERSION  0  #define NET_DM_CFG_ALERT_COUNT  1  #define NET_DM_CFG_ALERT_DELAY 2 diff --git a/include/linux/netdevice.h b/include/linux/netdevice.h index 5a96a1a406e..9ea8d6dfe54 100644 --- a/include/linux/netdevice.h +++ b/include/linux/netdevice.h @@ -39,9 +39,11 @@  #include <linux/device.h>  #include <linux/percpu.h> +#include <linux/rculist.h>  #include <linux/dmaengine.h>  #include <linux/workqueue.h> +#include <linux/ethtool.h>  #include <net/net_namespace.h>  #include <net/dsa.h>  #ifdef CONFIG_DCB @@ -49,7 +51,6 @@  #endif  struct vlan_group; -struct ethtool_ops;  struct netpoll_info;  /* 802.11 specific */  struct wireless_dev; @@ -210,6 +211,19 @@ struct dev_addr_list  #define dmi_users	da_users  #define dmi_gusers	da_gusers +struct netdev_hw_addr { +	struct list_head	list; +	unsigned char		addr[MAX_ADDR_LEN]; +	unsigned char		type; +#define NETDEV_HW_ADDR_T_LAN		1 +#define NETDEV_HW_ADDR_T_SAN		2 +#define NETDEV_HW_ADDR_T_SLAVE		3 +#define NETDEV_HW_ADDR_T_UNICAST	4 +	int			refcount; +	bool			synced; +	struct rcu_head		rcu_head; +}; +  struct hh_cache  {  	struct hh_cache *hh_next;	/* Next entry			     */ @@ -447,12 +461,25 @@ enum netdev_queue_state_t  };  struct netdev_queue { +/* + * read mostly part + */  	struct net_device	*dev;  	struct Qdisc		*qdisc;  	unsigned long		state; -	spinlock_t		_xmit_lock; -	int			xmit_lock_owner;  	struct Qdisc		*qdisc_sleeping; +/* + * write mostly part + */ +	spinlock_t		_xmit_lock ____cacheline_aligned_in_smp; +	int			xmit_lock_owner; +	/* +	 * please use this field instead of dev->trans_start +	 */ +	unsigned long		trans_start; +	unsigned long		tx_bytes; +	unsigned long		tx_packets; +	unsigned long		tx_dropped;  } ____cacheline_aligned_in_smp; @@ -670,7 +697,9 @@ struct net_device  #define NETIF_F_GRO		16384	/* Generic receive offload */  #define NETIF_F_LRO		32768	/* large receive offload */ +/* the GSO_MASK reserves bits 16 through 23 */  #define NETIF_F_FCOE_CRC	(1 << 24) /* FCoE CRC32 */ +#define NETIF_F_SCTP_CSUM	(1 << 25) /* SCTP checksum offload */  	/* Segmentation offload features */  #define NETIF_F_GSO_SHIFT	16 @@ -747,10 +776,11 @@ struct net_device  	unsigned char		addr_len;	/* hardware address length	*/  	unsigned short          dev_id;		/* for shared network cards */ -	spinlock_t		addr_list_lock; -	struct dev_addr_list	*uc_list;	/* Secondary unicast mac addresses */ +	struct list_head	uc_list;	/* Secondary unicast mac +						   addresses */  	int			uc_count;	/* Number of installed ucasts	*/  	int			uc_promisc; +	spinlock_t		addr_list_lock;  	struct dev_addr_list	*mc_list;	/* Multicast mac addresses	*/  	int			mc_count;	/* Number of installed mcasts	*/  	unsigned int		promiscuity; @@ -776,8 +806,11 @@ struct net_device   */  	unsigned long		last_rx;	/* Time of last Rx	*/  	/* Interface address info used in eth_type_trans() */ -	unsigned char		dev_addr[MAX_ADDR_LEN];	/* hw address, (before bcast -							   because most packets are unicast) */ +	unsigned char		*dev_addr;	/* hw address, (before bcast +						   because most packets are +						   unicast) */ + +	struct list_head	dev_addr_list; /* list of device hw addresses */  	unsigned char		broadcast[MAX_ADDR_LEN];	/* hw bcast add	*/ @@ -797,6 +830,11 @@ struct net_device   * One part is mostly used on xmit path (device)   */  	/* These may be needed for future network-power-down code. */ + +	/* +	 * trans_start here is expensive for high speed devices on SMP, +	 * please use netdev_queue->trans_start instead. +	 */  	unsigned long		trans_start;	/* Time (in jiffies) of last Tx	*/  	int			watchdog_timeo; /* used by dev_watchdog() */ @@ -867,49 +905,10 @@ struct net_device  	/* max exchange id for FCoE LRO by ddp */  	unsigned int		fcoe_ddp_xid;  #endif - -#ifdef CONFIG_COMPAT_NET_DEV_OPS -	struct { -		int			(*init)(struct net_device *dev); -		void			(*uninit)(struct net_device *dev); -		int			(*open)(struct net_device *dev); -		int			(*stop)(struct net_device *dev); -		int			(*hard_start_xmit) (struct sk_buff *skb, -							    struct net_device *dev); -		u16			(*select_queue)(struct net_device *dev, -							struct sk_buff *skb); -		void			(*change_rx_flags)(struct net_device *dev, -							   int flags); -		void			(*set_rx_mode)(struct net_device *dev); -		void			(*set_multicast_list)(struct net_device *dev); -		int			(*set_mac_address)(struct net_device *dev, -							   void *addr); -		int			(*validate_addr)(struct net_device *dev); -		int			(*do_ioctl)(struct net_device *dev, -						    struct ifreq *ifr, int cmd); -		int			(*set_config)(struct net_device *dev, -						      struct ifmap *map); -		int			(*change_mtu)(struct net_device *dev, int new_mtu); -		int			(*neigh_setup)(struct net_device *dev, -						       struct neigh_parms *); -		void			(*tx_timeout) (struct net_device *dev); -		struct net_device_stats* (*get_stats)(struct net_device *dev); -		void			(*vlan_rx_register)(struct net_device *dev, -							    struct vlan_group *grp); -		void			(*vlan_rx_add_vid)(struct net_device *dev, -							   unsigned short vid); -		void			(*vlan_rx_kill_vid)(struct net_device *dev, -							    unsigned short vid); -#ifdef CONFIG_NET_POLL_CONTROLLER -		void                    (*poll_controller)(struct net_device *dev); -#endif -	}; -#endif  };  #define to_net_dev(d) container_of(d, struct net_device, dev)  #define	NETDEV_ALIGN		32 -#define	NETDEV_ALIGN_CONST	(NETDEV_ALIGN - 1)  static inline  struct netdev_queue *netdev_get_tx_queue(const struct net_device *dev, @@ -980,9 +979,7 @@ static inline bool netdev_uses_trailer_tags(struct net_device *dev)   */  static inline void *netdev_priv(const struct net_device *dev)  { -	return (char *)dev + ((sizeof(struct net_device) -			       + NETDEV_ALIGN_CONST) -			      & ~NETDEV_ALIGN_CONST); +	return (char *)dev + ALIGN(sizeof(struct net_device), NETDEV_ALIGN);  }  /* Set the sysfs physical device reference for the network logical device @@ -1012,6 +1009,12 @@ void netif_napi_add(struct net_device *dev, struct napi_struct *napi,  void netif_napi_del(struct napi_struct *napi);  struct napi_gro_cb { +	/* Virtual address of skb_shinfo(skb)->frags[0].page + offset. */ +	void *frag0; + +	/* Length of frag0. */ +	unsigned int frag0_len; +  	/* This indicates where we are processing relative to skb->data. */  	int data_offset; @@ -1047,14 +1050,6 @@ struct packet_type {  	struct list_head	list;  }; -struct napi_gro_fraginfo { -	skb_frag_t frags[MAX_SKB_FRAGS]; -	unsigned int nr_frags; -	unsigned int ip_summed; -	unsigned int len; -	__wsum csum; -}; -  #include <linux/interrupt.h>  #include <linux/notifier.h> @@ -1119,9 +1114,9 @@ extern int		dev_restart(struct net_device *dev);  #ifdef CONFIG_NETPOLL_TRAP  extern int		netpoll_trap(void);  #endif -extern void	      *skb_gro_header(struct sk_buff *skb, unsigned int hlen);  extern int	       skb_gro_receive(struct sk_buff **head,  				       struct sk_buff *skb); +extern void	       skb_gro_reset_offset(struct sk_buff *skb);  static inline unsigned int skb_gro_offset(const struct sk_buff *skb)  { @@ -1138,16 +1133,34 @@ static inline void skb_gro_pull(struct sk_buff *skb, unsigned int len)  	NAPI_GRO_CB(skb)->data_offset += len;  } -static inline void skb_gro_reset_offset(struct sk_buff *skb) +static inline void *skb_gro_header_fast(struct sk_buff *skb, +					unsigned int offset)  { -	NAPI_GRO_CB(skb)->data_offset = 0; +	return NAPI_GRO_CB(skb)->frag0 + offset; +} + +static inline int skb_gro_header_hard(struct sk_buff *skb, unsigned int hlen) +{ +	return NAPI_GRO_CB(skb)->frag0_len < hlen; +} + +static inline void *skb_gro_header_slow(struct sk_buff *skb, unsigned int hlen, +					unsigned int offset) +{ +	NAPI_GRO_CB(skb)->frag0 = NULL; +	NAPI_GRO_CB(skb)->frag0_len = 0; +	return pskb_may_pull(skb, hlen) ? skb->data + offset : NULL;  }  static inline void *skb_gro_mac_header(struct sk_buff *skb)  { -	return skb_mac_header(skb) < skb->data ? skb_mac_header(skb) : -	       page_address(skb_shinfo(skb)->frags[0].page) + -	       skb_shinfo(skb)->frags[0].page_offset; +	return NAPI_GRO_CB(skb)->frag0 ?: skb_mac_header(skb); +} + +static inline void *skb_gro_network_header(struct sk_buff *skb) +{ +	return (NAPI_GRO_CB(skb)->frag0 ?: skb->data) + +	       skb_network_offset(skb);  }  static inline int dev_hard_header(struct sk_buff *skb, struct net_device *dev, @@ -1442,12 +1455,18 @@ extern int		napi_gro_receive(struct napi_struct *napi,  					 struct sk_buff *skb);  extern void		napi_reuse_skb(struct napi_struct *napi,  				       struct sk_buff *skb); -extern struct sk_buff *	napi_fraginfo_skb(struct napi_struct *napi, -					  struct napi_gro_fraginfo *info); +extern struct sk_buff *	napi_get_frags(struct napi_struct *napi);  extern int		napi_frags_finish(struct napi_struct *napi,  					  struct sk_buff *skb, int ret); -extern int		napi_gro_frags(struct napi_struct *napi, -				       struct napi_gro_fraginfo *info); +extern struct sk_buff *	napi_frags_skb(struct napi_struct *napi); +extern int		napi_gro_frags(struct napi_struct *napi); + +static inline void napi_free_frags(struct napi_struct *napi) +{ +	kfree_skb(napi->skb); +	napi->skb = NULL; +} +  extern void		netif_nit_deliver(struct sk_buff *skb);  extern int		dev_valid_name(const char *name);  extern int		dev_ioctl(struct net *net, unsigned int cmd, void __user *); @@ -1514,6 +1533,8 @@ static inline int netif_carrier_ok(const struct net_device *dev)  	return !test_bit(__LINK_STATE_NOCARRIER, &dev->state);  } +extern unsigned long dev_trans_start(struct net_device *dev); +  extern void __netdev_watchdog_up(struct net_device *dev);  extern void netif_carrier_on(struct net_device *dev); @@ -1671,6 +1692,12 @@ static inline void __netif_tx_unlock_bh(struct netdev_queue *txq)  	spin_unlock_bh(&txq->_xmit_lock);  } +static inline void txq_trans_update(struct netdev_queue *txq) +{ +	if (txq->xmit_lock_owner != -1) +		txq->trans_start = jiffies; +} +  /**   *	netif_tx_lock - grab network device transmit lock   *	@dev: network device @@ -1778,6 +1805,13 @@ static inline void netif_addr_unlock_bh(struct net_device *dev)  	spin_unlock_bh(&dev->addr_list_lock);  } +/* + * dev_addr_list walker. Should be used only for read access. Call with + * rcu_read_lock held. + */ +#define for_each_dev_addr(dev, ha) \ +		list_for_each_entry_rcu(ha, &dev->dev_addr_list, list) +  /* These functions live elsewhere (drivers/net/net_init.c, but related) */  extern void		ether_setup(struct net_device *dev); @@ -1790,11 +1824,24 @@ extern struct net_device *alloc_netdev_mq(int sizeof_priv, const char *name,  	alloc_netdev_mq(sizeof_priv, name, setup, 1)  extern int		register_netdev(struct net_device *dev);  extern void		unregister_netdev(struct net_device *dev); + +/* Functions used for device addresses handling */ +extern int dev_addr_add(struct net_device *dev, unsigned char *addr, +			unsigned char addr_type); +extern int dev_addr_del(struct net_device *dev, unsigned char *addr, +			unsigned char addr_type); +extern int dev_addr_add_multiple(struct net_device *to_dev, +				 struct net_device *from_dev, +				 unsigned char addr_type); +extern int dev_addr_del_multiple(struct net_device *to_dev, +				 struct net_device *from_dev, +				 unsigned char addr_type); +  /* Functions used for secondary unicast and multicast support */  extern void		dev_set_rx_mode(struct net_device *dev);  extern void		__dev_set_rx_mode(struct net_device *dev); -extern int		dev_unicast_delete(struct net_device *dev, void *addr, int alen); -extern int		dev_unicast_add(struct net_device *dev, void *addr, int alen); +extern int		dev_unicast_delete(struct net_device *dev, void *addr); +extern int		dev_unicast_add(struct net_device *dev, void *addr);  extern int		dev_unicast_sync(struct net_device *to, struct net_device *from);  extern void		dev_unicast_unsync(struct net_device *to, struct net_device *from);  extern int 		dev_mc_delete(struct net_device *dev, void *addr, int alen, int all); @@ -1856,15 +1903,14 @@ static inline int net_gso_ok(int features, int gso_type)  static inline int skb_gso_ok(struct sk_buff *skb, int features)  { -	return net_gso_ok(features, skb_shinfo(skb)->gso_type); +	return net_gso_ok(features, skb_shinfo(skb)->gso_type) && +	       (!skb_has_frags(skb) || (features & NETIF_F_FRAGLIST));  }  static inline int netif_needs_gso(struct net_device *dev, struct sk_buff *skb)  {  	return skb_is_gso(skb) &&  	       (!skb_gso_ok(skb, dev->features) || -	        (skb_shinfo(skb)->frag_list && -	         !(dev->features & NETIF_F_FRAGLIST)) ||  		unlikely(skb->ip_summed != CHECKSUM_PARTIAL));  } @@ -1874,6 +1920,16 @@ static inline void netif_set_gso_max_size(struct net_device *dev,  	dev->gso_max_size = size;  } +static inline void skb_bond_set_mac_by_master(struct sk_buff *skb, +					      struct net_device *master) +{ +	if (skb->pkt_type == PACKET_HOST) { +		u16 *dest = (u16 *) eth_hdr(skb)->h_dest; + +		memcpy(dest, master->dev_addr, ETH_ALEN); +	} +} +  /* On bonding slaves other than the currently active slave, suppress   * duplicates except for 802.3ad ETH_P_SLOW, alb non-mcast/bcast, and   * ARP on active-backup slaves with arp_validate enabled. @@ -1887,6 +1943,14 @@ static inline int skb_bond_should_drop(struct sk_buff *skb)  		if (master->priv_flags & IFF_MASTER_ARPMON)  			dev->last_rx = jiffies; +		if ((master->priv_flags & IFF_MASTER_ALB) && master->br_port) { +			/* Do address unmangle. The local destination address +			 * will be always the one master has. Provides the right +			 * functionality in a bridge. +			 */ +			skb_bond_set_mac_by_master(skb, master); +		} +  		if (dev->priv_flags & IFF_SLAVE_INACTIVE) {  			if ((dev->priv_flags & IFF_SLAVE_NEEDARP) &&  			    skb->protocol == __cpu_to_be16(ETH_P_ARP)) @@ -1908,6 +1972,28 @@ static inline int skb_bond_should_drop(struct sk_buff *skb)  }  extern struct pernet_operations __net_initdata loopback_net_ops; + +static inline int dev_ethtool_get_settings(struct net_device *dev, +					   struct ethtool_cmd *cmd) +{ +	if (!dev->ethtool_ops || !dev->ethtool_ops->get_settings) +		return -EOPNOTSUPP; +	return dev->ethtool_ops->get_settings(dev, cmd); +} + +static inline u32 dev_ethtool_get_rx_csum(struct net_device *dev) +{ +	if (!dev->ethtool_ops || !dev->ethtool_ops->get_rx_csum) +		return 0; +	return dev->ethtool_ops->get_rx_csum(dev); +} + +static inline u32 dev_ethtool_get_flags(struct net_device *dev) +{ +	if (!dev->ethtool_ops || !dev->ethtool_ops->get_flags) +		return 0; +	return dev->ethtool_ops->get_flags(dev); +}  #endif /* __KERNEL__ */ -#endif	/* _LINUX_DEV_H */ +#endif	/* _LINUX_NETDEVICE_H */ diff --git a/include/linux/netfilter/Kbuild b/include/linux/netfilter/Kbuild index af9d2fb9721..2aea50399c0 100644 --- a/include/linux/netfilter/Kbuild +++ b/include/linux/netfilter/Kbuild @@ -33,6 +33,7 @@ header-y += xt_limit.h  header-y += xt_mac.h  header-y += xt_mark.h  header-y += xt_multiport.h +header-y += xt_osf.h  header-y += xt_owner.h  header-y += xt_pkttype.h  header-y += xt_quota.h diff --git a/include/linux/netfilter/nf_conntrack_common.h b/include/linux/netfilter/nf_conntrack_common.h index 885cbe28226..a8248ee422b 100644 --- a/include/linux/netfilter/nf_conntrack_common.h +++ b/include/linux/netfilter/nf_conntrack_common.h @@ -75,75 +75,6 @@ enum ip_conntrack_status {  	IPS_FIXED_TIMEOUT = (1 << IPS_FIXED_TIMEOUT_BIT),  }; -/* Connection tracking event bits */ -enum ip_conntrack_events -{ -	/* New conntrack */ -	IPCT_NEW_BIT = 0, -	IPCT_NEW = (1 << IPCT_NEW_BIT), - -	/* Expected connection */ -	IPCT_RELATED_BIT = 1, -	IPCT_RELATED = (1 << IPCT_RELATED_BIT), - -	/* Destroyed conntrack */ -	IPCT_DESTROY_BIT = 2, -	IPCT_DESTROY = (1 << IPCT_DESTROY_BIT), - -	/* Timer has been refreshed */ -	IPCT_REFRESH_BIT = 3, -	IPCT_REFRESH = (1 << IPCT_REFRESH_BIT), - -	/* Status has changed */ -	IPCT_STATUS_BIT = 4, -	IPCT_STATUS = (1 << IPCT_STATUS_BIT), - -	/* Update of protocol info */ -	IPCT_PROTOINFO_BIT = 5, -	IPCT_PROTOINFO = (1 << IPCT_PROTOINFO_BIT), - -	/* Volatile protocol info */ -	IPCT_PROTOINFO_VOLATILE_BIT = 6, -	IPCT_PROTOINFO_VOLATILE = (1 << IPCT_PROTOINFO_VOLATILE_BIT), - -	/* New helper for conntrack */ -	IPCT_HELPER_BIT = 7, -	IPCT_HELPER = (1 << IPCT_HELPER_BIT), - -	/* Update of helper info */ -	IPCT_HELPINFO_BIT = 8, -	IPCT_HELPINFO = (1 << IPCT_HELPINFO_BIT), - -	/* Volatile helper info */ -	IPCT_HELPINFO_VOLATILE_BIT = 9, -	IPCT_HELPINFO_VOLATILE = (1 << IPCT_HELPINFO_VOLATILE_BIT), - -	/* NAT info */ -	IPCT_NATINFO_BIT = 10, -	IPCT_NATINFO = (1 << IPCT_NATINFO_BIT), - -	/* Counter highest bit has been set, unused */ -	IPCT_COUNTER_FILLING_BIT = 11, -	IPCT_COUNTER_FILLING = (1 << IPCT_COUNTER_FILLING_BIT), - -	/* Mark is set */ -	IPCT_MARK_BIT = 12, -	IPCT_MARK = (1 << IPCT_MARK_BIT), - -	/* NAT sequence adjustment */ -	IPCT_NATSEQADJ_BIT = 13, -	IPCT_NATSEQADJ = (1 << IPCT_NATSEQADJ_BIT), - -	/* Secmark is set */ -	IPCT_SECMARK_BIT = 14, -	IPCT_SECMARK = (1 << IPCT_SECMARK_BIT), -}; - -enum ip_conntrack_expect_events { -	IPEXP_NEW_BIT = 0, -	IPEXP_NEW = (1 << IPEXP_NEW_BIT), -}; -  #ifdef __KERNEL__  struct ip_conntrack_stat  { diff --git a/include/linux/netfilter/nf_conntrack_tcp.h b/include/linux/netfilter/nf_conntrack_tcp.h index 3066789b972..4352feed237 100644 --- a/include/linux/netfilter/nf_conntrack_tcp.h +++ b/include/linux/netfilter/nf_conntrack_tcp.h @@ -15,7 +15,8 @@ enum tcp_conntrack {  	TCP_CONNTRACK_LAST_ACK,  	TCP_CONNTRACK_TIME_WAIT,  	TCP_CONNTRACK_CLOSE, -	TCP_CONNTRACK_LISTEN, +	TCP_CONNTRACK_LISTEN,	/* obsolete */ +#define TCP_CONNTRACK_SYN_SENT2	TCP_CONNTRACK_LISTEN  	TCP_CONNTRACK_MAX,  	TCP_CONNTRACK_IGNORE  }; @@ -35,6 +36,9 @@ enum tcp_conntrack {  /* Has unacknowledged data */  #define IP_CT_TCP_FLAG_DATA_UNACKNOWLEDGED	0x10 +/* The field td_maxack has been set */ +#define IP_CT_TCP_FLAG_MAXACK_SET		0x20 +  struct nf_ct_tcp_flags {  	__u8 flags;  	__u8 mask; @@ -46,6 +50,7 @@ struct ip_ct_tcp_state {  	u_int32_t	td_end;		/* max of seq + len */  	u_int32_t	td_maxend;	/* max of ack + max(win, 1) */  	u_int32_t	td_maxwin;	/* max(win) */ +	u_int32_t	td_maxack;	/* max of ack */  	u_int8_t	td_scale;	/* window scale factor */  	u_int8_t	flags;		/* per direction options */  }; diff --git a/include/linux/netfilter/nfnetlink.h b/include/linux/netfilter/nfnetlink.h index c600083cbdf..bff4d5741d9 100644 --- a/include/linux/netfilter/nfnetlink.h +++ b/include/linux/netfilter/nfnetlink.h @@ -46,7 +46,8 @@ struct nfgenmsg {  #define NFNL_SUBSYS_CTNETLINK_EXP	2  #define NFNL_SUBSYS_QUEUE		3  #define NFNL_SUBSYS_ULOG		4 -#define NFNL_SUBSYS_COUNT		5 +#define NFNL_SUBSYS_OSF			5 +#define NFNL_SUBSYS_COUNT		6  #ifdef __KERNEL__ @@ -75,7 +76,7 @@ extern int nfnetlink_subsys_unregister(const struct nfnetlink_subsystem *n);  extern int nfnetlink_has_listeners(unsigned int group);  extern int nfnetlink_send(struct sk_buff *skb, u32 pid, unsigned group,  -			  int echo); +			  int echo, gfp_t flags);  extern void nfnetlink_set_err(u32 pid, u32 group, int error);  extern int nfnetlink_unicast(struct sk_buff *skb, u_int32_t pid, int flags); diff --git a/include/linux/netfilter/nfnetlink_conntrack.h b/include/linux/netfilter/nfnetlink_conntrack.h index 1a865e48b8e..ed4ef8d0b11 100644 --- a/include/linux/netfilter/nfnetlink_conntrack.h +++ b/include/linux/netfilter/nfnetlink_conntrack.h @@ -101,6 +101,7 @@ enum ctattr_protoinfo_dccp {  	CTA_PROTOINFO_DCCP_UNSPEC,  	CTA_PROTOINFO_DCCP_STATE,  	CTA_PROTOINFO_DCCP_ROLE, +	CTA_PROTOINFO_DCCP_HANDSHAKE_SEQ,  	__CTA_PROTOINFO_DCCP_MAX,  };  #define CTA_PROTOINFO_DCCP_MAX (__CTA_PROTOINFO_DCCP_MAX - 1) diff --git a/include/linux/netfilter/x_tables.h b/include/linux/netfilter/x_tables.h index 1b2e43502ef..1030b759389 100644 --- a/include/linux/netfilter/x_tables.h +++ b/include/linux/netfilter/x_tables.h @@ -184,9 +184,10 @@ struct xt_counters_info   * @matchinfo:	per-match data   * @fragoff:	packet is a fragment, this is the data offset   * @thoff:	position of transport header relative to skb->data - * @hotdrop:	drop packet if we had inspection problems + * @hook:	hook number given packet came from   * @family:	Actual NFPROTO_* through which the function is invoked   * 		(helpful when match->family == NFPROTO_UNSPEC) + * @hotdrop:	drop packet if we had inspection problems   */  struct xt_match_param {  	const struct net_device *in, *out; @@ -194,8 +195,9 @@ struct xt_match_param {  	const void *matchinfo;  	int fragoff;  	unsigned int thoff; -	bool *hotdrop; +	unsigned int hooknum;  	u_int8_t family; +	bool *hotdrop;  };  /** @@ -472,7 +474,7 @@ static inline void xt_info_rdlock_bh(void)  	local_bh_disable();  	lock = &__get_cpu_var(xt_info_locks); -	if (!lock->readers++) +	if (likely(!lock->readers++))  		spin_lock(&lock->lock);  } @@ -480,7 +482,7 @@ static inline void xt_info_rdunlock_bh(void)  {  	struct xt_info_lock *lock = &__get_cpu_var(xt_info_locks); -	if (!--lock->readers) +	if (likely(!--lock->readers))  		spin_unlock(&lock->lock);  	local_bh_enable();  } diff --git a/include/linux/netfilter/xt_LED.h b/include/linux/netfilter/xt_LED.h index 4c91a0d770d..f5509e7524d 100644 --- a/include/linux/netfilter/xt_LED.h +++ b/include/linux/netfilter/xt_LED.h @@ -1,6 +1,8 @@  #ifndef _XT_LED_H  #define _XT_LED_H +#include <linux/types.h> +  struct xt_led_info {  	char id[27];        /* Unique ID for this trigger in the LED class */  	__u8 always_blink;  /* Blink even if the LED is already on */ diff --git a/include/linux/netfilter/xt_NFQUEUE.h b/include/linux/netfilter/xt_NFQUEUE.h index 982a89f7827..2584f4a777d 100644 --- a/include/linux/netfilter/xt_NFQUEUE.h +++ b/include/linux/netfilter/xt_NFQUEUE.h @@ -15,4 +15,9 @@ struct xt_NFQ_info {  	__u16 queuenum;  }; +struct xt_NFQ_info_v1 { +	__u16 queuenum; +	__u16 queues_total; +}; +  #endif /* _XT_NFQ_TARGET_H */ diff --git a/include/linux/netfilter/xt_cluster.h b/include/linux/netfilter/xt_cluster.h index 5e0a0d07b52..886682656f0 100644 --- a/include/linux/netfilter/xt_cluster.h +++ b/include/linux/netfilter/xt_cluster.h @@ -12,4 +12,6 @@ struct xt_cluster_match_info {  	u_int32_t		flags;  }; +#define XT_CLUSTER_NODES_MAX	32 +  #endif /* _XT_CLUSTER_MATCH_H */ diff --git a/include/linux/netfilter/xt_osf.h b/include/linux/netfilter/xt_osf.h new file mode 100644 index 00000000000..fd2272e0959 --- /dev/null +++ b/include/linux/netfilter/xt_osf.h @@ -0,0 +1,133 @@ +/* + * Copyright (c) 2003+ Evgeniy Polyakov <johnpol@2ka.mxt.ru> + * + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation; either version 2 of the License, or + * (at your option) any later version. + * + * 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. + * + * You should have received a copy of the GNU General Public License + * along with this program; if not, write to the Free Software + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA + */ + +#ifndef _XT_OSF_H +#define _XT_OSF_H + +#define MAXGENRELEN		32 + +#define XT_OSF_GENRE		(1<<0) +#define	XT_OSF_TTL		(1<<1) +#define XT_OSF_LOG		(1<<2) +#define XT_OSF_INVERT		(1<<3) + +#define XT_OSF_LOGLEVEL_ALL	0	/* log all matched fingerprints */ +#define XT_OSF_LOGLEVEL_FIRST	1	/* log only the first matced fingerprint */ +#define XT_OSF_LOGLEVEL_ALL_KNOWN	2 /* do not log unknown packets */ + +#define XT_OSF_TTL_TRUE		0	/* True ip and fingerprint TTL comparison */ +#define XT_OSF_TTL_LESS		1	/* Check if ip TTL is less than fingerprint one */ +#define XT_OSF_TTL_NOCHECK	2	/* Do not compare ip and fingerprint TTL at all */ + +struct xt_osf_info { +	char			genre[MAXGENRELEN]; +	__u32			len; +	__u32			flags; +	__u32			loglevel; +	__u32			ttl; +}; + +/* + * Wildcard MSS (kind of). + * It is used to implement a state machine for the different wildcard values + * of the MSS and window sizes. + */ +struct xt_osf_wc { +	__u32			wc; +	__u32			val; +}; + +/* + * This struct represents IANA options + * http://www.iana.org/assignments/tcp-parameters + */ +struct xt_osf_opt { +	__u16			kind, length; +	struct xt_osf_wc	wc; +}; + +struct xt_osf_user_finger { +	struct xt_osf_wc	wss; + +	__u8			ttl, df; +	__u16			ss, mss; +	__u16			opt_num; + +	char			genre[MAXGENRELEN]; +	char			version[MAXGENRELEN]; +	char			subtype[MAXGENRELEN]; + +	/* MAX_IPOPTLEN is maximum if all options are NOPs or EOLs */ +	struct xt_osf_opt	opt[MAX_IPOPTLEN]; +}; + +struct xt_osf_nlmsg { +	struct xt_osf_user_finger	f; +	struct iphdr		ip; +	struct tcphdr		tcp; +}; + +/* Defines for IANA option kinds */ + +enum iana_options { +	OSFOPT_EOL = 0,		/* End of options */ +	OSFOPT_NOP, 		/* NOP */ +	OSFOPT_MSS, 		/* Maximum segment size */ +	OSFOPT_WSO, 		/* Window scale option */ +	OSFOPT_SACKP,		/* SACK permitted */ +	OSFOPT_SACK,		/* SACK */ +	OSFOPT_ECHO, +	OSFOPT_ECHOREPLY, +	OSFOPT_TS,		/* Timestamp option */ +	OSFOPT_POCP,		/* Partial Order Connection Permitted */ +	OSFOPT_POSP,		/* Partial Order Service Profile */ + +	/* Others are not used in the current OSF */ +	OSFOPT_EMPTY = 255, +}; + +/* + * Initial window size option state machine: multiple of mss, mtu or + * plain numeric value. Can also be made as plain numeric value which + * is not a multiple of specified value. + */ +enum xt_osf_window_size_options { +	OSF_WSS_PLAIN	= 0, +	OSF_WSS_MSS, +	OSF_WSS_MTU, +	OSF_WSS_MODULO, +	OSF_WSS_MAX, +}; + +/* + * Add/remove fingerprint from the kernel. + */ +enum xt_osf_msg_types { +	OSF_MSG_ADD, +	OSF_MSG_REMOVE, +	OSF_MSG_MAX, +}; + +enum xt_osf_attr_type { +	OSF_ATTR_UNSPEC, +	OSF_ATTR_FINGER, +	OSF_ATTR_MAX, +}; + +#endif				/* _XT_OSF_H */ diff --git a/include/linux/netfilter/xt_socket.h b/include/linux/netfilter/xt_socket.h new file mode 100644 index 00000000000..6f475b8ff34 --- /dev/null +++ b/include/linux/netfilter/xt_socket.h @@ -0,0 +1,12 @@ +#ifndef _XT_SOCKET_H +#define _XT_SOCKET_H + +enum { +	XT_SOCKET_TRANSPARENT = 1 << 0, +}; + +struct xt_socket_mtinfo1 { +	__u8 flags; +}; + +#endif /* _XT_SOCKET_H */ diff --git a/include/linux/nfsd/export.h b/include/linux/nfsd/export.h index bcd0201589f..a6d9ef2bb34 100644 --- a/include/linux/nfsd/export.h +++ b/include/linux/nfsd/export.h @@ -125,11 +125,9 @@ void			nfsd_export_flush(void);  void			exp_readlock(void);  void			exp_readunlock(void);  struct svc_export *	rqst_exp_get_by_name(struct svc_rqst *, -					     struct vfsmount *, -					     struct dentry *); +					     struct path *);  struct svc_export *	rqst_exp_parent(struct svc_rqst *, -					struct vfsmount *mnt, -					struct dentry *dentry); +					struct path *);  int			exp_rootfh(struct auth_domain *,   					char *path, struct knfsd_fh *, int maxsize);  __be32			exp_pseudoroot(struct svc_rqst *, struct svc_fh *); diff --git a/include/linux/nl80211.h b/include/linux/nl80211.h index cbe8ce3bf48..dbea93b694e 100644 --- a/include/linux/nl80211.h +++ b/include/linux/nl80211.h @@ -7,7 +7,7 @@   * Copyright 2008 Michael Wu <flamingice@sourmilk.net>   * Copyright 2008 Luis Carlos Cobo <luisca@cozybit.com>   * Copyright 2008 Michael Buesch <mb@bu3sch.de> - * Copyright 2008 Luis R. Rodriguez <lrodriguez@atheros.com> + * Copyright 2008, 2009 Luis R. Rodriguez <lrodriguez@atheros.com>   * Copyright 2008 Jouni Malinen <jouni.malinen@atheros.com>   * Copyright 2008 Colin McCabe <colin@cozybit.com>   * @@ -25,6 +25,8 @@   *   */ +#include <linux/types.h> +  /**   * DOC: Station handling   * @@ -46,8 +48,10 @@   *	to get a list of all present wiphys.   * @NL80211_CMD_SET_WIPHY: set wiphy parameters, needs %NL80211_ATTR_WIPHY or   *	%NL80211_ATTR_IFINDEX; can be used to set %NL80211_ATTR_WIPHY_NAME, - *	%NL80211_ATTR_WIPHY_TXQ_PARAMS, %NL80211_ATTR_WIPHY_FREQ, and/or - *	%NL80211_ATTR_WIPHY_CHANNEL_TYPE. + *	%NL80211_ATTR_WIPHY_TXQ_PARAMS, %NL80211_ATTR_WIPHY_FREQ, + *	%NL80211_ATTR_WIPHY_CHANNEL_TYPE, %NL80211_ATTR_WIPHY_RETRY_SHORT, + *	%NL80211_ATTR_WIPHY_RETRY_LONG, %NL80211_ATTR_WIPHY_FRAG_THRESHOLD, + *	and/or %NL80211_ATTR_WIPHY_RTS_THRESHOLD.   * @NL80211_CMD_NEW_WIPHY: Newly created wiphy, response to get request   *	or rename notification. Has attributes %NL80211_ATTR_WIPHY and   *	%NL80211_ATTR_WIPHY_NAME. @@ -75,8 +79,8 @@   * @NL80211_CMD_SET_KEY: Set key attributes %NL80211_ATTR_KEY_DEFAULT,   *	%NL80211_ATTR_KEY_DEFAULT_MGMT, or %NL80211_ATTR_KEY_THRESHOLD.   * @NL80211_CMD_NEW_KEY: add a key with given %NL80211_ATTR_KEY_DATA, - *	%NL80211_ATTR_KEY_IDX, %NL80211_ATTR_MAC and %NL80211_ATTR_KEY_CIPHER - *	attributes. + *	%NL80211_ATTR_KEY_IDX, %NL80211_ATTR_MAC, %NL80211_ATTR_KEY_CIPHER, + *	and %NL80211_ATTR_KEY_SEQ attributes.   * @NL80211_CMD_DEL_KEY: delete a key identified by %NL80211_ATTR_KEY_IDX   *	or %NL80211_ATTR_MAC.   * @@ -166,6 +170,22 @@   * 	set (%NL80211_ATTR_REG_TYPE), if the type of regulatory domain is   * 	%NL80211_REG_TYPE_COUNTRY the alpha2 to which we have moved on   * 	to (%NL80211_ATTR_REG_ALPHA2). + * @NL80211_CMD_REG_BEACON_HINT: indicates to userspace that an AP beacon + * 	has been found while world roaming thus enabling active scan or + * 	any mode of operation that initiates TX (beacons) on a channel + * 	where we would not have been able to do either before. As an example + * 	if you are world roaming (regulatory domain set to world or if your + * 	driver is using a custom world roaming regulatory domain) and while + * 	doing a passive scan on the 5 GHz band you find an AP there (if not + * 	on a DFS channel) you will now be able to actively scan for that AP + * 	or use AP mode on your card on that same channel. Note that this will + * 	never be used for channels 1-11 on the 2 GHz band as they are always + * 	enabled world wide. This beacon hint is only sent if your device had + * 	either disabled active scanning or beaconing on a channel. We send to + * 	userspace the wiphy on which we removed a restriction from + * 	(%NL80211_ATTR_WIPHY) and the channel on which this occurred + * 	before (%NL80211_ATTR_FREQ_BEFORE) and after (%NL80211_ATTR_FREQ_AFTER) + * 	the beacon hint was processed.   *   * @NL80211_CMD_AUTHENTICATE: authentication request and notification.   *	This command is used both as a command (request to authenticate) and @@ -185,8 +205,12 @@   *	frame, i.e., it was for the local STA and was received in correct   *	state. This is similar to MLME-AUTHENTICATE.confirm primitive in the   *	MLME SAP interface (kernel providing MLME, userspace SME). The - *	included NL80211_ATTR_FRAME attribute contains the management frame - *	(including both the header and frame body, but not FCS). + *	included %NL80211_ATTR_FRAME attribute contains the management frame + *	(including both the header and frame body, but not FCS). This event is + *	also used to indicate if the authentication attempt timed out. In that + *	case the %NL80211_ATTR_FRAME attribute is replaced with a + *	%NL80211_ATTR_TIMED_OUT flag (and %NL80211_ATTR_MAC to indicate which + *	pending authentication timed out).   * @NL80211_CMD_ASSOCIATE: association request and notification; like   *	NL80211_CMD_AUTHENTICATE but for Association and Reassociation   *	(similar to MLME-ASSOCIATE.request, MLME-REASSOCIATE.request, @@ -199,6 +223,25 @@   *	NL80211_CMD_AUTHENTICATE but for Disassociation frames (similar to   *	MLME-DISASSOCIATE.request and MLME-DISASSOCIATE.indication primitives).   * + * @NL80211_CMD_MICHAEL_MIC_FAILURE: notification of a locally detected Michael + *	MIC (part of TKIP) failure; sent on the "mlme" multicast group; the + *	event includes %NL80211_ATTR_MAC to describe the source MAC address of + *	the frame with invalid MIC, %NL80211_ATTR_KEY_TYPE to show the key + *	type, %NL80211_ATTR_KEY_IDX to indicate the key identifier, and + *	%NL80211_ATTR_KEY_SEQ to indicate the TSC value of the frame; this + *	event matches with MLME-MICHAELMICFAILURE.indication() primitive + * + * @NL80211_CMD_JOIN_IBSS: Join a new IBSS -- given at least an SSID and a + *	FREQ attribute (for the initial frequency if no peer can be found) + *	and optionally a MAC (as BSSID) and FREQ_FIXED attribute if those + *	should be fixed rather than automatically determined. Can only be + *	executed on a network interface that is UP, and fixed BSSID/FREQ + *	may be rejected. Another optional parameter is the beacon interval, + *	given in the %NL80211_ATTR_BEACON_INTERVAL attribute, which if not + *	given defaults to 100 TU (102.4ms). + * @NL80211_CMD_LEAVE_IBSS: Leave the IBSS -- no special arguments, the IBSS is + *	determined by the network interface. + *   * @NL80211_CMD_MAX: highest used command number   * @__NL80211_CMD_AFTER_LAST: internal use   */ @@ -260,6 +303,13 @@ enum nl80211_commands {  	NL80211_CMD_DEAUTHENTICATE,  	NL80211_CMD_DISASSOCIATE, +	NL80211_CMD_MICHAEL_MIC_FAILURE, + +	NL80211_CMD_REG_BEACON_HINT, + +	NL80211_CMD_JOIN_IBSS, +	NL80211_CMD_LEAVE_IBSS, +  	/* add new commands above here */  	/* used to define NL80211_CMD_MAX below */ @@ -278,6 +328,7 @@ enum nl80211_commands {  #define NL80211_CMD_ASSOCIATE NL80211_CMD_ASSOCIATE  #define NL80211_CMD_DEAUTHENTICATE NL80211_CMD_DEAUTHENTICATE  #define NL80211_CMD_DISASSOCIATE NL80211_CMD_DISASSOCIATE +#define NL80211_CMD_REG_BEACON_HINT NL80211_CMD_REG_BEACON_HINT  /**   * enum nl80211_attrs - nl80211 netlink attributes @@ -296,6 +347,18 @@ enum nl80211_commands {   *	NL80211_CHAN_HT20 = HT20 only   *	NL80211_CHAN_HT40MINUS = secondary channel is below the primary channel   *	NL80211_CHAN_HT40PLUS = secondary channel is above the primary channel + * @NL80211_ATTR_WIPHY_RETRY_SHORT: TX retry limit for frames whose length is + *	less than or equal to the RTS threshold; allowed range: 1..255; + *	dot11ShortRetryLimit; u8 + * @NL80211_ATTR_WIPHY_RETRY_LONG: TX retry limit for frames whose length is + *	greater than the RTS threshold; allowed range: 1..255; + *	dot11ShortLongLimit; u8 + * @NL80211_ATTR_WIPHY_FRAG_THRESHOLD: fragmentation threshold, i.e., maximum + *	length in octets for frames; allowed range: 256..8000, disable + *	fragmentation with (u32)-1; dot11FragmentationThreshold; u32 + * @NL80211_ATTR_WIPHY_RTS_THRESHOLD: RTS threshold (TX frames with length + *	larger than or equal to this use RTS/CTS handshake); allowed range: + *	0..65536, disable with (u32)-1; dot11RTSThreshold; u32   *   * @NL80211_ATTR_IFINDEX: network interface index of the device to operate on   * @NL80211_ATTR_IFNAME: network interface name @@ -319,7 +382,7 @@ enum nl80211_commands {   *   * @NL80211_ATTR_STA_AID: Association ID for the station (u16)   * @NL80211_ATTR_STA_FLAGS: flags, nested element with NLA_FLAG attributes of - *	&enum nl80211_sta_flags. + *	&enum nl80211_sta_flags (deprecated, use %NL80211_ATTR_STA_FLAGS2)   * @NL80211_ATTR_STA_LISTEN_INTERVAL: listen interval as defined by   *	IEEE 802.11 7.3.1.6 (u16).   * @NL80211_ATTR_STA_SUPPORTED_RATES: supported rates, array of supported @@ -380,6 +443,8 @@ enum nl80211_commands {   *   * @NL80211_ATTR_MAX_NUM_SCAN_SSIDS: number of SSIDs you can scan with   *	a single scan request, a wiphy attribute. + * @NL80211_ATTR_MAX_SCAN_IE_LEN: maximum length of information elements + *	that can be added to a scan request   *   * @NL80211_ATTR_SCAN_FREQUENCIES: nested attribute with frequencies (in MHz)   * @NL80211_ATTR_SCAN_SSIDS: nested attribute with SSIDs, leave out for passive @@ -408,6 +473,44 @@ enum nl80211_commands {   * @NL80211_ATTR_REASON_CODE: ReasonCode for %NL80211_CMD_DEAUTHENTICATE and   *	%NL80211_CMD_DISASSOCIATE, u16   * + * @NL80211_ATTR_KEY_TYPE: Key Type, see &enum nl80211_key_type, represented as + *	a u32 + * + * @NL80211_ATTR_FREQ_BEFORE: A channel which has suffered a regulatory change + * 	due to considerations from a beacon hint. This attribute reflects + * 	the state of the channel _before_ the beacon hint processing. This + * 	attributes consists of a nested attribute containing + * 	NL80211_FREQUENCY_ATTR_* + * @NL80211_ATTR_FREQ_AFTER: A channel which has suffered a regulatory change + * 	due to considerations from a beacon hint. This attribute reflects + * 	the state of the channel _after_ the beacon hint processing. This + * 	attributes consists of a nested attribute containing + * 	NL80211_FREQUENCY_ATTR_* + * + * @NL80211_ATTR_CIPHER_SUITES: a set of u32 values indicating the supported + *	cipher suites + * + * @NL80211_ATTR_FREQ_FIXED: a flag indicating the IBSS should not try to look + *	for other networks on different channels + * + * @NL80211_ATTR_TIMED_OUT: a flag indicating than an operation timed out; this + *	is used, e.g., with %NL80211_CMD_AUTHENTICATE event + * + * @NL80211_ATTR_USE_MFP: Whether management frame protection (IEEE 802.11w) is + *	used for the association (&enum nl80211_mfp, represented as a u32); + *	this attribute can be used + *	with %NL80211_CMD_ASSOCIATE request + * + * @NL80211_ATTR_STA_FLAGS2: Attribute containing a + *	&struct nl80211_sta_flag_update. + * + * @NL80211_ATTR_CONTROL_PORT: A flag indicating whether user space controls + *	IEEE 802.1X port, i.e., sets/clears %NL80211_STA_FLAG_AUTHORIZED, in + *	station mode. If the flag is included in %NL80211_CMD_ASSOCIATE + *	request, the driver will assume that the port is unauthorized until + *	authorized by user space. Otherwise, port is marked authorized by + *	default in station mode. + *   * @NL80211_ATTR_MAX: highest attribute number currently defined   * @__NL80211_ATTR_AFTER_LAST: internal use   */ @@ -492,6 +595,30 @@ enum nl80211_attrs {  	NL80211_ATTR_AUTH_TYPE,  	NL80211_ATTR_REASON_CODE, +	NL80211_ATTR_KEY_TYPE, + +	NL80211_ATTR_MAX_SCAN_IE_LEN, +	NL80211_ATTR_CIPHER_SUITES, + +	NL80211_ATTR_FREQ_BEFORE, +	NL80211_ATTR_FREQ_AFTER, + +	NL80211_ATTR_FREQ_FIXED, + + +	NL80211_ATTR_WIPHY_RETRY_SHORT, +	NL80211_ATTR_WIPHY_RETRY_LONG, +	NL80211_ATTR_WIPHY_FRAG_THRESHOLD, +	NL80211_ATTR_WIPHY_RTS_THRESHOLD, + +	NL80211_ATTR_TIMED_OUT, + +	NL80211_ATTR_USE_MFP, + +	NL80211_ATTR_STA_FLAGS2, + +	NL80211_ATTR_CONTROL_PORT, +  	/* add attributes here, update the policy in nl80211.c */  	__NL80211_ATTR_AFTER_LAST, @@ -581,6 +708,18 @@ enum nl80211_sta_flags {  };  /** + * struct nl80211_sta_flag_update - station flags mask/set + * @mask: mask of station flags to set + * @set: which values to set them to + * + * Both mask and set contain bits as per &enum nl80211_sta_flags. + */ +struct nl80211_sta_flag_update { +	__u32 mask; +	__u32 set; +} __attribute__((packed)); + +/**   * enum nl80211_rate_info - bitrate information   *   * These attribute types are used with %NL80211_STA_INFO_TXRATE @@ -1062,4 +1201,27 @@ enum nl80211_auth_type {  	NL80211_AUTHTYPE_FT,  	NL80211_AUTHTYPE_NETWORK_EAP,  }; + +/** + * enum nl80211_key_type - Key Type + * @NL80211_KEYTYPE_GROUP: Group (broadcast/multicast) key + * @NL80211_KEYTYPE_PAIRWISE: Pairwise (unicast/individual) key + * @NL80211_KEYTYPE_PEERKEY: PeerKey (DLS) + */ +enum nl80211_key_type { +	NL80211_KEYTYPE_GROUP, +	NL80211_KEYTYPE_PAIRWISE, +	NL80211_KEYTYPE_PEERKEY, +}; + +/** + * enum nl80211_mfp - Management frame protection state + * @NL80211_MFP_NO: Management frame protection not used + * @NL80211_MFP_REQUIRED: Management frame protection required + */ +enum nl80211_mfp { +	NL80211_MFP_NO, +	NL80211_MFP_REQUIRED, +}; +  #endif /* __LINUX_NL80211_H */ diff --git a/include/linux/nl802154.h b/include/linux/nl802154.h new file mode 100644 index 00000000000..2cda00ccfcc --- /dev/null +++ b/include/linux/nl802154.h @@ -0,0 +1,119 @@ +/* + * nl802154.h + * + * Copyright (C) 2007, 2008, 2009 Siemens AG + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License 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. + * + * You should have received a copy of the GNU General Public License along + * with this program; if not, write to the Free Software Foundation, Inc., + * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. + * + */ + +#ifndef NL802154_H +#define NL802154_H + +#define IEEE802154_NL_NAME "802.15.4 MAC" +#define IEEE802154_MCAST_COORD_NAME "coordinator" +#define IEEE802154_MCAST_BEACON_NAME "beacon" + +enum { +	__IEEE802154_ATTR_INVALID, + +	IEEE802154_ATTR_DEV_NAME, +	IEEE802154_ATTR_DEV_INDEX, + +	IEEE802154_ATTR_STATUS, + +	IEEE802154_ATTR_SHORT_ADDR, +	IEEE802154_ATTR_HW_ADDR, +	IEEE802154_ATTR_PAN_ID, + +	IEEE802154_ATTR_CHANNEL, + +	IEEE802154_ATTR_COORD_SHORT_ADDR, +	IEEE802154_ATTR_COORD_HW_ADDR, +	IEEE802154_ATTR_COORD_PAN_ID, + +	IEEE802154_ATTR_SRC_SHORT_ADDR, +	IEEE802154_ATTR_SRC_HW_ADDR, +	IEEE802154_ATTR_SRC_PAN_ID, + +	IEEE802154_ATTR_DEST_SHORT_ADDR, +	IEEE802154_ATTR_DEST_HW_ADDR, +	IEEE802154_ATTR_DEST_PAN_ID, + +	IEEE802154_ATTR_CAPABILITY, +	IEEE802154_ATTR_REASON, +	IEEE802154_ATTR_SCAN_TYPE, +	IEEE802154_ATTR_CHANNELS, +	IEEE802154_ATTR_DURATION, +	IEEE802154_ATTR_ED_LIST, +	IEEE802154_ATTR_BCN_ORD, +	IEEE802154_ATTR_SF_ORD, +	IEEE802154_ATTR_PAN_COORD, +	IEEE802154_ATTR_BAT_EXT, +	IEEE802154_ATTR_COORD_REALIGN, +	IEEE802154_ATTR_SEC, + +	__IEEE802154_ATTR_MAX, +}; + +#define IEEE802154_ATTR_MAX (__IEEE802154_ATTR_MAX - 1) + +extern struct nla_policy ieee802154_policy[]; + +/* commands */ +/* REQ should be responded with CONF + * and INDIC with RESP + */ +enum { +	__IEEE802154_COMMAND_INVALID, + +	IEEE802154_ASSOCIATE_REQ, +	IEEE802154_ASSOCIATE_CONF, +	IEEE802154_DISASSOCIATE_REQ, +	IEEE802154_DISASSOCIATE_CONF, +	IEEE802154_GET_REQ, +	IEEE802154_GET_CONF, +	IEEE802154_RESET_REQ, +	IEEE802154_RESET_CONF, +	IEEE802154_SCAN_REQ, +	IEEE802154_SCAN_CONF, +	IEEE802154_SET_REQ, +	IEEE802154_SET_CONF, +	IEEE802154_START_REQ, +	IEEE802154_START_CONF, +	IEEE802154_SYNC_REQ, +	IEEE802154_POLL_REQ, +	IEEE802154_POLL_CONF, + +	IEEE802154_ASSOCIATE_INDIC, +	IEEE802154_ASSOCIATE_RESP, +	IEEE802154_DISASSOCIATE_INDIC, +	IEEE802154_BEACON_NOTIFY_INDIC, +	IEEE802154_ORPHAN_INDIC, +	IEEE802154_ORPHAN_RESP, +	IEEE802154_COMM_STATUS_INDIC, +	IEEE802154_SYNC_LOSS_INDIC, + +	IEEE802154_GTS_REQ, /* Not supported yet */ +	IEEE802154_GTS_INDIC, /* Not supported yet */ +	IEEE802154_GTS_CONF, /* Not supported yet */ +	IEEE802154_RX_ENABLE_REQ, /* Not supported yet */ +	IEEE802154_RX_ENABLE_CONF, /* Not supported yet */ + +	__IEEE802154_CMD_MAX, +}; + +#define IEEE802154_CMD_MAX (__IEEE802154_CMD_MAX - 1) + +#endif diff --git a/include/linux/nls.h b/include/linux/nls.h index 6a882208301..52b1a76c1b4 100644 --- a/include/linux/nls.h +++ b/include/linux/nls.h @@ -58,6 +58,25 @@ static inline int nls_strnicmp(struct nls_table *t, const unsigned char *s1,  	return 0;  } +/* + * nls_nullsize - return length of null character for codepage + * @codepage - codepage for which to return length of NULL terminator + * + * Since we can't guarantee that the null terminator will be a particular + * length, we have to check against the codepage. If there's a problem + * determining it, assume a single-byte NULL terminator. + */ +static inline int +nls_nullsize(const struct nls_table *codepage) +{ +	int charlen; +	char tmp[NLS_MAX_CHARSET_SIZE]; + +	charlen = codepage->uni2char(0, tmp, NLS_MAX_CHARSET_SIZE); + +	return charlen > 0 ? charlen : 1; +} +  #define MODULE_ALIAS_NLS(name)	MODULE_ALIAS("nls_" __stringify(name))  #endif /* _LINUX_NLS_H */ diff --git a/include/linux/notifier.h b/include/linux/notifier.h index b86fa2ffca0..81bc252dc8a 100644 --- a/include/linux/notifier.h +++ b/include/linux/notifier.h @@ -198,6 +198,7 @@ static inline int notifier_to_errno(int ret)  #define NETDEV_CHANGENAME	0x000A  #define NETDEV_FEAT_CHANGE	0x000B  #define NETDEV_BONDING_FAILOVER 0x000C +#define NETDEV_PRE_UP		0x000D  #define SYS_DOWN	0x0001	/* Notify of system down */  #define SYS_RESTART	SYS_DOWN diff --git a/include/linux/of.h b/include/linux/of.h index 6a7efa242f5..7be2d1043c1 100644 --- a/include/linux/of.h +++ b/include/linux/of.h @@ -77,6 +77,9 @@ extern int of_n_size_cells(struct device_node *np);  extern const struct of_device_id *of_match_node(  	const struct of_device_id *matches, const struct device_node *node);  extern int of_modalias_node(struct device_node *node, char *modalias, int len); +extern struct device_node *of_parse_phandle(struct device_node *np, +					    const char *phandle_name, +					    int index);  extern int of_parse_phandles_with_args(struct device_node *np,  	const char *list_name, const char *cells_name, int index,  	struct device_node **out_node, const void **out_args); diff --git a/include/linux/of_mdio.h b/include/linux/of_mdio.h new file mode 100644 index 00000000000..c9663c69030 --- /dev/null +++ b/include/linux/of_mdio.h @@ -0,0 +1,22 @@ +/* + * OF helpers for the MDIO (Ethernet PHY) API + * + * Copyright (c) 2009 Secret Lab Technologies, Ltd. + * + * This file is released under the GPLv2 + */ + +#ifndef __LINUX_OF_MDIO_H +#define __LINUX_OF_MDIO_H + +#include <linux/phy.h> +#include <linux/of.h> + +extern int of_mdiobus_register(struct mii_bus *mdio, struct device_node *np); +extern struct phy_device *of_phy_find_device(struct device_node *phy_np); +extern struct phy_device *of_phy_connect(struct net_device *dev, +					 struct device_node *phy_np, +					 void (*hndlr)(struct net_device *), +					 u32 flags, phy_interface_t iface); + +#endif /* __LINUX_OF_MDIO_H */ diff --git a/include/linux/page_cgroup.h b/include/linux/page_cgroup.h index 7339c7bf733..13f126c89ae 100644 --- a/include/linux/page_cgroup.h +++ b/include/linux/page_cgroup.h @@ -18,7 +18,19 @@ struct page_cgroup {  };  void __meminit pgdat_page_cgroup_init(struct pglist_data *pgdat); -void __init page_cgroup_init(void); + +#ifdef CONFIG_SPARSEMEM +static inline void __init page_cgroup_init_flatmem(void) +{ +} +extern void __init page_cgroup_init(void); +#else +void __init page_cgroup_init_flatmem(void); +static inline void __init page_cgroup_init(void) +{ +} +#endif +  struct page_cgroup *lookup_page_cgroup(struct page *page);  enum { @@ -87,6 +99,10 @@ static inline void page_cgroup_init(void)  {  } +static inline void __init page_cgroup_init_flatmem(void) +{ +} +  #endif  #ifdef CONFIG_CGROUP_MEM_RES_CTLR_SWAP diff --git a/include/linux/parport.h b/include/linux/parport.h index e1f83c5065c..38a423ed3c0 100644 --- a/include/linux/parport.h +++ b/include/linux/parport.h @@ -324,6 +324,10 @@ struct parport {  	int spintime;  	atomic_t ref_count; +	unsigned long devflags; +#define PARPORT_DEVPROC_REGISTERED	0 +	struct pardevice *proc_device;	/* Currently register proc device */ +  	struct list_head full_list;  	struct parport *slaves[3];  }; diff --git a/include/linux/pci_ids.h b/include/linux/pci_ids.h index 06ba90c211a..aa01d38c997 100644 --- a/include/linux/pci_ids.h +++ b/include/linux/pci_ids.h @@ -1005,6 +1005,7 @@  #define PCI_DEVICE_ID_PLX_PCI200SYN	0x3196  #define PCI_DEVICE_ID_PLX_9030          0x9030  #define PCI_DEVICE_ID_PLX_9050		0x9050 +#define PCI_DEVICE_ID_PLX_9056		0x9056  #define PCI_DEVICE_ID_PLX_9080		0x9080  #define PCI_DEVICE_ID_PLX_GTEK_SERIAL2	0xa001 @@ -1066,8 +1067,6 @@  #define PCI_DEVICE_ID_NVIDIA_NFORCE_MCP04_SMBUS	0x0034  #define PCI_DEVICE_ID_NVIDIA_NFORCE_MCP04_IDE	0x0035  #define PCI_DEVICE_ID_NVIDIA_NFORCE_MCP04_SATA	0x0036 -#define PCI_DEVICE_ID_NVIDIA_NVENET_10		0x0037 -#define PCI_DEVICE_ID_NVIDIA_NVENET_11		0x0038  #define PCI_DEVICE_ID_NVIDIA_NFORCE_MCP04_SATA2	0x003e  #define PCI_DEVICE_ID_NVIDIA_GEFORCE_6800_ULTRA 0x0040  #define PCI_DEVICE_ID_NVIDIA_GEFORCE_6800       0x0041 @@ -1078,21 +1077,16 @@  #define PCI_DEVICE_ID_NVIDIA_NFORCE_CK804_IDE	0x0053  #define PCI_DEVICE_ID_NVIDIA_NFORCE_CK804_SATA	0x0054  #define PCI_DEVICE_ID_NVIDIA_NFORCE_CK804_SATA2	0x0055 -#define PCI_DEVICE_ID_NVIDIA_NVENET_8		0x0056 -#define PCI_DEVICE_ID_NVIDIA_NVENET_9		0x0057  #define PCI_DEVICE_ID_NVIDIA_CK804_AUDIO	0x0059  #define PCI_DEVICE_ID_NVIDIA_CK804_PCIE		0x005d  #define PCI_DEVICE_ID_NVIDIA_NFORCE2_SMBUS	0x0064  #define PCI_DEVICE_ID_NVIDIA_NFORCE2_IDE	0x0065 -#define PCI_DEVICE_ID_NVIDIA_NVENET_2		0x0066  #define PCI_DEVICE_ID_NVIDIA_MCP2_MODEM		0x0069  #define PCI_DEVICE_ID_NVIDIA_MCP2_AUDIO		0x006a  #define PCI_DEVICE_ID_NVIDIA_NFORCE2S_SMBUS	0x0084  #define PCI_DEVICE_ID_NVIDIA_NFORCE2S_IDE	0x0085 -#define PCI_DEVICE_ID_NVIDIA_NVENET_4		0x0086  #define PCI_DEVICE_ID_NVIDIA_MCP2S_MODEM	0x0089  #define PCI_DEVICE_ID_NVIDIA_CK8_AUDIO		0x008a -#define PCI_DEVICE_ID_NVIDIA_NVENET_5		0x008c  #define PCI_DEVICE_ID_NVIDIA_NFORCE2S_SATA	0x008e  #define PCI_DEVICE_ID_NVIDIA_GEFORCE_7800_GT   0x0090  #define PCI_DEVICE_ID_NVIDIA_GEFORCE_7800_GTX	0x0091 @@ -1108,15 +1102,12 @@  #define PCI_DEVICE_ID_NVIDIA_NFORCE3		0x00d1  #define PCI_DEVICE_ID_NVIDIA_NFORCE3_SMBUS	0x00d4  #define PCI_DEVICE_ID_NVIDIA_NFORCE3_IDE	0x00d5 -#define PCI_DEVICE_ID_NVIDIA_NVENET_3		0x00d6  #define PCI_DEVICE_ID_NVIDIA_MCP3_MODEM		0x00d9  #define PCI_DEVICE_ID_NVIDIA_MCP3_AUDIO		0x00da -#define PCI_DEVICE_ID_NVIDIA_NVENET_7		0x00df  #define PCI_DEVICE_ID_NVIDIA_NFORCE3S		0x00e1  #define PCI_DEVICE_ID_NVIDIA_NFORCE3S_SATA	0x00e3  #define PCI_DEVICE_ID_NVIDIA_NFORCE3S_SMBUS	0x00e4  #define PCI_DEVICE_ID_NVIDIA_NFORCE3S_IDE	0x00e5 -#define PCI_DEVICE_ID_NVIDIA_NVENET_6		0x00e6  #define PCI_DEVICE_ID_NVIDIA_CK8S_AUDIO		0x00ea  #define PCI_DEVICE_ID_NVIDIA_NFORCE3S_SATA2	0x00ee  #define PCIE_DEVICE_ID_NVIDIA_GEFORCE_6800_ALT1 0x00f0 @@ -1176,7 +1167,6 @@  #define PCI_DEVICE_ID_NVIDIA_NFORCE_SMBUS	0x01b4  #define PCI_DEVICE_ID_NVIDIA_NFORCE_IDE		0x01bc  #define PCI_DEVICE_ID_NVIDIA_MCP1_MODEM		0x01c1 -#define PCI_DEVICE_ID_NVIDIA_NVENET_1		0x01c3  #define PCI_DEVICE_ID_NVIDIA_NFORCE2		0x01e0  #define PCI_DEVICE_ID_NVIDIA_GEFORCE3		0x0200  #define PCI_DEVICE_ID_NVIDIA_GEFORCE3_1		0x0201 @@ -1199,8 +1189,6 @@  #define PCI_DEVICE_ID_NVIDIA_NFORCE_MCP55_IDE	0x036E  #define PCI_DEVICE_ID_NVIDIA_NFORCE_MCP55_SATA	0x037E  #define PCI_DEVICE_ID_NVIDIA_NFORCE_MCP55_SATA2	0x037F -#define PCI_DEVICE_ID_NVIDIA_NVENET_12		0x0268 -#define PCI_DEVICE_ID_NVIDIA_NVENET_13		0x0269  #define PCI_DEVICE_ID_NVIDIA_GEFORCE4_TI_4800	0x0280  #define PCI_DEVICE_ID_NVIDIA_GEFORCE4_TI_4800_8X    0x0281  #define PCI_DEVICE_ID_NVIDIA_GEFORCE4_TI_4800SE     0x0282 @@ -1247,46 +1235,21 @@  #define PCI_DEVICE_ID_NVIDIA_GEFORCE_FX_GO5700_2    0x0348  #define PCI_DEVICE_ID_NVIDIA_QUADRO_FX_GO1000       0x034C  #define PCI_DEVICE_ID_NVIDIA_QUADRO_FX_1100         0x034E -#define PCI_DEVICE_ID_NVIDIA_NVENET_14              0x0372  #define PCI_DEVICE_ID_NVIDIA_NVENET_15              0x0373 -#define PCI_DEVICE_ID_NVIDIA_NVENET_16              0x03E5 -#define PCI_DEVICE_ID_NVIDIA_NVENET_17              0x03E6  #define PCI_DEVICE_ID_NVIDIA_NFORCE_MCP61_SATA      0x03E7  #define PCI_DEVICE_ID_NVIDIA_NFORCE_MCP61_SMBUS	    0x03EB  #define PCI_DEVICE_ID_NVIDIA_NFORCE_MCP61_IDE       0x03EC -#define PCI_DEVICE_ID_NVIDIA_NVENET_18              0x03EE -#define PCI_DEVICE_ID_NVIDIA_NVENET_19              0x03EF  #define PCI_DEVICE_ID_NVIDIA_NFORCE_MCP61_SATA2     0x03F6  #define PCI_DEVICE_ID_NVIDIA_NFORCE_MCP61_SATA3     0x03F7  #define PCI_DEVICE_ID_NVIDIA_NFORCE_MCP65_SMBUS	    0x0446  #define PCI_DEVICE_ID_NVIDIA_NFORCE_MCP65_IDE	    0x0448 -#define PCI_DEVICE_ID_NVIDIA_NVENET_20              0x0450 -#define PCI_DEVICE_ID_NVIDIA_NVENET_21              0x0451 -#define PCI_DEVICE_ID_NVIDIA_NVENET_22              0x0452 -#define PCI_DEVICE_ID_NVIDIA_NVENET_23              0x0453  #define PCI_DEVICE_ID_NVIDIA_NFORCE_MCP67_SMBUS     0x0542 -#define PCI_DEVICE_ID_NVIDIA_NVENET_24              0x054C -#define PCI_DEVICE_ID_NVIDIA_NVENET_25              0x054D -#define PCI_DEVICE_ID_NVIDIA_NVENET_26              0x054E -#define PCI_DEVICE_ID_NVIDIA_NVENET_27              0x054F -#define PCI_DEVICE_ID_NVIDIA_NVENET_28              0x07DC -#define PCI_DEVICE_ID_NVIDIA_NVENET_29              0x07DD -#define PCI_DEVICE_ID_NVIDIA_NVENET_30              0x07DE -#define PCI_DEVICE_ID_NVIDIA_NVENET_31              0x07DF  #define PCI_DEVICE_ID_NVIDIA_NFORCE_MCP67_IDE       0x0560  #define PCI_DEVICE_ID_NVIDIA_NFORCE_MCP73_IDE       0x056C  #define PCI_DEVICE_ID_NVIDIA_NFORCE_MCP78S_SMBUS    0x0752  #define PCI_DEVICE_ID_NVIDIA_NFORCE_MCP77_IDE       0x0759 -#define PCI_DEVICE_ID_NVIDIA_NVENET_32              0x0760 -#define PCI_DEVICE_ID_NVIDIA_NVENET_33              0x0761 -#define PCI_DEVICE_ID_NVIDIA_NVENET_34              0x0762 -#define PCI_DEVICE_ID_NVIDIA_NVENET_35              0x0763  #define PCI_DEVICE_ID_NVIDIA_NFORCE_MCP73_SMBUS     0x07D8  #define PCI_DEVICE_ID_NVIDIA_NFORCE_MCP79_SMBUS     0x0AA2 -#define PCI_DEVICE_ID_NVIDIA_NVENET_36              0x0AB0 -#define PCI_DEVICE_ID_NVIDIA_NVENET_37              0x0AB1 -#define PCI_DEVICE_ID_NVIDIA_NVENET_38              0x0AB2 -#define PCI_DEVICE_ID_NVIDIA_NVENET_39              0x0AB3  #define PCI_VENDOR_ID_IMS		0x10e0  #define PCI_DEVICE_ID_IMS_TT128		0x9128 @@ -1314,6 +1277,13 @@  #define PCI_VENDOR_ID_CREATIVE		0x1102 /* duplicate: ECTIVA */  #define PCI_DEVICE_ID_CREATIVE_EMU10K1	0x0002 +#define PCI_DEVICE_ID_CREATIVE_20K1	0x0005 +#define PCI_DEVICE_ID_CREATIVE_20K2	0x000b +#define PCI_SUBDEVICE_ID_CREATIVE_SB0760	0x0024 +#define PCI_SUBDEVICE_ID_CREATIVE_SB08801	0x0041 +#define PCI_SUBDEVICE_ID_CREATIVE_SB08802	0x0042 +#define PCI_SUBDEVICE_ID_CREATIVE_SB08803	0x0043 +#define PCI_SUBDEVICE_ID_CREATIVE_HENDRIX	0x6000  #define PCI_VENDOR_ID_ECTIVA		0x1102 /* duplicate: CREATIVE */  #define PCI_DEVICE_ID_ECTIVA_EV1938	0x8938 @@ -1406,7 +1376,7 @@  #define PCI_DEVICE_ID_VIA_82C598_1	0x8598  #define PCI_DEVICE_ID_VIA_838X_1	0xB188  #define PCI_DEVICE_ID_VIA_83_87XX_1	0xB198 -#define PCI_DEVICE_ID_VIA_C409_IDE	0XC409 +#define PCI_DEVICE_ID_VIA_VX855_IDE	0xC409  #define PCI_DEVICE_ID_VIA_ANON		0xFFFF  #define PCI_VENDOR_ID_SIEMENS           0x110A @@ -1847,6 +1817,10 @@  #define PCI_SUBDEVICE_ID_HYPERCOPE_METRO	0x0107  #define PCI_SUBDEVICE_ID_HYPERCOPE_CHAMP2	0x0108 +#define PCI_VENDOR_ID_DIGIGRAM		0x1369 +#define PCI_SUBDEVICE_ID_DIGIGRAM_LX6464ES_SERIAL_SUBSYSTEM	0xc001 +#define PCI_SUBDEVICE_ID_DIGIGRAM_LX6464ES_CAE_SERIAL_SUBSYSTEM	0xc002 +  #define PCI_VENDOR_ID_KAWASAKI		0x136b  #define PCI_DEVICE_ID_MCHIP_KL5A72002	0xff01 @@ -1914,6 +1888,8 @@  #define PCI_SUBDEVICE_ID_CCD_SWYX4S	0xB540  #define PCI_SUBDEVICE_ID_CCD_JH4S20	0xB550  #define PCI_SUBDEVICE_ID_CCD_IOB8ST_1	0xB552 +#define PCI_SUBDEVICE_ID_CCD_JHSE1	0xB553 +#define PCI_SUBDEVICE_ID_CCD_JH8S	0xB55B  #define PCI_SUBDEVICE_ID_CCD_BN4S	0xB560  #define PCI_SUBDEVICE_ID_CCD_BN8S	0xB562  #define PCI_SUBDEVICE_ID_CCD_BNE1	0xB563 @@ -1996,10 +1972,12 @@  #define PCI_DEVICE_ID_OXSEMI_PCIe952_1_U	0xC118  #define PCI_DEVICE_ID_OXSEMI_PCIe952_1_GU	0xC11C  #define PCI_DEVICE_ID_OXSEMI_16PCI954	0x9501 +#define PCI_DEVICE_ID_OXSEMI_C950	0x950B  #define PCI_DEVICE_ID_OXSEMI_16PCI95N	0x9511  #define PCI_DEVICE_ID_OXSEMI_16PCI954PP	0x9513  #define PCI_DEVICE_ID_OXSEMI_16PCI952	0x9521  #define PCI_DEVICE_ID_OXSEMI_16PCI952PP	0x9523 +#define PCI_SUBDEVICE_ID_OXSEMI_C950	0x0001  #define PCI_VENDOR_ID_CHELSIO		0x1425 @@ -2113,6 +2091,7 @@  #define PCI_VENDOR_ID_MAINPINE		0x1522  #define PCI_DEVICE_ID_MAINPINE_PBRIDGE	0x0100  #define PCI_VENDOR_ID_ENE		0x1524 +#define PCI_DEVICE_ID_ENE_CB710_FLASH	0x0510  #define PCI_DEVICE_ID_ENE_CB712_SD	0x0550  #define PCI_DEVICE_ID_ENE_CB712_SD_2	0x0551  #define PCI_DEVICE_ID_ENE_CB714_SD	0x0750 @@ -2274,6 +2253,8 @@  #define PCI_DEVICE_ID_MPC8547E		0x0018  #define PCI_DEVICE_ID_MPC8545E		0x0019  #define PCI_DEVICE_ID_MPC8545		0x001a +#define PCI_DEVICE_ID_MPC8569E		0x0061 +#define PCI_DEVICE_ID_MPC8569		0x0060  #define PCI_DEVICE_ID_MPC8568E		0x0020  #define PCI_DEVICE_ID_MPC8568		0x0021  #define PCI_DEVICE_ID_MPC8567E		0x0022 @@ -2286,6 +2267,8 @@  #define PCI_DEVICE_ID_MPC8572		0x0041  #define PCI_DEVICE_ID_MPC8536E		0x0050  #define PCI_DEVICE_ID_MPC8536		0x0051 +#define PCI_DEVICE_ID_P2020E		0x0070 +#define PCI_DEVICE_ID_P2020		0x0071  #define PCI_DEVICE_ID_MPC8641		0x7010  #define PCI_DEVICE_ID_MPC8641D		0x7011  #define PCI_DEVICE_ID_MPC8610		0x7018 @@ -2313,6 +2296,8 @@  #define PCI_VENDOR_ID_QMI		0x1a32 +#define PCI_VENDOR_ID_AZWAVE		0x1a3b +  #define PCI_VENDOR_ID_TEKRAM		0x1de1  #define PCI_DEVICE_ID_TEKRAM_DC290	0xdc29 diff --git a/include/linux/percpu.h b/include/linux/percpu.h index 1581ff235c7..26fd9d12f05 100644 --- a/include/linux/percpu.h +++ b/include/linux/percpu.h @@ -86,7 +86,12 @@ struct percpu_data {  	void *ptrs[1];  }; +/* pointer disguising messes up the kmemleak objects tracking */ +#ifndef CONFIG_DEBUG_KMEMLEAK  #define __percpu_disguise(pdata) (struct percpu_data *)~(unsigned long)(pdata) +#else +#define __percpu_disguise(pdata) (struct percpu_data *)(pdata) +#endif  #define per_cpu_ptr(ptr, cpu)						\  ({									\ diff --git a/include/linux/perf_counter.h b/include/linux/perf_counter.h new file mode 100644 index 00000000000..1b3118a1023 --- /dev/null +++ b/include/linux/perf_counter.h @@ -0,0 +1,709 @@ +/* + *  Performance counters: + * + *    Copyright (C) 2008-2009, Thomas Gleixner <tglx@linutronix.de> + *    Copyright (C) 2008-2009, Red Hat, Inc., Ingo Molnar + *    Copyright (C) 2008-2009, Red Hat, Inc., Peter Zijlstra + * + *  Data type definitions, declarations, prototypes. + * + *    Started by: Thomas Gleixner and Ingo Molnar + * + *  For licencing details see kernel-base/COPYING + */ +#ifndef _LINUX_PERF_COUNTER_H +#define _LINUX_PERF_COUNTER_H + +#include <linux/types.h> +#include <linux/ioctl.h> +#include <asm/byteorder.h> + +/* + * User-space ABI bits: + */ + +/* + * attr.type + */ +enum perf_type_id { +	PERF_TYPE_HARDWARE			= 0, +	PERF_TYPE_SOFTWARE			= 1, +	PERF_TYPE_TRACEPOINT			= 2, +	PERF_TYPE_HW_CACHE			= 3, +	PERF_TYPE_RAW				= 4, + +	PERF_TYPE_MAX,				/* non-ABI */ +}; + +/* + * Generalized performance counter event types, used by the + * attr.event_id parameter of the sys_perf_counter_open() + * syscall: + */ +enum perf_hw_id { +	/* +	 * Common hardware events, generalized by the kernel: +	 */ +	PERF_COUNT_HW_CPU_CYCLES		= 0, +	PERF_COUNT_HW_INSTRUCTIONS		= 1, +	PERF_COUNT_HW_CACHE_REFERENCES		= 2, +	PERF_COUNT_HW_CACHE_MISSES		= 3, +	PERF_COUNT_HW_BRANCH_INSTRUCTIONS	= 4, +	PERF_COUNT_HW_BRANCH_MISSES		= 5, +	PERF_COUNT_HW_BUS_CYCLES		= 6, + +	PERF_COUNT_HW_MAX,			/* non-ABI */ +}; + +/* + * Generalized hardware cache counters: + * + *       { L1-D, L1-I, LLC, ITLB, DTLB, BPU } x + *       { read, write, prefetch } x + *       { accesses, misses } + */ +enum perf_hw_cache_id { +	PERF_COUNT_HW_CACHE_L1D			= 0, +	PERF_COUNT_HW_CACHE_L1I			= 1, +	PERF_COUNT_HW_CACHE_LL			= 2, +	PERF_COUNT_HW_CACHE_DTLB		= 3, +	PERF_COUNT_HW_CACHE_ITLB		= 4, +	PERF_COUNT_HW_CACHE_BPU			= 5, + +	PERF_COUNT_HW_CACHE_MAX,		/* non-ABI */ +}; + +enum perf_hw_cache_op_id { +	PERF_COUNT_HW_CACHE_OP_READ		= 0, +	PERF_COUNT_HW_CACHE_OP_WRITE		= 1, +	PERF_COUNT_HW_CACHE_OP_PREFETCH		= 2, + +	PERF_COUNT_HW_CACHE_OP_MAX,		/* non-ABI */ +}; + +enum perf_hw_cache_op_result_id { +	PERF_COUNT_HW_CACHE_RESULT_ACCESS	= 0, +	PERF_COUNT_HW_CACHE_RESULT_MISS		= 1, + +	PERF_COUNT_HW_CACHE_RESULT_MAX,		/* non-ABI */ +}; + +/* + * Special "software" counters provided by the kernel, even if the hardware + * does not support performance counters. These counters measure various + * physical and sw events of the kernel (and allow the profiling of them as + * well): + */ +enum perf_sw_ids { +	PERF_COUNT_SW_CPU_CLOCK			= 0, +	PERF_COUNT_SW_TASK_CLOCK		= 1, +	PERF_COUNT_SW_PAGE_FAULTS		= 2, +	PERF_COUNT_SW_CONTEXT_SWITCHES		= 3, +	PERF_COUNT_SW_CPU_MIGRATIONS		= 4, +	PERF_COUNT_SW_PAGE_FAULTS_MIN		= 5, +	PERF_COUNT_SW_PAGE_FAULTS_MAJ		= 6, + +	PERF_COUNT_SW_MAX,			/* non-ABI */ +}; + +/* + * Bits that can be set in attr.sample_type to request information + * in the overflow packets. + */ +enum perf_counter_sample_format { +	PERF_SAMPLE_IP				= 1U << 0, +	PERF_SAMPLE_TID				= 1U << 1, +	PERF_SAMPLE_TIME			= 1U << 2, +	PERF_SAMPLE_ADDR			= 1U << 3, +	PERF_SAMPLE_GROUP			= 1U << 4, +	PERF_SAMPLE_CALLCHAIN			= 1U << 5, +	PERF_SAMPLE_ID				= 1U << 6, +	PERF_SAMPLE_CPU				= 1U << 7, +	PERF_SAMPLE_PERIOD			= 1U << 8, + +	PERF_SAMPLE_MAX = 1U << 9,		/* non-ABI */ +}; + +/* + * Bits that can be set in attr.read_format to request that + * reads on the counter should return the indicated quantities, + * in increasing order of bit value, after the counter value. + */ +enum perf_counter_read_format { +	PERF_FORMAT_TOTAL_TIME_ENABLED		= 1U << 0, +	PERF_FORMAT_TOTAL_TIME_RUNNING		= 1U << 1, +	PERF_FORMAT_ID				= 1U << 2, + +	PERF_FORMAT_MAX = 1U << 3, 		/* non-ABI */ +}; + +#define PERF_ATTR_SIZE_VER0	64	/* sizeof first published struct */ + +/* + * Hardware event to monitor via a performance monitoring counter: + */ +struct perf_counter_attr { + +	/* +	 * Major type: hardware/software/tracepoint/etc. +	 */ +	__u32			type; + +	/* +	 * Size of the attr structure, for fwd/bwd compat. +	 */ +	__u32			size; + +	/* +	 * Type specific configuration information. +	 */ +	__u64			config; + +	union { +		__u64		sample_period; +		__u64		sample_freq; +	}; + +	__u64			sample_type; +	__u64			read_format; + +	__u64			disabled       :  1, /* off by default        */ +				inherit	       :  1, /* children inherit it   */ +				pinned	       :  1, /* must always be on PMU */ +				exclusive      :  1, /* only group on PMU     */ +				exclude_user   :  1, /* don't count user      */ +				exclude_kernel :  1, /* ditto kernel          */ +				exclude_hv     :  1, /* ditto hypervisor      */ +				exclude_idle   :  1, /* don't count when idle */ +				mmap           :  1, /* include mmap data     */ +				comm	       :  1, /* include comm data     */ +				freq           :  1, /* use freq, not period  */ + +				__reserved_1   : 53; + +	__u32			wakeup_events;	/* wakeup every n events */ +	__u32			__reserved_2; + +	__u64			__reserved_3; +}; + +/* + * Ioctls that can be done on a perf counter fd: + */ +#define PERF_COUNTER_IOC_ENABLE		_IO ('$', 0) +#define PERF_COUNTER_IOC_DISABLE	_IO ('$', 1) +#define PERF_COUNTER_IOC_REFRESH	_IO ('$', 2) +#define PERF_COUNTER_IOC_RESET		_IO ('$', 3) +#define PERF_COUNTER_IOC_PERIOD		_IOW('$', 4, u64) + +enum perf_counter_ioc_flags { +	PERF_IOC_FLAG_GROUP		= 1U << 0, +}; + +/* + * Structure of the page that can be mapped via mmap + */ +struct perf_counter_mmap_page { +	__u32	version;		/* version number of this structure */ +	__u32	compat_version;		/* lowest version this is compat with */ + +	/* +	 * Bits needed to read the hw counters in user-space. +	 * +	 *   u32 seq; +	 *   s64 count; +	 * +	 *   do { +	 *     seq = pc->lock; +	 * +	 *     barrier() +	 *     if (pc->index) { +	 *       count = pmc_read(pc->index - 1); +	 *       count += pc->offset; +	 *     } else +	 *       goto regular_read; +	 * +	 *     barrier(); +	 *   } while (pc->lock != seq); +	 * +	 * NOTE: for obvious reason this only works on self-monitoring +	 *       processes. +	 */ +	__u32	lock;			/* seqlock for synchronization */ +	__u32	index;			/* hardware counter identifier */ +	__s64	offset;			/* add to hardware counter value */ + +	/* +	 * Control data for the mmap() data buffer. +	 * +	 * User-space reading this value should issue an rmb(), on SMP capable +	 * platforms, after reading this value -- see perf_counter_wakeup(). +	 */ +	__u64   data_head;		/* head in the data section */ +}; + +#define PERF_EVENT_MISC_CPUMODE_MASK		(3 << 0) +#define PERF_EVENT_MISC_CPUMODE_UNKNOWN		(0 << 0) +#define PERF_EVENT_MISC_KERNEL			(1 << 0) +#define PERF_EVENT_MISC_USER			(2 << 0) +#define PERF_EVENT_MISC_HYPERVISOR		(3 << 0) +#define PERF_EVENT_MISC_OVERFLOW		(1 << 2) + +struct perf_event_header { +	__u32	type; +	__u16	misc; +	__u16	size; +}; + +enum perf_event_type { + +	/* +	 * The MMAP events record the PROT_EXEC mappings so that we can +	 * correlate userspace IPs to code. They have the following structure: +	 * +	 * struct { +	 *	struct perf_event_header	header; +	 * +	 *	u32				pid, tid; +	 *	u64				addr; +	 *	u64				len; +	 *	u64				pgoff; +	 *	char				filename[]; +	 * }; +	 */ +	PERF_EVENT_MMAP			= 1, + +	/* +	 * struct { +	 *	struct perf_event_header	header; +	 * +	 *	u32				pid, tid; +	 *	char				comm[]; +	 * }; +	 */ +	PERF_EVENT_COMM			= 3, + +	/* +	 * struct { +	 *	struct perf_event_header	header; +	 *	u64				time; +	 *	u64				id; +	 *	u64				sample_period; +	 * }; +	 */ +	PERF_EVENT_PERIOD		= 4, + +	/* +	 * struct { +	 *	struct perf_event_header	header; +	 *	u64				time; +	 *	u64				id; +	 * }; +	 */ +	PERF_EVENT_THROTTLE		= 5, +	PERF_EVENT_UNTHROTTLE		= 6, + +	/* +	 * struct { +	 *	struct perf_event_header	header; +	 *	u32				pid, ppid; +	 * }; +	 */ +	PERF_EVENT_FORK			= 7, + +	/* +	 * When header.misc & PERF_EVENT_MISC_OVERFLOW the event_type field +	 * will be PERF_RECORD_* +	 * +	 * struct { +	 *	struct perf_event_header	header; +	 * +	 *	{ u64			ip;	  } && PERF_RECORD_IP +	 *	{ u32			pid, tid; } && PERF_RECORD_TID +	 *	{ u64			time;     } && PERF_RECORD_TIME +	 *	{ u64			addr;     } && PERF_RECORD_ADDR +	 *	{ u64			config;   } && PERF_RECORD_CONFIG +	 *	{ u32			cpu, res; } && PERF_RECORD_CPU +	 * +	 *	{ u64			nr; +	 *	  { u64 id, val; }	cnt[nr];  } && PERF_RECORD_GROUP +	 * +	 *	{ u16			nr, +	 *				hv, +	 *				kernel, +	 *				user; +	 *	  u64			ips[nr];  } && PERF_RECORD_CALLCHAIN +	 * }; +	 */ +}; + +#ifdef __KERNEL__ +/* + * Kernel-internal data types and definitions: + */ + +#ifdef CONFIG_PERF_COUNTERS +# include <asm/perf_counter.h> +#endif + +#include <linux/list.h> +#include <linux/mutex.h> +#include <linux/rculist.h> +#include <linux/rcupdate.h> +#include <linux/spinlock.h> +#include <linux/hrtimer.h> +#include <linux/fs.h> +#include <linux/pid_namespace.h> +#include <asm/atomic.h> + +struct task_struct; + +/** + * struct hw_perf_counter - performance counter hardware details: + */ +struct hw_perf_counter { +#ifdef CONFIG_PERF_COUNTERS +	union { +		struct { /* hardware */ +			u64		config; +			unsigned long	config_base; +			unsigned long	counter_base; +			int		idx; +		}; +		union { /* software */ +			atomic64_t	count; +			struct hrtimer	hrtimer; +		}; +	}; +	atomic64_t			prev_count; +	u64				sample_period; +	u64				last_period; +	atomic64_t			period_left; +	u64				interrupts; + +	u64				freq_count; +	u64				freq_interrupts; +	u64				freq_stamp; +#endif +}; + +struct perf_counter; + +/** + * struct pmu - generic performance monitoring unit + */ +struct pmu { +	int (*enable)			(struct perf_counter *counter); +	void (*disable)			(struct perf_counter *counter); +	void (*read)			(struct perf_counter *counter); +	void (*unthrottle)		(struct perf_counter *counter); +}; + +/** + * enum perf_counter_active_state - the states of a counter + */ +enum perf_counter_active_state { +	PERF_COUNTER_STATE_ERROR	= -2, +	PERF_COUNTER_STATE_OFF		= -1, +	PERF_COUNTER_STATE_INACTIVE	=  0, +	PERF_COUNTER_STATE_ACTIVE	=  1, +}; + +struct file; + +struct perf_mmap_data { +	struct rcu_head			rcu_head; +	int				nr_pages;	/* nr of data pages  */ +	int				nr_locked;	/* nr pages mlocked  */ + +	atomic_t			poll;		/* POLL_ for wakeups */ +	atomic_t			events;		/* event limit       */ + +	atomic_long_t			head;		/* write position    */ +	atomic_long_t			done_head;	/* completed head    */ + +	atomic_t			lock;		/* concurrent writes */ + +	atomic_t			wakeup;		/* needs a wakeup    */ + +	struct perf_counter_mmap_page   *user_page; +	void				*data_pages[0]; +}; + +struct perf_pending_entry { +	struct perf_pending_entry *next; +	void (*func)(struct perf_pending_entry *); +}; + +/** + * struct perf_counter - performance counter kernel representation: + */ +struct perf_counter { +#ifdef CONFIG_PERF_COUNTERS +	struct list_head		list_entry; +	struct list_head		event_entry; +	struct list_head		sibling_list; +	int				nr_siblings; +	struct perf_counter		*group_leader; +	const struct pmu		*pmu; + +	enum perf_counter_active_state	state; +	atomic64_t			count; + +	/* +	 * These are the total time in nanoseconds that the counter +	 * has been enabled (i.e. eligible to run, and the task has +	 * been scheduled in, if this is a per-task counter) +	 * and running (scheduled onto the CPU), respectively. +	 * +	 * They are computed from tstamp_enabled, tstamp_running and +	 * tstamp_stopped when the counter is in INACTIVE or ACTIVE state. +	 */ +	u64				total_time_enabled; +	u64				total_time_running; + +	/* +	 * These are timestamps used for computing total_time_enabled +	 * and total_time_running when the counter is in INACTIVE or +	 * ACTIVE state, measured in nanoseconds from an arbitrary point +	 * in time. +	 * tstamp_enabled: the notional time when the counter was enabled +	 * tstamp_running: the notional time when the counter was scheduled on +	 * tstamp_stopped: in INACTIVE state, the notional time when the +	 *	counter was scheduled off. +	 */ +	u64				tstamp_enabled; +	u64				tstamp_running; +	u64				tstamp_stopped; + +	struct perf_counter_attr	attr; +	struct hw_perf_counter		hw; + +	struct perf_counter_context	*ctx; +	struct file			*filp; + +	/* +	 * These accumulate total time (in nanoseconds) that children +	 * counters have been enabled and running, respectively. +	 */ +	atomic64_t			child_total_time_enabled; +	atomic64_t			child_total_time_running; + +	/* +	 * Protect attach/detach and child_list: +	 */ +	struct mutex			child_mutex; +	struct list_head		child_list; +	struct perf_counter		*parent; + +	int				oncpu; +	int				cpu; + +	struct list_head		owner_entry; +	struct task_struct		*owner; + +	/* mmap bits */ +	struct mutex			mmap_mutex; +	atomic_t			mmap_count; +	struct perf_mmap_data		*data; + +	/* poll related */ +	wait_queue_head_t		waitq; +	struct fasync_struct		*fasync; + +	/* delayed work for NMIs and such */ +	int				pending_wakeup; +	int				pending_kill; +	int				pending_disable; +	struct perf_pending_entry	pending; + +	atomic_t			event_limit; + +	void (*destroy)(struct perf_counter *); +	struct rcu_head			rcu_head; + +	struct pid_namespace		*ns; +	u64				id; +#endif +}; + +/** + * struct perf_counter_context - counter context structure + * + * Used as a container for task counters and CPU counters as well: + */ +struct perf_counter_context { +	/* +	 * Protect the states of the counters in the list, +	 * nr_active, and the list: +	 */ +	spinlock_t			lock; +	/* +	 * Protect the list of counters.  Locking either mutex or lock +	 * is sufficient to ensure the list doesn't change; to change +	 * the list you need to lock both the mutex and the spinlock. +	 */ +	struct mutex			mutex; + +	struct list_head		counter_list; +	struct list_head		event_list; +	int				nr_counters; +	int				nr_active; +	int				is_active; +	atomic_t			refcount; +	struct task_struct		*task; + +	/* +	 * Context clock, runs when context enabled. +	 */ +	u64				time; +	u64				timestamp; + +	/* +	 * These fields let us detect when two contexts have both +	 * been cloned (inherited) from a common ancestor. +	 */ +	struct perf_counter_context	*parent_ctx; +	u64				parent_gen; +	u64				generation; +	int				pin_count; +	struct rcu_head			rcu_head; +}; + +/** + * struct perf_counter_cpu_context - per cpu counter context structure + */ +struct perf_cpu_context { +	struct perf_counter_context	ctx; +	struct perf_counter_context	*task_ctx; +	int				active_oncpu; +	int				max_pertask; +	int				exclusive; + +	/* +	 * Recursion avoidance: +	 * +	 * task, softirq, irq, nmi context +	 */ +	int				recursion[4]; +}; + +#ifdef CONFIG_PERF_COUNTERS + +/* + * Set by architecture code: + */ +extern int perf_max_counters; + +extern const struct pmu *hw_perf_counter_init(struct perf_counter *counter); + +extern void perf_counter_task_sched_in(struct task_struct *task, int cpu); +extern void perf_counter_task_sched_out(struct task_struct *task, +					struct task_struct *next, int cpu); +extern void perf_counter_task_tick(struct task_struct *task, int cpu); +extern int perf_counter_init_task(struct task_struct *child); +extern void perf_counter_exit_task(struct task_struct *child); +extern void perf_counter_free_task(struct task_struct *task); +extern void perf_counter_do_pending(void); +extern void perf_counter_print_debug(void); +extern void __perf_disable(void); +extern bool __perf_enable(void); +extern void perf_disable(void); +extern void perf_enable(void); +extern int perf_counter_task_disable(void); +extern int perf_counter_task_enable(void); +extern int hw_perf_group_sched_in(struct perf_counter *group_leader, +	       struct perf_cpu_context *cpuctx, +	       struct perf_counter_context *ctx, int cpu); +extern void perf_counter_update_userpage(struct perf_counter *counter); + +struct perf_sample_data { +	struct pt_regs			*regs; +	u64				addr; +	u64				period; +}; + +extern int perf_counter_overflow(struct perf_counter *counter, int nmi, +				 struct perf_sample_data *data); + +/* + * Return 1 for a software counter, 0 for a hardware counter + */ +static inline int is_software_counter(struct perf_counter *counter) +{ +	return (counter->attr.type != PERF_TYPE_RAW) && +		(counter->attr.type != PERF_TYPE_HARDWARE) && +		(counter->attr.type != PERF_TYPE_HW_CACHE); +} + +extern void perf_swcounter_event(u32, u64, int, struct pt_regs *, u64); + +extern void __perf_counter_mmap(struct vm_area_struct *vma); + +static inline void perf_counter_mmap(struct vm_area_struct *vma) +{ +	if (vma->vm_flags & VM_EXEC) +		__perf_counter_mmap(vma); +} + +extern void perf_counter_comm(struct task_struct *tsk); +extern void perf_counter_fork(struct task_struct *tsk); + +extern void perf_counter_task_migration(struct task_struct *task, int cpu); + +#define MAX_STACK_DEPTH			255 + +struct perf_callchain_entry { +	u16				nr; +	u16				hv; +	u16				kernel; +	u16				user; +	u64				ip[MAX_STACK_DEPTH]; +}; + +extern struct perf_callchain_entry *perf_callchain(struct pt_regs *regs); + +extern int sysctl_perf_counter_paranoid; +extern int sysctl_perf_counter_mlock; +extern int sysctl_perf_counter_sample_rate; + +extern void perf_counter_init(void); + +#ifndef perf_misc_flags +#define perf_misc_flags(regs)	(user_mode(regs) ? PERF_EVENT_MISC_USER : \ +				 PERF_EVENT_MISC_KERNEL) +#define perf_instruction_pointer(regs)	instruction_pointer(regs) +#endif + +#else +static inline void +perf_counter_task_sched_in(struct task_struct *task, int cpu)		{ } +static inline void +perf_counter_task_sched_out(struct task_struct *task, +			    struct task_struct *next, int cpu)		{ } +static inline void +perf_counter_task_tick(struct task_struct *task, int cpu)		{ } +static inline int perf_counter_init_task(struct task_struct *child)	{ return 0; } +static inline void perf_counter_exit_task(struct task_struct *child)	{ } +static inline void perf_counter_free_task(struct task_struct *task)	{ } +static inline void perf_counter_do_pending(void)			{ } +static inline void perf_counter_print_debug(void)			{ } +static inline void perf_disable(void)					{ } +static inline void perf_enable(void)					{ } +static inline int perf_counter_task_disable(void)	{ return -EINVAL; } +static inline int perf_counter_task_enable(void)	{ return -EINVAL; } + +static inline void +perf_swcounter_event(u32 event, u64 nr, int nmi, +		     struct pt_regs *regs, u64 addr)			{ } + +static inline void perf_counter_mmap(struct vm_area_struct *vma)	{ } +static inline void perf_counter_comm(struct task_struct *tsk)		{ } +static inline void perf_counter_fork(struct task_struct *tsk)		{ } +static inline void perf_counter_init(void)				{ } +static inline void perf_counter_task_migration(struct task_struct *task, +					       int cpu)			{ } +#endif + +#endif /* __KERNEL__ */ +#endif /* _LINUX_PERF_COUNTER_H */ diff --git a/include/linux/phy.h b/include/linux/phy.h index 97e40cb6b58..b1368b8f657 100644 --- a/include/linux/phy.h +++ b/include/linux/phy.h @@ -79,7 +79,7 @@ typedef enum {   * Need to be a little smaller than phydev->dev.bus_id to leave room   * for the ":%02x"   */ -#define MII_BUS_ID_SIZE	(BUS_ID_SIZE - 3) +#define MII_BUS_ID_SIZE	(20 - 3)  /*   * The Bus class for PHYs.  Devices which provide access to @@ -407,7 +407,7 @@ struct phy_driver {  /* A Structure for boards to register fixups with the PHY Lib */  struct phy_fixup {  	struct list_head list; -	char bus_id[BUS_ID_SIZE]; +	char bus_id[20];  	u32 phy_uid;  	u32 phy_uid_mask;  	int (*run)(struct phy_device *phydev); @@ -444,10 +444,16 @@ static inline int phy_write(struct phy_device *phydev, u16 regnum, u16 val)  int get_phy_id(struct mii_bus *bus, int addr, u32 *phy_id);  struct phy_device* get_phy_device(struct mii_bus *bus, int addr); +int phy_device_register(struct phy_device *phy);  int phy_clear_interrupt(struct phy_device *phydev);  int phy_config_interrupt(struct phy_device *phydev, u32 interrupts); +int phy_attach_direct(struct net_device *dev, struct phy_device *phydev, +		u32 flags, phy_interface_t interface);  struct phy_device * phy_attach(struct net_device *dev,  		const char *bus_id, u32 flags, phy_interface_t interface); +int phy_connect_direct(struct net_device *dev, struct phy_device *phydev, +		void (*handler)(struct net_device *), u32 flags, +		phy_interface_t interface);  struct phy_device * phy_connect(struct net_device *dev, const char *bus_id,  		void (*handler)(struct net_device *), u32 flags,  		phy_interface_t interface); diff --git a/include/linux/pipe_fs_i.h b/include/linux/pipe_fs_i.h index c8f038554e8..b43a9e03905 100644 --- a/include/linux/pipe_fs_i.h +++ b/include/linux/pipe_fs_i.h @@ -152,5 +152,6 @@ void generic_pipe_buf_unmap(struct pipe_inode_info *, struct pipe_buffer *, void  void generic_pipe_buf_get(struct pipe_inode_info *, struct pipe_buffer *);  int generic_pipe_buf_confirm(struct pipe_inode_info *, struct pipe_buffer *);  int generic_pipe_buf_steal(struct pipe_inode_info *, struct pipe_buffer *); +void generic_pipe_buf_release(struct pipe_inode_info *, struct pipe_buffer *);  #endif diff --git a/include/linux/platform_device.h b/include/linux/platform_device.h index 72736fd8223..b67bb5d7b22 100644 --- a/include/linux/platform_device.h +++ b/include/linux/platform_device.h @@ -20,7 +20,6 @@ struct platform_device {  	struct device	dev;  	u32		num_resources;  	struct resource	* resource; -	void		*platform_data;  	struct platform_device_id	*id_entry;  }; diff --git a/include/linux/pm.h b/include/linux/pm.h index 1d4e2d28982..b3f74764a58 100644 --- a/include/linux/pm.h +++ b/include/linux/pm.h @@ -382,14 +382,13 @@ struct dev_pm_info {  #ifdef CONFIG_PM_SLEEP  extern void device_pm_lock(void);  extern int sysdev_resume(void); -extern void device_power_up(pm_message_t state); -extern void device_resume(pm_message_t state); +extern void dpm_resume_noirq(pm_message_t state); +extern void dpm_resume_end(pm_message_t state);  extern void device_pm_unlock(void);  extern int sysdev_suspend(pm_message_t state); -extern int device_power_down(pm_message_t state); -extern int device_suspend(pm_message_t state); -extern int device_prepare_suspend(pm_message_t state); +extern int dpm_suspend_noirq(pm_message_t state); +extern int dpm_suspend_start(pm_message_t state);  extern void __suspend_report_result(const char *function, void *fn, int ret); @@ -403,7 +402,7 @@ extern void __suspend_report_result(const char *function, void *fn, int ret);  #define device_pm_lock() do {} while (0)  #define device_pm_unlock() do {} while (0) -static inline int device_suspend(pm_message_t state) +static inline int dpm_suspend_start(pm_message_t state)  {  	return 0;  } diff --git a/include/linux/pnp.h b/include/linux/pnp.h index ca3c8877302..b063c7328ba 100644 --- a/include/linux/pnp.h +++ b/include/linux/pnp.h @@ -446,6 +446,7 @@ int pnp_start_dev(struct pnp_dev *dev);  int pnp_stop_dev(struct pnp_dev *dev);  int pnp_activate_dev(struct pnp_dev *dev);  int pnp_disable_dev(struct pnp_dev *dev); +int pnp_range_reserved(resource_size_t start, resource_size_t end);  /* protocol helpers */  int pnp_is_active(struct pnp_dev *dev); @@ -476,6 +477,7 @@ static inline int pnp_start_dev(struct pnp_dev *dev) { return -ENODEV; }  static inline int pnp_stop_dev(struct pnp_dev *dev) { return -ENODEV; }  static inline int pnp_activate_dev(struct pnp_dev *dev) { return -ENODEV; }  static inline int pnp_disable_dev(struct pnp_dev *dev) { return -ENODEV; } +static inline int pnp_range_reserved(resource_size_t start, resource_size_t end) { return 0;}  /* protocol helpers */  static inline int pnp_is_active(struct pnp_dev *dev) { return 0; } diff --git a/include/linux/prctl.h b/include/linux/prctl.h index 48d887e3c6e..b00df4c79c6 100644 --- a/include/linux/prctl.h +++ b/include/linux/prctl.h @@ -85,4 +85,7 @@  #define PR_SET_TIMERSLACK 29  #define PR_GET_TIMERSLACK 30 +#define PR_TASK_PERF_COUNTERS_DISABLE		31 +#define PR_TASK_PERF_COUNTERS_ENABLE		32 +  #endif /* _LINUX_PRCTL_H */ diff --git a/include/linux/proc_fs.h b/include/linux/proc_fs.h index fbfa3d44d33..e6e77d31c41 100644 --- a/include/linux/proc_fs.h +++ b/include/linux/proc_fs.h @@ -93,20 +93,9 @@ struct vmcore {  #ifdef CONFIG_PROC_FS -extern spinlock_t proc_subdir_lock; -  extern void proc_root_init(void);  void proc_flush_task(struct task_struct *task); -struct dentry *proc_pid_lookup(struct inode *dir, struct dentry * dentry, struct nameidata *); -int proc_pid_readdir(struct file * filp, void * dirent, filldir_t filldir); -unsigned long task_vsize(struct mm_struct *); -int task_statm(struct mm_struct *, int *, int *, int *, int *); -void task_mem(struct seq_file *, struct mm_struct *); -void clear_refs_smap(struct mm_struct *mm); - -struct proc_dir_entry *de_get(struct proc_dir_entry *de); -void de_put(struct proc_dir_entry *de);  extern struct proc_dir_entry *create_proc_entry(const char *name, mode_t mode,  						struct proc_dir_entry *parent); @@ -116,20 +105,7 @@ struct proc_dir_entry *proc_create_data(const char *name, mode_t mode,  				void *data);  extern void remove_proc_entry(const char *name, struct proc_dir_entry *parent); -extern struct vfsmount *proc_mnt;  struct pid_namespace; -extern int proc_fill_super(struct super_block *); -extern struct inode *proc_get_inode(struct super_block *, unsigned int, struct proc_dir_entry *); - -/* - * These are generic /proc routines that use the internal - * "struct proc_dir_entry" tree to traverse the filesystem. - * - * The /proc root directory has extended versions to take care - * of the /proc/<pid> subdirectories. - */ -extern int proc_readdir(struct file *, void *, filldir_t); -extern struct dentry *proc_lookup(struct inode *, struct dentry *, struct nameidata *);  extern int pid_ns_prepare_proc(struct pid_namespace *ns);  extern void pid_ns_release_proc(struct pid_namespace *ns); diff --git a/include/linux/ptrace.h b/include/linux/ptrace.h index 67c15653fc2..59e133d39d5 100644 --- a/include/linux/ptrace.h +++ b/include/linux/ptrace.h @@ -95,7 +95,6 @@ extern void __ptrace_link(struct task_struct *child,  			  struct task_struct *new_parent);  extern void __ptrace_unlink(struct task_struct *child);  extern void exit_ptrace(struct task_struct *tracer); -extern void ptrace_fork(struct task_struct *task, unsigned long clone_flags);  #define PTRACE_MODE_READ   1  #define PTRACE_MODE_ATTACH 2  /* Returns 0 on success, -errno on denial. */ @@ -327,15 +326,6 @@ static inline void user_enable_block_step(struct task_struct *task)  #define arch_ptrace_untrace(task)		do { } while (0)  #endif -#ifndef arch_ptrace_fork -/* - * Do machine-specific work to initialize a new task. - * - * This is called from copy_process(). - */ -#define arch_ptrace_fork(child, clone_flags)	do { } while (0) -#endif -  extern int task_current_syscall(struct task_struct *target, long *callno,  				unsigned long args[6], unsigned int maxargs,  				unsigned long *sp, unsigned long *pc); diff --git a/include/linux/qnx4_fs.h b/include/linux/qnx4_fs.h index 787d19ea9f4..8b9aee1a9ce 100644 --- a/include/linux/qnx4_fs.h +++ b/include/linux/qnx4_fs.h @@ -85,65 +85,4 @@ struct qnx4_super_block {  	struct qnx4_inode_entry AltBoot;  }; -#ifdef __KERNEL__ - -#define QNX4_DEBUG 0 - -#if QNX4_DEBUG -#define QNX4DEBUG(X) printk X -#else -#define QNX4DEBUG(X) (void) 0 -#endif - -struct qnx4_sb_info { -	struct buffer_head	*sb_buf;	/* superblock buffer */ -	struct qnx4_super_block	*sb;		/* our superblock */ -	unsigned int		Version;	/* may be useful */ -	struct qnx4_inode_entry	*BitMap;	/* useful */ -}; - -struct qnx4_inode_info { -	struct qnx4_inode_entry raw; -	loff_t mmu_private; -	struct inode vfs_inode; -}; - -extern struct inode *qnx4_iget(struct super_block *, unsigned long); -extern struct dentry *qnx4_lookup(struct inode *dir, struct dentry *dentry, struct nameidata *nd); -extern unsigned long qnx4_count_free_blocks(struct super_block *sb); -extern unsigned long qnx4_block_map(struct inode *inode, long iblock); - -extern struct buffer_head *qnx4_bread(struct inode *, int, int); - -extern const struct inode_operations qnx4_file_inode_operations; -extern const struct inode_operations qnx4_dir_inode_operations; -extern const struct file_operations qnx4_file_operations; -extern const struct file_operations qnx4_dir_operations; -extern int qnx4_is_free(struct super_block *sb, long block); -extern int qnx4_set_bitmap(struct super_block *sb, long block, int busy); -extern int qnx4_create(struct inode *inode, struct dentry *dentry, int mode, struct nameidata *nd); -extern void qnx4_truncate(struct inode *inode); -extern void qnx4_free_inode(struct inode *inode); -extern int qnx4_unlink(struct inode *dir, struct dentry *dentry); -extern int qnx4_rmdir(struct inode *dir, struct dentry *dentry); -extern int qnx4_sync_file(struct file *file, struct dentry *dentry, int); -extern int qnx4_sync_inode(struct inode *inode); - -static inline struct qnx4_sb_info *qnx4_sb(struct super_block *sb) -{ -	return sb->s_fs_info; -} - -static inline struct qnx4_inode_info *qnx4_i(struct inode *inode) -{ -	return container_of(inode, struct qnx4_inode_info, vfs_inode); -} - -static inline struct qnx4_inode_entry *qnx4_raw_inode(struct inode *inode) -{ -	return &qnx4_i(inode)->raw; -} - -#endif				/* __KERNEL__ */ -  #endif diff --git a/include/linux/quotaops.h b/include/linux/quotaops.h index 36353d95c8d..7bc45759368 100644 --- a/include/linux/quotaops.h +++ b/include/linux/quotaops.h @@ -20,7 +20,12 @@ static inline struct quota_info *sb_dqopt(struct super_block *sb)  /*   * declaration of quota_function calls in kernel.   */ -void sync_dquots(struct super_block *sb, int type); +void sync_quota_sb(struct super_block *sb, int type); +static inline void writeout_quota_sb(struct super_block *sb, int type) +{ +	if (sb->s_qcop->quota_sync) +		sb->s_qcop->quota_sync(sb, type); +}  int dquot_initialize(struct inode *inode, int type);  int dquot_drop(struct inode *inode); @@ -253,12 +258,7 @@ static inline void vfs_dq_free_inode(struct inode *inode)  		inode->i_sb->dq_op->free_inode(inode, 1);  } -/* The following two functions cannot be called inside a transaction */ -static inline void vfs_dq_sync(struct super_block *sb) -{ -	sync_dquots(sb, -1); -} - +/* Cannot be called inside a transaction */  static inline int vfs_dq_off(struct super_block *sb, int remount)  {  	int ret = -ENOSYS; @@ -334,7 +334,11 @@ static inline void vfs_dq_free_inode(struct inode *inode)  {  } -static inline void vfs_dq_sync(struct super_block *sb) +static inline void sync_quota_sb(struct super_block *sb, int type) +{ +} + +static inline void writeout_quota_sb(struct super_block *sb, int type)  {  } diff --git a/include/linux/rational.h b/include/linux/rational.h new file mode 100644 index 00000000000..4f532fcd9ee --- /dev/null +++ b/include/linux/rational.h @@ -0,0 +1,19 @@ +/* + * rational fractions + * + * Copyright (C) 2009 emlix GmbH, Oskar Schirmer <os@emlix.com> + * + * helper functions when coping with rational numbers, + * e.g. when calculating optimum numerator/denominator pairs for + * pll configuration taking into account restricted register size + */ + +#ifndef _LINUX_RATIONAL_H +#define _LINUX_RATIONAL_H + +void rational_best_approximation( +	unsigned long given_numerator, unsigned long given_denominator, +	unsigned long max_numerator, unsigned long max_denominator, +	unsigned long *best_numerator, unsigned long *best_denominator); + +#endif /* _LINUX_RATIONAL_H */ diff --git a/include/linux/rculist.h b/include/linux/rculist.h index e649bd3f2c9..5710f43bbc9 100644 --- a/include/linux/rculist.h +++ b/include/linux/rculist.h @@ -198,6 +198,32 @@ static inline void list_splice_init_rcu(struct list_head *list,  	at->prev = last;  } +/** + * list_entry_rcu - get the struct for this entry + * @ptr:        the &struct list_head pointer. + * @type:       the type of the struct this is embedded in. + * @member:     the name of the list_struct within the struct. + * + * This primitive may safely run concurrently with the _rcu list-mutation + * primitives such as list_add_rcu() as long as it's guarded by rcu_read_lock(). + */ +#define list_entry_rcu(ptr, type, member) \ +	container_of(rcu_dereference(ptr), type, member) + +/** + * list_first_entry_rcu - get the first element from a list + * @ptr:        the list head to take the element from. + * @type:       the type of the struct this is embedded in. + * @member:     the name of the list_struct within the struct. + * + * Note, that list is expected to be not empty. + * + * This primitive may safely run concurrently with the _rcu list-mutation + * primitives such as list_add_rcu() as long as it's guarded by rcu_read_lock(). + */ +#define list_first_entry_rcu(ptr, type, member) \ +	list_entry_rcu((ptr)->next, type, member) +  #define __list_for_each_rcu(pos, head) \  	for (pos = rcu_dereference((head)->next); \  		pos != (head); \ @@ -214,9 +240,9 @@ static inline void list_splice_init_rcu(struct list_head *list,   * as long as the traversal is guarded by rcu_read_lock().   */  #define list_for_each_entry_rcu(pos, head, member) \ -	for (pos = list_entry(rcu_dereference((head)->next), typeof(*pos), member); \ +	for (pos = list_entry_rcu((head)->next, typeof(*pos), member); \  		prefetch(pos->member.next), &pos->member != (head); \ -		pos = list_entry(rcu_dereference(pos->member.next), typeof(*pos), member)) +		pos = list_entry_rcu(pos->member.next, typeof(*pos), member))  /** diff --git a/include/linux/rcutree.h b/include/linux/rcutree.h index 58b2aa5312b..5a5153806c4 100644 --- a/include/linux/rcutree.h +++ b/include/linux/rcutree.h @@ -161,8 +161,15 @@ struct rcu_data {  	unsigned long offline_fqs;	/* Kicked due to being offline. */  	unsigned long resched_ipi;	/* Sent a resched IPI. */ -	/* 5) For future __rcu_pending statistics. */ +	/* 5) __rcu_pending() statistics. */  	long n_rcu_pending;		/* rcu_pending() calls since boot. */ +	long n_rp_qs_pending; +	long n_rp_cb_ready; +	long n_rp_cpu_needs_gp; +	long n_rp_gp_completed; +	long n_rp_gp_started; +	long n_rp_need_fqs; +	long n_rp_need_nothing;  	int cpu;  }; diff --git a/include/linux/regulator/lp3971.h b/include/linux/regulator/lp3971.h new file mode 100644 index 00000000000..61401649fe7 --- /dev/null +++ b/include/linux/regulator/lp3971.h @@ -0,0 +1,51 @@ +/* + * National Semiconductors LP3971 PMIC chip client interface + * + *  Copyright (C) 2009 Samsung Electronics + *  Author: Marek Szyprowski <m.szyprowski@samsung.com> + * + * Based on wm8400.h + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation; either version 2 of the License, or + * (at your option) any later version. + * + * 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. + * + * You should have received a copy of the GNU General Public License + * along with this program; if not, write to the Free Software + * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. + */ + +#ifndef __LINUX_REGULATOR_LP3971_H +#define __LINUX_REGULATOR_LP3971_H + +#include <linux/regulator/machine.h> + +#define LP3971_LDO1  0 +#define LP3971_LDO2  1 +#define LP3971_LDO3  2 +#define LP3971_LDO4  3 +#define LP3971_LDO5  4 + +#define LP3971_DCDC1 5 +#define LP3971_DCDC2 6 +#define LP3971_DCDC3 7 + +#define LP3971_NUM_REGULATORS 8 + +struct lp3971_regulator_subdev { +	int id; +	struct regulator_init_data *initdata; +}; + +struct lp3971_platform_data { +	int num_regulators; +	struct lp3971_regulator_subdev *regulators; +}; + +#endif diff --git a/include/linux/regulator/max1586.h b/include/linux/regulator/max1586.h new file mode 100644 index 00000000000..44563192bf1 --- /dev/null +++ b/include/linux/regulator/max1586.h @@ -0,0 +1,63 @@ +/* + * max1586.h  --  Voltage regulation for the Maxim 1586 + * + * Copyright (C) 2008 Robert Jarzmik + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation; either version 2 of the License, or + * (at your option) any later version. + * + * 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. + * + * You should have received a copy of the GNU General Public License + * along with this program; if not, write to the Free Software + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA + */ + +#ifndef REGULATOR_MAX1586 +#define REGULATOR_MAX1586 + +#include <linux/regulator/machine.h> + +#define MAX1586_V3 0 +#define MAX1586_V6 1 + +/* precalculated values for v3_gain */ +#define MAX1586_GAIN_NO_R24   1000000  /* 700000 .. 1475000 mV */ +#define MAX1586_GAIN_R24_3k32 1051098  /* 735768 .. 1550369 mV */ +#define MAX1586_GAIN_R24_5k11 1078648  /* 755053 .. 1591005 mV */ +#define MAX1586_GAIN_R24_7k5  1115432  /* 780802 .. 1645262 mV */ + +/** + * max1586_subdev_data - regulator data + * @id: regulator Id (either MAX1586_V3 or MAX1586_V6) + * @name: regulator cute name (example for V3: "vcc_core") + * @platform_data: regulator init data (contraints, supplies, ...) + */ +struct max1586_subdev_data { +	int				id; +	char				*name; +	struct regulator_init_data	*platform_data; +}; + +/** + * max1586_platform_data - platform data for max1586 + * @num_subdevs: number of regultors used (may be 1 or 2) + * @subdevs: regulator used + *           At most, there will be a regulator for V3 and one for V6 voltages. + * @v3_gain: gain on the V3 voltage output multiplied by 1e6. + *           This can be calculated as ((1 + R24/R25 + R24/185.5kOhm) * 1e6) + *           for an external resistor configuration as described in the + *           data sheet (R25=100kOhm). + */ +struct max1586_platform_data { +	int num_subdevs; +	struct max1586_subdev_data *subdevs; +	int v3_gain; +}; + +#endif diff --git a/include/linux/regulator/userspace-consumer.h b/include/linux/regulator/userspace-consumer.h new file mode 100644 index 00000000000..b4554ce9d4b --- /dev/null +++ b/include/linux/regulator/userspace-consumer.h @@ -0,0 +1,25 @@ +#ifndef __REGULATOR_PLATFORM_CONSUMER_H_ +#define __REGULATOR_PLATFORM_CONSUMER_H_ + +struct regulator_consumer_supply; + +/** + * struct regulator_userspace_consumer_data - line consumer + * initialisation data. + * + * @name: Name for the consumer line + * @num_supplies: Number of supplies feeding the line + * @supplies: Supplies configuration. + * @init_on: Set if the regulators supplying the line should be + *           enabled during initialisation + */ +struct regulator_userspace_consumer_data { +	const char *name; + +	int num_supplies; +	struct regulator_bulk_data *supplies; + +	bool init_on; +}; + +#endif /* __REGULATOR_PLATFORM_CONSUMER_H_ */ diff --git a/include/linux/reiserfs_fs_sb.h b/include/linux/reiserfs_fs_sb.h index 6b361d23a49..dab68bbed67 100644 --- a/include/linux/reiserfs_fs_sb.h +++ b/include/linux/reiserfs_fs_sb.h @@ -402,7 +402,7 @@ struct reiserfs_sb_info {  	int reserved_blocks;	/* amount of blocks reserved for further allocations */  	spinlock_t bitmap_lock;	/* this lock on now only used to protect reserved_blocks variable */  	struct dentry *priv_root;	/* root of /.reiserfs_priv */ -	struct dentry *xattr_root;	/* root of /.reiserfs_priv/.xa */ +	struct dentry *xattr_root;	/* root of /.reiserfs_priv/xattrs */  	int j_errno;  #ifdef CONFIG_QUOTA  	char *s_qf_names[MAXQUOTAS]; @@ -453,6 +453,7 @@ enum reiserfs_mount_options {  	REISERFS_ATTRS,  	REISERFS_XATTRS_USER,  	REISERFS_POSIXACL, +	REISERFS_EXPOSE_PRIVROOT,  	REISERFS_BARRIER_NONE,  	REISERFS_BARRIER_FLUSH, @@ -488,9 +489,9 @@ enum reiserfs_mount_options {  #define reiserfs_data_log(s) (REISERFS_SB(s)->s_mount_opt & (1 << REISERFS_DATA_LOG))  #define reiserfs_data_ordered(s) (REISERFS_SB(s)->s_mount_opt & (1 << REISERFS_DATA_ORDERED))  #define reiserfs_data_writeback(s) (REISERFS_SB(s)->s_mount_opt & (1 << REISERFS_DATA_WRITEBACK)) -#define reiserfs_xattrs(s) ((s)->s_xattr != NULL)  #define reiserfs_xattrs_user(s) (REISERFS_SB(s)->s_mount_opt & (1 << REISERFS_XATTRS_USER))  #define reiserfs_posixacl(s) (REISERFS_SB(s)->s_mount_opt & (1 << REISERFS_POSIXACL)) +#define reiserfs_expose_privroot(s) (REISERFS_SB(s)->s_mount_opt & (1 << REISERFS_EXPOSE_PRIVROOT))  #define reiserfs_xattrs_optional(s) (reiserfs_xattrs_user(s) || reiserfs_posixacl(s))  #define reiserfs_barrier_none(s) (REISERFS_SB(s)->s_mount_opt & (1 << REISERFS_BARRIER_NONE))  #define reiserfs_barrier_flush(s) (REISERFS_SB(s)->s_mount_opt & (1 << REISERFS_BARRIER_FLUSH)) diff --git a/include/linux/reiserfs_xattr.h b/include/linux/reiserfs_xattr.h index dcae01e63e4..99928dce37e 100644 --- a/include/linux/reiserfs_xattr.h +++ b/include/linux/reiserfs_xattr.h @@ -38,8 +38,10 @@ struct nameidata;  int reiserfs_xattr_register_handlers(void) __init;  void reiserfs_xattr_unregister_handlers(void);  int reiserfs_xattr_init(struct super_block *sb, int mount_flags); +int reiserfs_lookup_privroot(struct super_block *sb);  int reiserfs_delete_xattrs(struct inode *inode);  int reiserfs_chown_xattrs(struct inode *inode, struct iattr *attrs); +int reiserfs_permission(struct inode *inode, int mask);  #ifdef CONFIG_REISERFS_FS_XATTR  #define has_xattr_dir(inode) (REISERFS_I(inode)->i_flags & i_has_xattr_dir) @@ -49,7 +51,6 @@ int reiserfs_setxattr(struct dentry *dentry, const char *name,  		      const void *value, size_t size, int flags);  ssize_t reiserfs_listxattr(struct dentry *dentry, char *buffer, size_t size);  int reiserfs_removexattr(struct dentry *dentry, const char *name); -int reiserfs_permission(struct inode *inode, int mask);  int reiserfs_xattr_get(struct inode *, const char *, void *, size_t);  int reiserfs_xattr_set(struct inode *, const char *, const void *, size_t, int); @@ -97,7 +98,7 @@ static inline size_t reiserfs_xattr_jcreate_nblocks(struct inode *inode)  	if ((REISERFS_I(inode)->i_flags & i_has_xattr_dir) == 0) {  		nblocks += JOURNAL_BLOCKS_PER_OBJECT(inode->i_sb); -		if (REISERFS_SB(inode->i_sb)->xattr_root == NULL) +		if (!REISERFS_SB(inode->i_sb)->xattr_root->d_inode)  			nblocks += JOURNAL_BLOCKS_PER_OBJECT(inode->i_sb);  	} @@ -116,8 +117,6 @@ static inline void reiserfs_init_xattr_rwsem(struct inode *inode)  #define reiserfs_listxattr NULL  #define reiserfs_removexattr NULL -#define reiserfs_permission NULL -  static inline void reiserfs_init_xattr_rwsem(struct inode *inode)  {  } diff --git a/include/linux/rfkill.h b/include/linux/rfkill.h index 164332cbb77..16e39c7a67f 100644 --- a/include/linux/rfkill.h +++ b/include/linux/rfkill.h @@ -4,6 +4,7 @@  /*   * Copyright (C) 2006 - 2007 Ivo van Doorn   * Copyright (C) 2007 Dmitry Torokhov + * Copyright 2009 Johannes Berg <johannes@sipsolutions.net>   *   * This program is free software; you can redistribute it and/or modify   * it under the terms of the GNU General Public License as published by @@ -22,131 +23,331 @@   */  #include <linux/types.h> -#include <linux/kernel.h> -#include <linux/list.h> -#include <linux/mutex.h> -#include <linux/device.h> -#include <linux/leds.h> + +/* define userspace visible states */ +#define RFKILL_STATE_SOFT_BLOCKED	0 +#define RFKILL_STATE_UNBLOCKED		1 +#define RFKILL_STATE_HARD_BLOCKED	2  /**   * enum rfkill_type - type of rfkill switch. - * RFKILL_TYPE_WLAN: switch is on a 802.11 wireless network device. - * RFKILL_TYPE_BLUETOOTH: switch is on a bluetooth device. - * RFKILL_TYPE_UWB: switch is on a ultra wideband device. - * RFKILL_TYPE_WIMAX: switch is on a WiMAX device. - * RFKILL_TYPE_WWAN: switch is on a wireless WAN device. + * + * @RFKILL_TYPE_ALL: toggles all switches (userspace only) + * @RFKILL_TYPE_WLAN: switch is on a 802.11 wireless network device. + * @RFKILL_TYPE_BLUETOOTH: switch is on a bluetooth device. + * @RFKILL_TYPE_UWB: switch is on a ultra wideband device. + * @RFKILL_TYPE_WIMAX: switch is on a WiMAX device. + * @RFKILL_TYPE_WWAN: switch is on a wireless WAN device. + * @NUM_RFKILL_TYPES: number of defined rfkill types   */  enum rfkill_type { -	RFKILL_TYPE_WLAN , +	RFKILL_TYPE_ALL = 0, +	RFKILL_TYPE_WLAN,  	RFKILL_TYPE_BLUETOOTH,  	RFKILL_TYPE_UWB,  	RFKILL_TYPE_WIMAX,  	RFKILL_TYPE_WWAN, -	RFKILL_TYPE_MAX, +	NUM_RFKILL_TYPES,  }; -enum rfkill_state { -	RFKILL_STATE_SOFT_BLOCKED = 0,	/* Radio output blocked */ -	RFKILL_STATE_UNBLOCKED    = 1,	/* Radio output allowed */ -	RFKILL_STATE_HARD_BLOCKED = 2,	/* Output blocked, non-overrideable */ -	RFKILL_STATE_MAX,		/* marker for last valid state */ +/** + * enum rfkill_operation - operation types + * @RFKILL_OP_ADD: a device was added + * @RFKILL_OP_DEL: a device was removed + * @RFKILL_OP_CHANGE: a device's state changed -- userspace changes one device + * @RFKILL_OP_CHANGE_ALL: userspace changes all devices (of a type, or all) + */ +enum rfkill_operation { +	RFKILL_OP_ADD = 0, +	RFKILL_OP_DEL, +	RFKILL_OP_CHANGE, +	RFKILL_OP_CHANGE_ALL,  }; -/* - * These are DEPRECATED, drivers using them should be verified to - * comply with the rfkill usage guidelines in Documentation/rfkill.txt - * and then converted to use the new names for rfkill_state - */ -#define RFKILL_STATE_OFF RFKILL_STATE_SOFT_BLOCKED -#define RFKILL_STATE_ON  RFKILL_STATE_UNBLOCKED - -/** - * struct rfkill - rfkill control structure. - * @name: Name of the switch. - * @type: Radio type which the button controls, the value stored - *	here should be a value from enum rfkill_type. - * @state: State of the switch, "UNBLOCKED" means radio can operate. - * @user_claim_unsupported: Whether the hardware supports exclusive - *	RF-kill control by userspace. Set this before registering. - * @user_claim: Set when the switch is controlled exlusively by userspace. - * @mutex: Guards switch state transitions.  It serializes callbacks - *	and also protects the state. - * @data: Pointer to the RF button drivers private data which will be - *	passed along when toggling radio state. - * @toggle_radio(): Mandatory handler to control state of the radio. - *	only RFKILL_STATE_SOFT_BLOCKED and RFKILL_STATE_UNBLOCKED are - *	valid parameters. - * @get_state(): handler to read current radio state from hardware, - *      may be called from atomic context, should return 0 on success. - *      Either this handler OR judicious use of rfkill_force_state() is - *      MANDATORY for any driver capable of RFKILL_STATE_HARD_BLOCKED. - * @led_trigger: A LED trigger for this button's LED. - * @dev: Device structure integrating the switch into device tree. - * @node: Used to place switch into list of all switches known to the - *	the system. - * - * This structure represents a RF switch located on a network device. - */ -struct rfkill { -	const char *name; -	enum rfkill_type type; - -	bool user_claim_unsupported; -	bool user_claim; - -	/* the mutex serializes callbacks and also protects -	 * the state */ -	struct mutex mutex; -	enum rfkill_state state; -	void *data; -	int (*toggle_radio)(void *data, enum rfkill_state state); -	int (*get_state)(void *data, enum rfkill_state *state); +/** + * struct rfkill_event - events for userspace on /dev/rfkill + * @idx: index of dev rfkill + * @type: type of the rfkill struct + * @op: operation code + * @hard: hard state (0/1) + * @soft: soft state (0/1) + * + * Structure used for userspace communication on /dev/rfkill, + * used for events from the kernel and control to the kernel. + */ +struct rfkill_event { +	__u32 idx; +	__u8  type; +	__u8  op; +	__u8  soft, hard; +} __packed; -#ifdef CONFIG_RFKILL_LEDS -	struct led_trigger led_trigger; -#endif +/* ioctl for turning off rfkill-input (if present) */ +#define RFKILL_IOC_MAGIC	'R' +#define RFKILL_IOC_NOINPUT	1 +#define RFKILL_IOCTL_NOINPUT	_IO(RFKILL_IOC_MAGIC, RFKILL_IOC_NOINPUT) + +/* and that's all userspace gets */ +#ifdef __KERNEL__ +/* don't allow anyone to use these in the kernel */ +enum rfkill_user_states { +	RFKILL_USER_STATE_SOFT_BLOCKED	= RFKILL_STATE_SOFT_BLOCKED, +	RFKILL_USER_STATE_UNBLOCKED	= RFKILL_STATE_UNBLOCKED, +	RFKILL_USER_STATE_HARD_BLOCKED	= RFKILL_STATE_HARD_BLOCKED, +}; +#undef RFKILL_STATE_SOFT_BLOCKED +#undef RFKILL_STATE_UNBLOCKED +#undef RFKILL_STATE_HARD_BLOCKED + +#include <linux/types.h> +#include <linux/kernel.h> +#include <linux/list.h> +#include <linux/mutex.h> +#include <linux/device.h> +#include <linux/leds.h> +#include <linux/err.h> + +/* this is opaque */ +struct rfkill; -	struct device dev; -	struct list_head node; -	enum rfkill_state state_for_resume; +/** + * struct rfkill_ops - rfkill driver methods + * + * @poll: poll the rfkill block state(s) -- only assign this method + *	when you need polling. When called, simply call one of the + *	rfkill_set{,_hw,_sw}_state family of functions. If the hw + *	is getting unblocked you need to take into account the return + *	value of those functions to make sure the software block is + *	properly used. + * @query: query the rfkill block state(s) and call exactly one of the + *	rfkill_set{,_hw,_sw}_state family of functions. Assign this + *	method if input events can cause hardware state changes to make + *	the rfkill core query your driver before setting a requested + *	block. + * @set_block: turn the transmitter on (blocked == false) or off + *	(blocked == true) -- ignore and return 0 when hard blocked. + *	This callback must be assigned. + */ +struct rfkill_ops { +	void	(*poll)(struct rfkill *rfkill, void *data); +	void	(*query)(struct rfkill *rfkill, void *data); +	int	(*set_block)(void *data, bool blocked);  }; -#define to_rfkill(d)	container_of(d, struct rfkill, dev) -struct rfkill * __must_check rfkill_allocate(struct device *parent, -					     enum rfkill_type type); -void rfkill_free(struct rfkill *rfkill); +#if defined(CONFIG_RFKILL) || defined(CONFIG_RFKILL_MODULE) +/** + * rfkill_alloc - allocate rfkill structure + * @name: name of the struct -- the string is not copied internally + * @parent: device that has rf switch on it + * @type: type of the switch (RFKILL_TYPE_*) + * @ops: rfkill methods + * @ops_data: data passed to each method + * + * This function should be called by the transmitter driver to allocate an + * rfkill structure. Returns %NULL on failure. + */ +struct rfkill * __must_check rfkill_alloc(const char *name, +					  struct device *parent, +					  const enum rfkill_type type, +					  const struct rfkill_ops *ops, +					  void *ops_data); + +/** + * rfkill_register - Register a rfkill structure. + * @rfkill: rfkill structure to be registered + * + * This function should be called by the transmitter driver to register + * the rfkill structure. Before calling this function the driver needs + * to be ready to service method calls from rfkill. + * + * If the software blocked state is not set before registration, + * set_block will be called to initialize it to a default value. + * + * If the hardware blocked state is not set before registration, + * it is assumed to be unblocked. + */  int __must_check rfkill_register(struct rfkill *rfkill); + +/** + * rfkill_pause_polling(struct rfkill *rfkill) + * + * Pause polling -- say transmitter is off for other reasons. + * NOTE: not necessary for suspend/resume -- in that case the + * core stops polling anyway + */ +void rfkill_pause_polling(struct rfkill *rfkill); + +/** + * rfkill_resume_polling(struct rfkill *rfkill) + * + * Pause polling -- say transmitter is off for other reasons. + * NOTE: not necessary for suspend/resume -- in that case the + * core stops polling anyway + */ +void rfkill_resume_polling(struct rfkill *rfkill); + + +/** + * rfkill_unregister - Unregister a rfkill structure. + * @rfkill: rfkill structure to be unregistered + * + * This function should be called by the network driver during device + * teardown to destroy rfkill structure. Until it returns, the driver + * needs to be able to service method calls. + */  void rfkill_unregister(struct rfkill *rfkill); -int rfkill_force_state(struct rfkill *rfkill, enum rfkill_state state); -int rfkill_set_default(enum rfkill_type type, enum rfkill_state state); +/** + * rfkill_destroy - free rfkill structure + * @rfkill: rfkill structure to be destroyed + * + * Destroys the rfkill structure. + */ +void rfkill_destroy(struct rfkill *rfkill); + +/** + * rfkill_set_hw_state - Set the internal rfkill hardware block state + * @rfkill: pointer to the rfkill class to modify. + * @state: the current hardware block state to set + * + * rfkill drivers that get events when the hard-blocked state changes + * use this function to notify the rfkill core (and through that also + * userspace) of the current state.  They should also use this after + * resume if the state could have changed. + * + * You need not (but may) call this function if poll_state is assigned. + * + * This function can be called in any context, even from within rfkill + * callbacks. + * + * The function returns the combined block state (true if transmitter + * should be blocked) so that drivers need not keep track of the soft + * block state -- which they might not be able to. + */ +bool __must_check rfkill_set_hw_state(struct rfkill *rfkill, bool blocked); + +/** + * rfkill_set_sw_state - Set the internal rfkill software block state + * @rfkill: pointer to the rfkill class to modify. + * @state: the current software block state to set + * + * rfkill drivers that get events when the soft-blocked state changes + * (yes, some platforms directly act on input but allow changing again) + * use this function to notify the rfkill core (and through that also + * userspace) of the current state.  It is not necessary to notify on + * resume; since hibernation can always change the soft-blocked state, + * the rfkill core will unconditionally restore the previous state. + * + * This function can be called in any context, even from within rfkill + * callbacks. + * + * The function returns the combined block state (true if transmitter + * should be blocked). + */ +bool rfkill_set_sw_state(struct rfkill *rfkill, bool blocked); + +/** + * rfkill_set_states - Set the internal rfkill block states + * @rfkill: pointer to the rfkill class to modify. + * @sw: the current software block state to set + * @hw: the current hardware block state to set + * + * This function can be called in any context, even from within rfkill + * callbacks. + */ +void rfkill_set_states(struct rfkill *rfkill, bool sw, bool hw);  /** - * rfkill_state_complement - return complementar state - * @state: state to return the complement of + * rfkill_blocked - query rfkill block   * - * Returns RFKILL_STATE_SOFT_BLOCKED if @state is RFKILL_STATE_UNBLOCKED, - * returns RFKILL_STATE_UNBLOCKED otherwise. + * @rfkill: rfkill struct to query   */ -static inline enum rfkill_state rfkill_state_complement(enum rfkill_state state) +bool rfkill_blocked(struct rfkill *rfkill); +#else /* !RFKILL */ +static inline struct rfkill * __must_check +rfkill_alloc(const char *name, +	     struct device *parent, +	     const enum rfkill_type type, +	     const struct rfkill_ops *ops, +	     void *ops_data) +{ +	return ERR_PTR(-ENODEV); +} + +static inline int __must_check rfkill_register(struct rfkill *rfkill) +{ +	if (rfkill == ERR_PTR(-ENODEV)) +		return 0; +	return -EINVAL; +} + +static inline void rfkill_pause_polling(struct rfkill *rfkill) +{ +} + +static inline void rfkill_resume_polling(struct rfkill *rfkill) +{ +} + +static inline void rfkill_unregister(struct rfkill *rfkill) +{ +} + +static inline void rfkill_destroy(struct rfkill *rfkill) +{ +} + +static inline bool rfkill_set_hw_state(struct rfkill *rfkill, bool blocked) +{ +	return blocked; +} + +static inline bool rfkill_set_sw_state(struct rfkill *rfkill, bool blocked)  { -	return (state == RFKILL_STATE_UNBLOCKED) ? -		RFKILL_STATE_SOFT_BLOCKED : RFKILL_STATE_UNBLOCKED; +	return blocked;  } +static inline void rfkill_set_states(struct rfkill *rfkill, bool sw, bool hw) +{ +} + +static inline bool rfkill_blocked(struct rfkill *rfkill) +{ +	return false; +} +#endif /* RFKILL || RFKILL_MODULE */ + + +#ifdef CONFIG_RFKILL_LEDS  /** - * rfkill_get_led_name - Get the LED trigger name for the button's LED. + * rfkill_get_led_trigger_name - Get the LED trigger name for the button's LED.   * This function might return a NULL pointer if registering of the - * LED trigger failed. - * Use this as "default_trigger" for the LED. + * LED trigger failed. Use this as "default_trigger" for the LED.   */ -static inline char *rfkill_get_led_name(struct rfkill *rfkill) -{ -#ifdef CONFIG_RFKILL_LEDS -	return (char *)(rfkill->led_trigger.name); +const char *rfkill_get_led_trigger_name(struct rfkill *rfkill); + +/** + * rfkill_set_led_trigger_name -- set the LED trigger name + * @rfkill: rfkill struct + * @name: LED trigger name + * + * This function sets the LED trigger name of the radio LED + * trigger that rfkill creates. It is optional, but if called + * must be called before rfkill_register() to be effective. + */ +void rfkill_set_led_trigger_name(struct rfkill *rfkill, const char *name);  #else +static inline const char *rfkill_get_led_trigger_name(struct rfkill *rfkill) +{  	return NULL; -#endif  } +static inline void +rfkill_set_led_trigger_name(struct rfkill *rfkill, const char *name) +{ +} +#endif + +#endif /* __KERNEL__ */ +  #endif /* RFKILL_H */ diff --git a/include/linux/ring_buffer.h b/include/linux/ring_buffer.h index e1b7b217388..8670f1575fe 100644 --- a/include/linux/ring_buffer.h +++ b/include/linux/ring_buffer.h @@ -11,7 +11,7 @@ struct ring_buffer_iter;   * Don't refer to this struct directly, use functions below.   */  struct ring_buffer_event { -	u32		type:2, len:3, time_delta:27; +	u32		type_len:5, time_delta:27;  	u32		array[];  }; @@ -24,7 +24,8 @@ struct ring_buffer_event {   *				  size is variable depending on how much   *				  padding is needed   *				 If time_delta is non zero: - *				  everything else same as RINGBUF_TYPE_DATA + *				  array[0] holds the actual length + *				  size = 4 + length (bytes)   *   * @RINGBUF_TYPE_TIME_EXTEND:	Extend the time delta   *				 array[0] = time delta (28 .. 59) @@ -35,22 +36,23 @@ struct ring_buffer_event {   *				 array[1..2] = tv_sec   *				 size = 16 bytes   * - * @RINGBUF_TYPE_DATA:		Data record - *				 If len is zero: + * <= @RINGBUF_TYPE_DATA_TYPE_LEN_MAX: + *				Data record + *				 If type_len is zero:   *				  array[0] holds the actual length   *				  array[1..(length+3)/4] holds data - *				  size = 4 + 4 + length (bytes) + *				  size = 4 + length (bytes)   *				 else - *				  length = len << 2 + *				  length = type_len << 2   *				  array[0..(length+3)/4-1] holds data   *				  size = 4 + length (bytes)   */  enum ring_buffer_type { +	RINGBUF_TYPE_DATA_TYPE_LEN_MAX = 28,  	RINGBUF_TYPE_PADDING,  	RINGBUF_TYPE_TIME_EXTEND,  	/* FIXME: RINGBUF_TYPE_TIME_STAMP not implemented */  	RINGBUF_TYPE_TIME_STAMP, -	RINGBUF_TYPE_DATA,  };  unsigned ring_buffer_event_length(struct ring_buffer_event *event); @@ -68,13 +70,54 @@ ring_buffer_event_time_delta(struct ring_buffer_event *event)  	return event->time_delta;  } +/* + * ring_buffer_event_discard can discard any event in the ring buffer. + *   it is up to the caller to protect against a reader from + *   consuming it or a writer from wrapping and replacing it. + * + * No external protection is needed if this is called before + * the event is commited. But in that case it would be better to + * use ring_buffer_discard_commit. + * + * Note, if an event that has not been committed is discarded + * with ring_buffer_event_discard, it must still be committed. + */  void ring_buffer_event_discard(struct ring_buffer_event *event);  /* + * ring_buffer_discard_commit will remove an event that has not + *   ben committed yet. If this is used, then ring_buffer_unlock_commit + *   must not be called on the discarded event. This function + *   will try to remove the event from the ring buffer completely + *   if another event has not been written after it. + * + * Example use: + * + *  if (some_condition) + *    ring_buffer_discard_commit(buffer, event); + *  else + *    ring_buffer_unlock_commit(buffer, event); + */ +void ring_buffer_discard_commit(struct ring_buffer *buffer, +				struct ring_buffer_event *event); + +/*   * size is in bytes for each per CPU buffer.   */  struct ring_buffer * -ring_buffer_alloc(unsigned long size, unsigned flags); +__ring_buffer_alloc(unsigned long size, unsigned flags, struct lock_class_key *key); + +/* + * Because the ring buffer is generic, if other users of the ring buffer get + * traced by ftrace, it can produce lockdep warnings. We need to keep each + * ring buffer's lock class separate. + */ +#define ring_buffer_alloc(size, flags)			\ +({							\ +	static struct lock_class_key __key;		\ +	__ring_buffer_alloc((size), (flags), &__key);	\ +}) +  void ring_buffer_free(struct ring_buffer *buffer);  int ring_buffer_resize(struct ring_buffer *buffer, unsigned long size); @@ -122,6 +165,8 @@ unsigned long ring_buffer_entries(struct ring_buffer *buffer);  unsigned long ring_buffer_overruns(struct ring_buffer *buffer);  unsigned long ring_buffer_entries_cpu(struct ring_buffer *buffer, int cpu);  unsigned long ring_buffer_overrun_cpu(struct ring_buffer *buffer, int cpu); +unsigned long ring_buffer_commit_overrun_cpu(struct ring_buffer *buffer, int cpu); +unsigned long ring_buffer_nmi_dropped_cpu(struct ring_buffer *buffer, int cpu);  u64 ring_buffer_time_stamp(struct ring_buffer *buffer, int cpu);  void ring_buffer_normalize_time_stamp(struct ring_buffer *buffer, @@ -137,6 +182,11 @@ void ring_buffer_free_read_page(struct ring_buffer *buffer, void *data);  int ring_buffer_read_page(struct ring_buffer *buffer, void **data_page,  			  size_t len, int cpu, int full); +struct trace_seq; + +int ring_buffer_print_entry_header(struct trace_seq *s); +int ring_buffer_print_page_header(struct trace_seq *s); +  enum ring_buffer_flags {  	RB_FL_OVERWRITE		= 1 << 0,  }; diff --git a/include/linux/romfs_fs.h b/include/linux/romfs_fs.h index e20bbf9eb36..c490fbc43fe 100644 --- a/include/linux/romfs_fs.h +++ b/include/linux/romfs_fs.h @@ -53,9 +53,4 @@ struct romfs_inode {  #define ROMFH_PAD (ROMFH_SIZE-1)  #define ROMFH_MASK (~ROMFH_PAD) -#ifdef __KERNEL__ - -/* Not much now */ - -#endif /* __KERNEL__ */  #endif diff --git a/include/linux/sched.h b/include/linux/sched.h index b4c38bc8049..c900aa53007 100644 --- a/include/linux/sched.h +++ b/include/linux/sched.h @@ -77,6 +77,7 @@ struct sched_param {  #include <linux/proportions.h>  #include <linux/seccomp.h>  #include <linux/rcupdate.h> +#include <linux/rculist.h>  #include <linux/rtmutex.h>  #include <linux/time.h> @@ -96,8 +97,9 @@ struct exec_domain;  struct futex_pi_state;  struct robust_list_head;  struct bio; -struct bts_tracer;  struct fs_struct; +struct bts_context; +struct perf_counter_context;  /*   * List of flags we want to share for kernel threads, @@ -116,6 +118,7 @@ struct fs_struct;   *    11 bit fractions.   */  extern unsigned long avenrun[];		/* Load averages */ +extern void get_avenrun(unsigned long *loads, unsigned long offset, int shift);  #define FSHIFT		11		/* nr of bits of precision */  #define FIXED_1		(1<<FSHIFT)	/* 1.0 as fixed-point */ @@ -135,8 +138,9 @@ DECLARE_PER_CPU(unsigned long, process_counts);  extern int nr_processes(void);  extern unsigned long nr_running(void);  extern unsigned long nr_uninterruptible(void); -extern unsigned long nr_active(void);  extern unsigned long nr_iowait(void); +extern void calc_global_load(void); +extern u64 cpu_nr_migrations(int cpu);  extern unsigned long get_parent_ip(unsigned long addr); @@ -257,6 +261,7 @@ extern void task_rq_unlock_wait(struct task_struct *p);  extern cpumask_var_t nohz_cpu_mask;  #if defined(CONFIG_SMP) && defined(CONFIG_NO_HZ)  extern int select_nohz_load_balancer(int cpu); +extern int get_nohz_load_balancer(void);  #else  static inline int select_nohz_load_balancer(int cpu)  { @@ -672,6 +677,10 @@ struct user_struct {  	struct work_struct work;  #endif  #endif + +#ifdef CONFIG_PERF_COUNTERS +	atomic_long_t locked_vm; +#endif  };  extern int uids_sysfs_init(void); @@ -838,7 +847,17 @@ struct sched_group {  	 */  	u32 reciprocal_cpu_power; -	unsigned long cpumask[]; +	/* +	 * The CPUs this group covers. +	 * +	 * NOTE: this field is variable length. (Allocated dynamically +	 * by attaching extra space to the end of the structure, +	 * depending on how many CPUs the kernel has booted up with) +	 * +	 * It is also be embedded into static data structures at build +	 * time. (See 'struct static_sched_group' in kernel/sched.c) +	 */ +	unsigned long cpumask[0];  };  static inline struct cpumask *sched_group_cpus(struct sched_group *sg) @@ -924,8 +943,17 @@ struct sched_domain {  	char *name;  #endif -	/* span of all CPUs in this domain */ -	unsigned long span[]; +	/* +	 * Span of all CPUs in this domain. +	 * +	 * NOTE: this field is variable length. (Allocated dynamically +	 * by attaching extra space to the end of the structure, +	 * depending on how many CPUs the kernel has booted up with) +	 * +	 * It is also be embedded into static data structures at build +	 * time. (See 'struct static_sched_domain' in kernel/sched.c) +	 */ +	unsigned long span[0];  };  static inline struct cpumask *sched_domain_span(struct sched_domain *sd) @@ -1052,9 +1080,10 @@ struct sched_entity {  	u64			last_wakeup;  	u64			avg_overlap; +	u64			nr_migrations; +  	u64			start_runtime;  	u64			avg_wakeup; -	u64			nr_migrations;  #ifdef CONFIG_SCHEDSTATS  	u64			wait_start; @@ -1209,18 +1238,11 @@ struct task_struct {  	struct list_head ptraced;  	struct list_head ptrace_entry; -#ifdef CONFIG_X86_PTRACE_BTS  	/*  	 * This is the tracer handle for the ptrace BTS extension.  	 * This field actually belongs to the ptracer task.  	 */ -	struct bts_tracer *bts; -	/* -	 * The buffer to hold the BTS data. -	 */ -	void *bts_buffer; -	size_t bts_size; -#endif /* CONFIG_X86_PTRACE_BTS */ +	struct bts_context *bts;  	/* PID/PID hash table linkage. */  	struct pid_link pids[PIDTYPE_MAX]; @@ -1247,7 +1269,9 @@ struct task_struct {  					 * credentials (COW) */  	const struct cred *cred;	/* effective (overridable) subjective task  					 * credentials (COW) */ -	struct mutex cred_exec_mutex;	/* execve vs ptrace cred calculation mutex */ +	struct mutex cred_guard_mutex;	/* guard against foreign influences on +					 * credential calculations +					 * (notably. ptrace) */  	char comm[TASK_COMM_LEN]; /* executable name excluding path  				     - access with [gs]et_task_comm (which lock @@ -1380,6 +1404,11 @@ struct task_struct {  	struct list_head pi_state_list;  	struct futex_pi_state *pi_state_cache;  #endif +#ifdef CONFIG_PERF_COUNTERS +	struct perf_counter_context *perf_counter_ctxp; +	struct mutex perf_counter_mutex; +	struct list_head perf_counter_list; +#endif  #ifdef CONFIG_NUMA  	struct mempolicy *mempolicy;  	short il_next; @@ -1428,7 +1457,9 @@ struct task_struct {  #ifdef CONFIG_TRACING  	/* state flags for use by tracers */  	unsigned long trace; -#endif +	/* bitmask of trace recursion */ +	unsigned long trace_recursion; +#endif /* CONFIG_TRACING */  };  /* Future-safe accessor for struct task_struct's cpus_allowed. */ @@ -1766,11 +1797,23 @@ extern unsigned int sysctl_sched_child_runs_first;  extern unsigned int sysctl_sched_features;  extern unsigned int sysctl_sched_migration_cost;  extern unsigned int sysctl_sched_nr_migrate; +extern unsigned int sysctl_timer_migration;  int sched_nr_latency_handler(struct ctl_table *table, int write,  		struct file *file, void __user *buffer, size_t *length,  		loff_t *ppos);  #endif +#ifdef CONFIG_SCHED_DEBUG +static inline unsigned int get_sysctl_timer_migration(void) +{ +	return sysctl_timer_migration; +} +#else +static inline unsigned int get_sysctl_timer_migration(void) +{ +	return 1; +} +#endif  extern unsigned int sysctl_sched_rt_period;  extern int sysctl_sched_rt_runtime; @@ -1885,6 +1928,7 @@ extern void sched_dead(struct task_struct *p);  extern void proc_caches_init(void);  extern void flush_signals(struct task_struct *); +extern void __flush_signals(struct task_struct *);  extern void ignore_signals(struct task_struct *);  extern void flush_signal_handlers(struct task_struct *, int force_default);  extern int dequeue_signal(struct task_struct *tsk, sigset_t *mask, siginfo_t *info); @@ -2001,8 +2045,10 @@ extern void set_task_comm(struct task_struct *tsk, char *from);  extern char *get_task_comm(char *to, struct task_struct *tsk);  #ifdef CONFIG_SMP +extern void wait_task_context_switch(struct task_struct *p);  extern unsigned long wait_task_inactive(struct task_struct *, long match_state);  #else +static inline void wait_task_context_switch(struct task_struct *p) {}  static inline unsigned long wait_task_inactive(struct task_struct *p,  					       long match_state)  { @@ -2010,7 +2056,8 @@ static inline unsigned long wait_task_inactive(struct task_struct *p,  }  #endif -#define next_task(p)	list_entry(rcu_dereference((p)->tasks.next), struct task_struct, tasks) +#define next_task(p) \ +	list_entry_rcu((p)->tasks.next, struct task_struct, tasks)  #define for_each_process(p) \  	for (p = &init_task ; (p = next_task(p)) != &init_task ; ) @@ -2049,8 +2096,8 @@ int same_thread_group(struct task_struct *p1, struct task_struct *p2)  static inline struct task_struct *next_thread(const struct task_struct *p)  { -	return list_entry(rcu_dereference(p->thread_group.next), -			  struct task_struct, thread_group); +	return list_entry_rcu(p->thread_group.next, +			      struct task_struct, thread_group);  }  static inline int thread_group_empty(struct task_struct *p) @@ -2178,6 +2225,12 @@ static inline int test_tsk_need_resched(struct task_struct *tsk)  	return unlikely(test_tsk_thread_flag(tsk,TIF_NEED_RESCHED));  } +static inline int restart_syscall(void) +{ +	set_tsk_thread_flag(current, TIF_SIGPENDING); +	return -ERESTARTNOINTR; +} +  static inline int signal_pending(struct task_struct *p)  {  	return unlikely(test_tsk_thread_flag(p,TIF_SIGPENDING)); @@ -2388,6 +2441,13 @@ static inline void inc_syscw(struct task_struct *tsk)  #define TASK_SIZE_OF(tsk)	TASK_SIZE  #endif +/* + * Call the function if the target task is executing on a CPU right now: + */ +extern void task_oncpu_function_call(struct task_struct *p, +				     void (*func) (void *info), void *info); + +  #ifdef CONFIG_MM_OWNER  extern void mm_update_next_owner(struct mm_struct *mm);  extern void mm_init_owner(struct mm_struct *mm, struct task_struct *p); diff --git a/include/linux/sctp.h b/include/linux/sctp.h index c2731bfe04d..b464b9d3d24 100644 --- a/include/linux/sctp.h +++ b/include/linux/sctp.h @@ -487,17 +487,17 @@ typedef enum {  	 *  	 * Value          Cause Code  	 * ---------      ---------------- -	 * 0x0100          Request to Delete Last Remaining IP Address. -	 * 0x0101          Operation Refused Due to Resource Shortage. -	 * 0x0102          Request to Delete Source IP Address. -	 * 0x0103          Association Aborted due to illegal ASCONF-ACK -	 * 0x0104          Request refused - no authorization. +	 * 0x00A0          Request to Delete Last Remaining IP Address. +	 * 0x00A1          Operation Refused Due to Resource Shortage. +	 * 0x00A2          Request to Delete Source IP Address. +	 * 0x00A3          Association Aborted due to illegal ASCONF-ACK +	 * 0x00A4          Request refused - no authorization.  	 */ -	SCTP_ERROR_DEL_LAST_IP	= cpu_to_be16(0x0100), -	SCTP_ERROR_RSRC_LOW	= cpu_to_be16(0x0101), -	SCTP_ERROR_DEL_SRC_IP	= cpu_to_be16(0x0102), -	SCTP_ERROR_ASCONF_ACK   = cpu_to_be16(0x0103), -	SCTP_ERROR_REQ_REFUSED	= cpu_to_be16(0x0104), +	SCTP_ERROR_DEL_LAST_IP	= cpu_to_be16(0x00A0), +	SCTP_ERROR_RSRC_LOW	= cpu_to_be16(0x00A1), +	SCTP_ERROR_DEL_SRC_IP	= cpu_to_be16(0x00A2), +	SCTP_ERROR_ASCONF_ACK   = cpu_to_be16(0x00A3), +	SCTP_ERROR_REQ_REFUSED	= cpu_to_be16(0x00A4),  	/* AUTH Section 4.  New Error Cause  	 * diff --git a/include/linux/section-names.h b/include/linux/section-names.h deleted file mode 100644 index c956f4eb2ad..00000000000 --- a/include/linux/section-names.h +++ /dev/null @@ -1,6 +0,0 @@ -#ifndef __LINUX_SECTION_NAMES_H -#define __LINUX_SECTION_NAMES_H - -#define HEAD_TEXT_SECTION .head.text - -#endif /* !__LINUX_SECTION_NAMES_H */ diff --git a/include/linux/security.h b/include/linux/security.h index d5fd6163606..5eff459b383 100644 --- a/include/linux/security.h +++ b/include/linux/security.h @@ -2197,6 +2197,8 @@ static inline int security_file_mmap(struct file *file, unsigned long reqprot,  				     unsigned long addr,  				     unsigned long addr_only)  { +	if ((addr < mmap_min_addr) && !capable(CAP_SYS_RAWIO)) +		return -EACCES;  	return 0;  } diff --git a/include/linux/serial.h b/include/linux/serial.h index 9136cc5608c..e5bb75a6380 100644 --- a/include/linux/serial.h +++ b/include/linux/serial.h @@ -96,54 +96,76 @@ struct serial_uart_config {  /*   * Definitions for async_struct (and serial_struct) flags field + * + * Define ASYNCB_* for convenient use with {test,set,clear}_bit.   */ -#define ASYNC_HUP_NOTIFY 0x0001 /* Notify getty on hangups and closes  -				   on the callout port */ -#define ASYNC_FOURPORT  0x0002	/* Set OU1, OUT2 per AST Fourport settings */ -#define ASYNC_SAK	0x0004	/* Secure Attention Key (Orange book) */ -#define ASYNC_SPLIT_TERMIOS 0x0008 /* Separate termios for dialin/callout */ - -#define ASYNC_SPD_MASK	0x1030 -#define ASYNC_SPD_HI	0x0010	/* Use 56000 instead of 38400 bps */ - -#define ASYNC_SPD_VHI	0x0020  /* Use 115200 instead of 38400 bps */ -#define ASYNC_SPD_CUST	0x0030  /* Use user-specified divisor */ - -#define ASYNC_SKIP_TEST	0x0040 /* Skip UART test during autoconfiguration */ -#define ASYNC_AUTO_IRQ  0x0080 /* Do automatic IRQ during autoconfiguration */ -#define ASYNC_SESSION_LOCKOUT 0x0100 /* Lock out cua opens based on session */ -#define ASYNC_PGRP_LOCKOUT    0x0200 /* Lock out cua opens based on pgrp */ -#define ASYNC_CALLOUT_NOHUP   0x0400 /* Don't do hangups for cua device */ - -#define ASYNC_HARDPPS_CD	0x0800	/* Call hardpps when CD goes high  */ - -#define ASYNC_SPD_SHI	0x1000	/* Use 230400 instead of 38400 bps */ -#define ASYNC_SPD_WARP	0x1010	/* Use 460800 instead of 38400 bps */ - -#define ASYNC_LOW_LATENCY 0x2000 /* Request low latency behaviour */ - -#define ASYNC_BUGGY_UART  0x4000 /* This is a buggy UART, skip some safety -				  * checks.  Note: can be dangerous! */ - -#define ASYNC_AUTOPROBE	 0x8000 /* Port was autoprobed by PCI or PNP code */ - -#define ASYNC_FLAGS	0x7FFF	/* Possible legal async flags */ -#define ASYNC_USR_MASK	0x3430	/* Legal flags that non-privileged -				 * users can set or reset */ - -/* Internal flags used only by kernel/chr_drv/serial.c */ -#define ASYNC_INITIALIZED	0x80000000 /* Serial port was initialized */ -#define ASYNC_NORMAL_ACTIVE	0x20000000 /* Normal device is active */ -#define ASYNC_BOOT_AUTOCONF	0x10000000 /* Autoconfigure port on bootup */ -#define ASYNC_CLOSING		0x08000000 /* Serial port is closing */ -#define ASYNC_CTS_FLOW		0x04000000 /* Do CTS flow control */ -#define ASYNC_CHECK_CD		0x02000000 /* i.e., CLOCAL */ -#define ASYNC_SHARE_IRQ		0x01000000 /* for multifunction cards -					     --- no longer used */ -#define ASYNC_CONS_FLOW		0x00800000 /* flow control for console  */ - -#define ASYNC_BOOT_ONLYMCA	0x00400000 /* Probe only if MCA bus */ -#define ASYNC_INTERNAL_FLAGS	0xFFC00000 /* Internal flags */ +#define ASYNCB_HUP_NOTIFY	 0 /* Notify getty on hangups and closes +				    * on the callout port */ +#define ASYNCB_FOURPORT		 1 /* Set OU1, OUT2 per AST Fourport settings */ +#define ASYNCB_SAK		 2 /* Secure Attention Key (Orange book) */ +#define ASYNCB_SPLIT_TERMIOS	 3 /* Separate termios for dialin/callout */ +#define ASYNCB_SPD_HI		 4 /* Use 56000 instead of 38400 bps */ +#define ASYNCB_SPD_VHI		 5 /* Use 115200 instead of 38400 bps */ +#define ASYNCB_SKIP_TEST	 6 /* Skip UART test during autoconfiguration */ +#define ASYNCB_AUTO_IRQ		 7 /* Do automatic IRQ during +				    * autoconfiguration */ +#define ASYNCB_SESSION_LOCKOUT	 8 /* Lock out cua opens based on session */ +#define ASYNCB_PGRP_LOCKOUT	 9 /* Lock out cua opens based on pgrp */ +#define ASYNCB_CALLOUT_NOHUP	10 /* Don't do hangups for cua device */ +#define ASYNCB_HARDPPS_CD	11 /* Call hardpps when CD goes high  */ +#define ASYNCB_SPD_SHI		12 /* Use 230400 instead of 38400 bps */ +#define ASYNCB_LOW_LATENCY	13 /* Request low latency behaviour */ +#define ASYNCB_BUGGY_UART	14 /* This is a buggy UART, skip some safety +				    * checks.  Note: can be dangerous! */ +#define ASYNCB_AUTOPROBE	15 /* Port was autoprobed by PCI or PNP code */ +#define ASYNCB_LAST_USER	15 + +/* Internal flags used only by kernel */ +#define ASYNCB_INITIALIZED	31 /* Serial port was initialized */ +#define ASYNCB_NORMAL_ACTIVE	29 /* Normal device is active */ +#define ASYNCB_BOOT_AUTOCONF	28 /* Autoconfigure port on bootup */ +#define ASYNCB_CLOSING		27 /* Serial port is closing */ +#define ASYNCB_CTS_FLOW		26 /* Do CTS flow control */ +#define ASYNCB_CHECK_CD		25 /* i.e., CLOCAL */ +#define ASYNCB_SHARE_IRQ	24 /* for multifunction cards, no longer used */ +#define ASYNCB_CONS_FLOW	23 /* flow control for console  */ +#define ASYNCB_BOOT_ONLYMCA	22 /* Probe only if MCA bus */ +#define ASYNCB_FIRST_KERNEL	22 + +#define ASYNC_HUP_NOTIFY	(1U << ASYNCB_HUP_NOTIFY) +#define ASYNC_FOURPORT		(1U << ASYNCB_FOURPORT) +#define ASYNC_SAK		(1U << ASYNCB_SAK) +#define ASYNC_SPLIT_TERMIOS	(1U << ASYNCB_SPLIT_TERMIOS) +#define ASYNC_SPD_HI		(1U << ASYNCB_SPD_HI) +#define ASYNC_SPD_VHI		(1U << ASYNCB_SPD_VHI) +#define ASYNC_SKIP_TEST		(1U << ASYNCB_SKIP_TEST) +#define ASYNC_AUTO_IRQ		(1U << ASYNCB_AUTO_IRQ) +#define ASYNC_SESSION_LOCKOUT	(1U << ASYNCB_SESSION_LOCKOUT) +#define ASYNC_PGRP_LOCKOUT	(1U << ASYNCB_PGRP_LOCKOUT) +#define ASYNC_CALLOUT_NOHUP	(1U << ASYNCB_CALLOUT_NOHUP) +#define ASYNC_HARDPPS_CD	(1U << ASYNCB_HARDPPS_CD) +#define ASYNC_SPD_SHI		(1U << ASYNCB_SPD_SHI) +#define ASYNC_LOW_LATENCY	(1U << ASYNCB_LOW_LATENCY) +#define ASYNC_BUGGY_UART	(1U << ASYNCB_BUGGY_UART) +#define ASYNC_AUTOPROBE		(1U << ASYNCB_AUTOPROBE) + +#define ASYNC_FLAGS		((1U << ASYNCB_LAST_USER) - 1) +#define ASYNC_USR_MASK		(ASYNC_SPD_HI|ASYNC_SPD_VHI| \ +		ASYNC_CALLOUT_NOHUP|ASYNC_SPD_SHI|ASYNC_LOW_LATENCY) +#define ASYNC_SPD_CUST		(ASYNC_SPD_HI|ASYNC_SPD_VHI) +#define ASYNC_SPD_WARP		(ASYNC_SPD_HI|ASYNC_SPD_SHI) +#define ASYNC_SPD_MASK		(ASYNC_SPD_HI|ASYNC_SPD_VHI|ASYNC_SPD_SHI) + +#define ASYNC_INITIALIZED	(1U << ASYNCB_INITIALIZED) +#define ASYNC_NORMAL_ACTIVE	(1U << ASYNCB_NORMAL_ACTIVE) +#define ASYNC_BOOT_AUTOCONF	(1U << ASYNCB_BOOT_AUTOCONF) +#define ASYNC_CLOSING		(1U << ASYNCB_CLOSING) +#define ASYNC_CTS_FLOW		(1U << ASYNCB_CTS_FLOW) +#define ASYNC_CHECK_CD		(1U << ASYNCB_CHECK_CD) +#define ASYNC_SHARE_IRQ		(1U << ASYNCB_SHARE_IRQ) +#define ASYNC_CONS_FLOW		(1U << ASYNCB_CONS_FLOW) +#define ASYNC_BOOT_ONLYMCA	(1U << ASYNCB_BOOT_ONLYMCA) +#define ASYNC_INTERNAL_FLAGS	(~((1U << ASYNCB_FIRST_KERNEL) - 1))  /*   * Multiport serial configuration structure --- external structure diff --git a/include/linux/serial_core.h b/include/linux/serial_core.h index 57a97e52e58..6fd80c4243f 100644 --- a/include/linux/serial_core.h +++ b/include/linux/serial_core.h @@ -41,7 +41,8 @@  #define PORT_XSCALE	15  #define PORT_RM9000	16	/* PMC-Sierra RM9xxx internal UART */  #define PORT_OCTEON	17	/* Cavium OCTEON internal UART */ -#define PORT_MAX_8250	17	/* max port ID */ +#define PORT_AR7	18	/* Texas Instruments AR7 internal UART */ +#define PORT_MAX_8250	18	/* max port ID */  /*   * ARM specific type numbers.  These are not currently guaranteed @@ -167,6 +168,9 @@  /* MAX3100 */  #define PORT_MAX3100    86 +/* Timberdale UART */ +#define PORT_TIMBUART	87 +  #ifdef __KERNEL__  #include <linux/compiler.h> diff --git a/include/linux/serial_sci.h b/include/linux/serial_sci.h index 893cc53486b..1c297ddc9d5 100644 --- a/include/linux/serial_sci.h +++ b/include/linux/serial_sci.h @@ -25,8 +25,7 @@ struct plat_sci_port {  	unsigned int	irqs[SCIx_NR_IRQS];	/* ERI, RXI, TXI, BRI */  	unsigned int	type;			/* SCI / SCIF / IRDA */  	upf_t		flags;			/* UPF_* flags */ +	char		*clk;			/* clock string */  }; -int early_sci_setup(struct uart_port *port); -  #endif /* __LINUX_SERIAL_SCI_H */ diff --git a/include/linux/sh_cmt.h b/include/linux/sh_cmt.h deleted file mode 100644 index 68cacde5954..00000000000 --- a/include/linux/sh_cmt.h +++ /dev/null @@ -1,13 +0,0 @@ -#ifndef __SH_CMT_H__ -#define __SH_CMT_H__ - -struct sh_cmt_config { -	char *name; -	unsigned long channel_offset; -	int timer_bit; -	char *clk; -	unsigned long clockevent_rating; -	unsigned long clocksource_rating; -}; - -#endif /* __SH_CMT_H__ */ diff --git a/include/linux/sh_timer.h b/include/linux/sh_timer.h new file mode 100644 index 00000000000..864bd56bd3b --- /dev/null +++ b/include/linux/sh_timer.h @@ -0,0 +1,13 @@ +#ifndef __SH_TIMER_H__ +#define __SH_TIMER_H__ + +struct sh_timer_config { +	char *name; +	long channel_offset; +	int timer_bit; +	char *clk; +	unsigned long clockevent_rating; +	unsigned long clocksource_rating; +}; + +#endif /* __SH_TIMER_H__ */ diff --git a/include/linux/signal.h b/include/linux/signal.h index 84f997f8aa5..c7552836bd9 100644 --- a/include/linux/signal.h +++ b/include/linux/signal.h @@ -235,6 +235,8 @@ static inline int valid_signal(unsigned long sig)  extern int next_signal(struct sigpending *pending, sigset_t *mask);  extern int group_send_sig_info(int sig, struct siginfo *info, struct task_struct *p);  extern int __group_send_sig_info(int, struct siginfo *, struct task_struct *); +extern long do_rt_tgsigqueueinfo(pid_t tgid, pid_t pid, int sig, +				 siginfo_t *info);  extern long do_sigpending(void __user *, unsigned long);  extern int sigprocmask(int, sigset_t *, sigset_t *);  extern int show_unhandled_signals; diff --git a/include/linux/skbuff.h b/include/linux/skbuff.h index 5fd389162f0..fa51293f270 100644 --- a/include/linux/skbuff.h +++ b/include/linux/skbuff.h @@ -189,20 +189,23 @@ struct skb_shared_info {  	atomic_t	dataref;  	unsigned short	nr_frags;  	unsigned short	gso_size; +#ifdef CONFIG_HAS_DMA +	dma_addr_t	dma_head; +#endif  	/* Warning: this field is not always filled in (UFO)! */  	unsigned short	gso_segs;  	unsigned short  gso_type;  	__be32          ip6_frag_id;  	union skb_shared_tx tx_flags; -#ifdef CONFIG_HAS_DMA -	unsigned int	num_dma_maps; -#endif  	struct sk_buff	*frag_list;  	struct skb_shared_hwtstamps hwtstamps;  	skb_frag_t	frags[MAX_SKB_FRAGS];  #ifdef CONFIG_HAS_DMA -	dma_addr_t	dma_maps[MAX_SKB_FRAGS + 1]; +	dma_addr_t	dma_maps[MAX_SKB_FRAGS];  #endif +	/* Intermediate layers must ensure that destructor_arg +	 * remains valid until skb destructor */ +	void *		destructor_arg;  };  /* We divide dataref into two halves.  The higher 16 bits hold references @@ -301,9 +304,6 @@ typedef unsigned char *sk_buff_data_t;   *	@tc_verd: traffic control verdict   *	@ndisc_nodetype: router type (from link layer)   *	@do_not_encrypt: set to prevent encryption of this frame - *	@requeue: set to indicate that the wireless core should attempt - *		a software retry on this frame if we failed to - *		receive an ACK for it   *	@dma_cookie: a cookie to one of several possible DMA operations   *		done by skb DMA functions   *	@secmark: security marking @@ -319,10 +319,7 @@ struct sk_buff {  	ktime_t			tstamp;  	struct net_device	*dev; -	union { -		struct  dst_entry	*dst; -		struct  rtable		*rtable; -	}; +	unsigned long		_skb_dst;  #ifdef CONFIG_XFRM  	struct	sec_path	*sp;  #endif @@ -380,7 +377,6 @@ struct sk_buff {  #endif  #if defined(CONFIG_MAC80211) || defined(CONFIG_MAC80211_MODULE)  	__u8			do_not_encrypt:1; -	__u8			requeue:1;  #endif  	/* 0/13/14 bit hole */ @@ -423,6 +419,21 @@ extern void skb_dma_unmap(struct device *dev, struct sk_buff *skb,  			  enum dma_data_direction dir);  #endif +static inline struct dst_entry *skb_dst(const struct sk_buff *skb) +{ +	return (struct dst_entry *)skb->_skb_dst; +} + +static inline void skb_dst_set(struct sk_buff *skb, struct dst_entry *dst) +{ +	skb->_skb_dst = (unsigned long)dst; +} + +static inline struct rtable *skb_rtable(const struct sk_buff *skb) +{ +	return (struct rtable *)skb_dst(skb); +} +  extern void kfree_skb(struct sk_buff *skb);  extern void consume_skb(struct sk_buff *skb);  extern void	       __kfree_skb(struct sk_buff *skb); @@ -1062,7 +1073,7 @@ extern void skb_add_rx_frag(struct sk_buff *skb, int i, struct page *page,  			    int off, int size);  #define SKB_PAGE_ASSERT(skb) 	BUG_ON(skb_shinfo(skb)->nr_frags) -#define SKB_FRAG_ASSERT(skb) 	BUG_ON(skb_shinfo(skb)->frag_list) +#define SKB_FRAG_ASSERT(skb) 	BUG_ON(skb_has_frags(skb))  #define SKB_LINEAR_ASSERT(skb)  BUG_ON(skb_is_nonlinear(skb))  #ifdef NET_SKBUFF_DATA_USES_OFFSET @@ -1701,6 +1712,25 @@ static inline int pskb_trim_rcsum(struct sk_buff *skb, unsigned int len)  		     skb = skb->prev) +static inline bool skb_has_frags(const struct sk_buff *skb) +{ +	return skb_shinfo(skb)->frag_list != NULL; +} + +static inline void skb_frag_list_init(struct sk_buff *skb) +{ +	skb_shinfo(skb)->frag_list = NULL; +} + +static inline void skb_frag_add_head(struct sk_buff *skb, struct sk_buff *frag) +{ +	frag->next = skb_shinfo(skb)->frag_list; +	skb_shinfo(skb)->frag_list = frag; +} + +#define skb_walk_frags(skb, iter)	\ +	for (iter = skb_shinfo(skb)->frag_list; iter; iter = iter->next) +  extern struct sk_buff *__skb_recv_datagram(struct sock *sk, unsigned flags,  					   int *peeked, int *err);  extern struct sk_buff *skb_recv_datagram(struct sock *sk, unsigned flags, @@ -1715,8 +1745,14 @@ extern int	       skb_copy_and_csum_datagram_iovec(struct sk_buff *skb,  							struct iovec *iov);  extern int	       skb_copy_datagram_from_iovec(struct sk_buff *skb,  						    int offset, -						    struct iovec *from, +						    const struct iovec *from, +						    int from_offset,  						    int len); +extern int	       skb_copy_datagram_const_iovec(const struct sk_buff *from, +						     int offset, +						     const struct iovec *to, +						     int to_offset, +						     int size);  extern void	       skb_free_datagram(struct sock *sk, struct sk_buff *skb);  extern int	       skb_kill_datagram(struct sock *sk, struct sk_buff *skb,  					 unsigned int flags); diff --git a/include/linux/slab.h b/include/linux/slab.h index 24c5602bee9..219b8fb4651 100644 --- a/include/linux/slab.h +++ b/include/linux/slab.h @@ -62,6 +62,8 @@  # define SLAB_DEBUG_OBJECTS	0x00000000UL  #endif +#define SLAB_NOLEAKTRACE	0x00800000UL	/* Avoid kmemleak tracing */ +  /* The following flags affect the page allocator grouping pages by mobility */  #define SLAB_RECLAIM_ACCOUNT	0x00020000UL		/* Objects are reclaimable */  #define SLAB_TEMPORARY		SLAB_RECLAIM_ACCOUNT	/* Objects are short-lived */ @@ -317,4 +319,6 @@ static inline void *kzalloc_node(size_t size, gfp_t flags, int node)  	return kmalloc_node(size, flags | __GFP_ZERO, node);  } +void __init kmem_cache_init_late(void); +  #endif	/* _LINUX_SLAB_H */ diff --git a/include/linux/slab_def.h b/include/linux/slab_def.h index 5ac9b0bcaf9..713f841ecaa 100644 --- a/include/linux/slab_def.h +++ b/include/linux/slab_def.h @@ -14,7 +14,7 @@  #include <asm/page.h>		/* kmalloc_sizes.h needs PAGE_SIZE */  #include <asm/cache.h>		/* kmalloc_sizes.h needs L1_CACHE_BYTES */  #include <linux/compiler.h> -#include <trace/kmemtrace.h> +#include <linux/kmemtrace.h>  /* Size description struct for general caches. */  struct cache_sizes { diff --git a/include/linux/slob_def.h b/include/linux/slob_def.h index 0ec00b39d00..bb5368df4be 100644 --- a/include/linux/slob_def.h +++ b/include/linux/slob_def.h @@ -34,4 +34,9 @@ static __always_inline void *__kmalloc(size_t size, gfp_t flags)  	return kmalloc(size, flags);  } +static inline void kmem_cache_init_late(void) +{ +	/* Nothing to do */ +} +  #endif /* __LINUX_SLOB_DEF_H */ diff --git a/include/linux/slub_def.h b/include/linux/slub_def.h index 5046f90c117..4dcbc2c7149 100644 --- a/include/linux/slub_def.h +++ b/include/linux/slub_def.h @@ -10,7 +10,7 @@  #include <linux/gfp.h>  #include <linux/workqueue.h>  #include <linux/kobject.h> -#include <trace/kmemtrace.h> +#include <linux/kmemtrace.h>  enum stat_item {  	ALLOC_FASTPATH,		/* Allocation from cpu slab */ @@ -302,4 +302,6 @@ static __always_inline void *kmalloc_node(size_t size, gfp_t flags, int node)  }  #endif +void __init kmem_cache_init_late(void); +  #endif /* _LINUX_SLUB_DEF_H */ diff --git a/include/linux/smsc911x.h b/include/linux/smsc911x.h index b32725075d7..5241e4fb4ec 100644 --- a/include/linux/smsc911x.h +++ b/include/linux/smsc911x.h @@ -47,4 +47,14 @@ struct smsc911x_platform_config {  #define SMSC911X_FORCE_EXTERNAL_PHY 		(BIT(3))  #define SMSC911X_SAVE_MAC_ADDRESS		(BIT(4)) +/* + * SMSC911X_SWAP_FIFO: + * Enables software byte swap for fifo data. Should only be used as a + * "last resort" in the case of big endian mode on boards with incorrectly + * routed data bus to older devices such as LAN9118. Newer devices such as + * LAN9221 can handle this in hardware, there are registers to control + * this swapping but the driver doesn't currently use them. + */ +#define SMSC911X_SWAP_FIFO			(BIT(5)) +  #endif /* __LINUX_SMSC911X_H__ */ diff --git a/include/linux/snmp.h b/include/linux/snmp.h index aee3f1e1d1c..0f953fe4041 100644 --- a/include/linux/snmp.h +++ b/include/linux/snmp.h @@ -18,7 +18,7 @@  enum  {  	IPSTATS_MIB_NUM = 0, -	IPSTATS_MIB_INRECEIVES,			/* InReceives */ +	IPSTATS_MIB_INPKTS,			/* InReceives */  	IPSTATS_MIB_INHDRERRORS,		/* InHdrErrors */  	IPSTATS_MIB_INTOOBIGERRORS,		/* InTooBigErrors */  	IPSTATS_MIB_INNOROUTES,			/* InNoRoutes */ @@ -28,7 +28,7 @@ enum  	IPSTATS_MIB_INDISCARDS,			/* InDiscards */  	IPSTATS_MIB_INDELIVERS,			/* InDelivers */  	IPSTATS_MIB_OUTFORWDATAGRAMS,		/* OutForwDatagrams */ -	IPSTATS_MIB_OUTREQUESTS,		/* OutRequests */ +	IPSTATS_MIB_OUTPKTS,			/* OutRequests */  	IPSTATS_MIB_OUTDISCARDS,		/* OutDiscards */  	IPSTATS_MIB_OUTNOROUTES,		/* OutNoRoutes */  	IPSTATS_MIB_REASMTIMEOUT,		/* ReasmTimeout */ @@ -42,6 +42,12 @@ enum  	IPSTATS_MIB_OUTMCASTPKTS,		/* OutMcastPkts */  	IPSTATS_MIB_INBCASTPKTS,		/* InBcastPkts */  	IPSTATS_MIB_OUTBCASTPKTS,		/* OutBcastPkts */ +	IPSTATS_MIB_INOCTETS,			/* InOctets */ +	IPSTATS_MIB_OUTOCTETS,			/* OutOctets */ +	IPSTATS_MIB_INMCASTOCTETS,		/* InMcastOctets */ +	IPSTATS_MIB_OUTMCASTOCTETS,		/* OutMcastOctets */ +	IPSTATS_MIB_INBCASTOCTETS,		/* InBcastOctets */ +	IPSTATS_MIB_OUTBCASTOCTETS,		/* OutBcastOctets */  	__IPSTATS_MIB_MAX  }; diff --git a/include/linux/socket.h b/include/linux/socket.h index 421afb4d29b..3b461dffe24 100644 --- a/include/linux/socket.h +++ b/include/linux/socket.h @@ -194,7 +194,8 @@ struct ucred {  #define AF_RXRPC	33	/* RxRPC sockets 		*/  #define AF_ISDN		34	/* mISDN sockets 		*/  #define AF_PHONET	35	/* Phonet sockets		*/ -#define AF_MAX		36	/* For now.. */ +#define AF_IEEE802154	36	/* IEEE802154 sockets		*/ +#define AF_MAX		37	/* For now.. */  /* Protocol families, same as address families. */  #define PF_UNSPEC	AF_UNSPEC @@ -233,6 +234,7 @@ struct ucred {  #define PF_RXRPC	AF_RXRPC  #define PF_ISDN		AF_ISDN  #define PF_PHONET	AF_PHONET +#define PF_IEEE802154	AF_IEEE802154  #define PF_MAX		AF_MAX  /* Maximum queue length specifiable by listen.  */ @@ -303,14 +305,15 @@ struct ucred {  #define SOL_BLUETOOTH	274  #define SOL_PNPIPE	275  #define SOL_RDS		276 +#define SOL_IUCV	277  /* IPX options */  #define IPX_TYPE	1  #ifdef __KERNEL__  extern int memcpy_fromiovec(unsigned char *kdata, struct iovec *iov, int len); -extern int memcpy_fromiovecend(unsigned char *kdata, struct iovec *iov,  -				int offset, int len); +extern int memcpy_fromiovecend(unsigned char *kdata, const struct iovec *iov, +			       int offset, int len);  extern int csum_partial_copy_fromiovecend(unsigned char *kdata,   					  struct iovec *iov,   					  int offset,  @@ -318,6 +321,8 @@ extern int csum_partial_copy_fromiovecend(unsigned char *kdata,  extern int verify_iovec(struct msghdr *m, struct iovec *iov, struct sockaddr *address, int mode);  extern int memcpy_toiovec(struct iovec *v, unsigned char *kdata, int len); +extern int memcpy_toiovecend(const struct iovec *v, unsigned char *kdata, +			     int offset, int len);  extern int move_addr_to_user(struct sockaddr *kaddr, int klen, void __user *uaddr, int __user *ulen);  extern int move_addr_to_kernel(void __user *uaddr, int ulen, struct sockaddr *kaddr);  extern int put_cmsg(struct msghdr*, int level, int type, int len, void *data); diff --git a/include/linux/spi/libertas_spi.h b/include/linux/spi/libertas_spi.h index 79506f5f9e6..1b5d5384fcd 100644 --- a/include/linux/spi/libertas_spi.h +++ b/include/linux/spi/libertas_spi.h @@ -22,9 +22,6 @@ struct libertas_spi_platform_data {  	 * speed, you may want to use 0 here. */  	u16 use_dummy_writes; -	/* GPIO number to use as chip select */ -	u16 gpio_cs; -  	/* Board specific setup/teardown */  	int (*setup)(struct spi_device *spi);  	int (*teardown)(struct spi_device *spi); diff --git a/include/linux/spi/wl12xx.h b/include/linux/spi/wl12xx.h new file mode 100644 index 00000000000..11430cab2aa --- /dev/null +++ b/include/linux/spi/wl12xx.h @@ -0,0 +1,31 @@ +/* + * This file is part of wl12xx + * + * Copyright (C) 2009 Nokia Corporation + * + * Contact: Kalle Valo <kalle.valo@nokia.com> + * + * This program is free software; you can redistribute it and/or + * modify it under the terms of the GNU General Public License + * 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. + * + * You should have received a copy of the GNU General Public License + * along with this program; if not, write to the Free Software + * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA + * 02110-1301 USA + * + */ + +#ifndef _LINUX_SPI_WL12XX_H +#define _LINUX_SPI_WL12XX_H + +struct wl12xx_platform_data { +	void (*set_power)(bool enable); +}; + +#endif diff --git a/include/linux/spinlock_up.h b/include/linux/spinlock_up.h index 938234c4a99..d4841ed8215 100644 --- a/include/linux/spinlock_up.h +++ b/include/linux/spinlock_up.h @@ -60,6 +60,7 @@ static inline void __raw_spin_unlock(raw_spinlock_t *lock)  #define __raw_spin_is_locked(lock)	((void)(lock), 0)  /* for sched.c and kernel_lock.c: */  # define __raw_spin_lock(lock)		do { (void)(lock); } while (0) +# define __raw_spin_lock_flags(lock, flags)	do { (void)(lock); } while (0)  # define __raw_spin_unlock(lock)	do { (void)(lock); } while (0)  # define __raw_spin_trylock(lock)	({ (void)(lock); 1; })  #endif /* DEBUG_SPINLOCK */ diff --git a/include/linux/splice.h b/include/linux/splice.h index 5f3faa9d15a..18e7c7c0cae 100644 --- a/include/linux/splice.h +++ b/include/linux/splice.h @@ -11,8 +11,7 @@  #include <linux/pipe_fs_i.h>  /* - * splice is tied to pipes as a transport (at least for now), so we'll just - * add the splice flags here. + * Flags passed in from splice/tee/vmsplice   */  #define SPLICE_F_MOVE	(0x01)	/* move pages instead of copying */  #define SPLICE_F_NONBLOCK (0x02) /* don't block on the pipe splicing (but */ diff --git a/include/linux/suspend.h b/include/linux/suspend.h index 795032edfc4..cd15df6c63c 100644 --- a/include/linux/suspend.h +++ b/include/linux/suspend.h @@ -245,11 +245,6 @@ extern unsigned long get_safe_page(gfp_t gfp_mask);  extern void hibernation_set_ops(struct platform_hibernation_ops *ops);  extern int hibernate(void); -extern int hibernate_nvs_register(unsigned long start, unsigned long size); -extern int hibernate_nvs_alloc(void); -extern void hibernate_nvs_free(void); -extern void hibernate_nvs_save(void); -extern void hibernate_nvs_restore(void);  extern bool system_entering_hibernation(void);  #else /* CONFIG_HIBERNATION */  static inline int swsusp_page_is_forbidden(struct page *p) { return 0; } @@ -258,6 +253,16 @@ static inline void swsusp_unset_page_free(struct page *p) {}  static inline void hibernation_set_ops(struct platform_hibernation_ops *ops) {}  static inline int hibernate(void) { return -ENOSYS; } +static inline bool system_entering_hibernation(void) { return false; } +#endif /* CONFIG_HIBERNATION */ + +#ifdef CONFIG_HIBERNATION_NVS +extern int hibernate_nvs_register(unsigned long start, unsigned long size); +extern int hibernate_nvs_alloc(void); +extern void hibernate_nvs_free(void); +extern void hibernate_nvs_save(void); +extern void hibernate_nvs_restore(void); +#else /* CONFIG_HIBERNATION_NVS */  static inline int hibernate_nvs_register(unsigned long a, unsigned long b)  {  	return 0; @@ -266,8 +271,7 @@ static inline int hibernate_nvs_alloc(void) { return 0; }  static inline void hibernate_nvs_free(void) {}  static inline void hibernate_nvs_save(void) {}  static inline void hibernate_nvs_restore(void) {} -static inline bool system_entering_hibernation(void) { return false; } -#endif /* CONFIG_HIBERNATION */ +#endif /* CONFIG_HIBERNATION_NVS */  #ifdef CONFIG_PM_SLEEP  void save_processor_state(void); diff --git a/include/linux/swap.h b/include/linux/swap.h index 62d81435347..d476aad3ff5 100644 --- a/include/linux/swap.h +++ b/include/linux/swap.h @@ -437,6 +437,11 @@ static inline int mem_cgroup_cache_charge_swapin(struct page *page,  	return 0;  } +static inline void +mem_cgroup_uncharge_swapcache(struct page *page, swp_entry_t ent) +{ +} +  #endif /* CONFIG_SWAP */  #endif /* __KERNEL__*/  #endif /* _LINUX_SWAP_H */ diff --git a/include/linux/swiotlb.h b/include/linux/swiotlb.h index ac9ff54f7cb..cb1a6631b8f 100644 --- a/include/linux/swiotlb.h +++ b/include/linux/swiotlb.h @@ -29,7 +29,8 @@ extern void *swiotlb_alloc(unsigned order, unsigned long nslabs);  extern dma_addr_t swiotlb_phys_to_bus(struct device *hwdev,  				      phys_addr_t address); -extern phys_addr_t swiotlb_bus_to_phys(dma_addr_t address); +extern phys_addr_t swiotlb_bus_to_phys(struct device *hwdev, +				       dma_addr_t address);  extern int swiotlb_arch_range_needs_mapping(phys_addr_t paddr, size_t size); diff --git a/include/linux/syscalls.h b/include/linux/syscalls.h index 40617c1d897..418d90f5eff 100644 --- a/include/linux/syscalls.h +++ b/include/linux/syscalls.h @@ -55,6 +55,7 @@ struct compat_timeval;  struct robust_list_head;  struct getcpu_cache;  struct old_linux_dirent; +struct perf_counter_attr;  #include <linux/types.h>  #include <linux/aio_abi.h> @@ -433,6 +434,7 @@ asmlinkage long sys_fcntl(unsigned int fd, unsigned int cmd, unsigned long arg);  asmlinkage long sys_fcntl64(unsigned int fd,  				unsigned int cmd, unsigned long arg);  #endif +asmlinkage long sys_pipe2(int __user *fildes, int flags);  asmlinkage long sys_dup(unsigned int fildes);  asmlinkage long sys_dup2(unsigned int oldfd, unsigned int newfd);  asmlinkage long sys_dup3(unsigned int oldfd, unsigned int newfd, int flags); @@ -754,4 +756,8 @@ asmlinkage long sys_pipe(int __user *);  int kernel_execve(const char *filename, char *const argv[], char *const envp[]); + +asmlinkage long sys_perf_counter_open( +		struct perf_counter_attr __user *attr_uptr, +		pid_t pid, int cpu, int group_fd, unsigned long flags);  #endif diff --git a/include/linux/tcp.h b/include/linux/tcp.h index 9d5078bd23a..8afac76cd74 100644 --- a/include/linux/tcp.h +++ b/include/linux/tcp.h @@ -377,7 +377,7 @@ struct tcp_sock {  	unsigned int		keepalive_time;	  /* time before keep alive takes place */  	unsigned int		keepalive_intvl;  /* time interval between keep alive probes */ -	unsigned long last_synq_overflow;  +	int			linger2;  /* Receiver side RTT estimation */  	struct { @@ -406,8 +406,6 @@ struct tcp_sock {  /* TCP MD5 Signagure Option information */  	struct tcp_md5sig_info	*md5sig_info;  #endif - -	int			linger2;  };  static inline struct tcp_sock *tcp_sk(const struct sock *sk) diff --git a/include/linux/thread_info.h b/include/linux/thread_info.h index e6b820f8b56..a8cc4e13434 100644 --- a/include/linux/thread_info.h +++ b/include/linux/thread_info.h @@ -21,13 +21,14 @@ struct restart_block {  		struct {  			unsigned long arg0, arg1, arg2, arg3;  		}; -		/* For futex_wait */ +		/* For futex_wait and futex_wait_requeue_pi */  		struct {  			u32 *uaddr;  			u32 val;  			u32 flags;  			u32 bitset;  			u64 time; +			u32 *uaddr2;  		} futex;  		/* For nanosleep */  		struct { diff --git a/include/linux/tick.h b/include/linux/tick.h index 469b82d88b3..0482229c07d 100644 --- a/include/linux/tick.h +++ b/include/linux/tick.h @@ -97,10 +97,12 @@ extern void tick_clock_notify(void);  extern int tick_check_oneshot_change(int allow_nohz);  extern struct tick_sched *tick_get_tick_sched(int cpu);  extern void tick_check_idle(int cpu); +extern int tick_oneshot_mode_active(void);  # else  static inline void tick_clock_notify(void) { }  static inline int tick_check_oneshot_change(int allow_nohz) { return 0; }  static inline void tick_check_idle(int cpu) { } +static inline int tick_oneshot_mode_active(void) { return 0; }  # endif  #else /* CONFIG_GENERIC_CLOCKEVENTS */ @@ -109,6 +111,7 @@ static inline void tick_cancel_sched_timer(int cpu) { }  static inline void tick_clock_notify(void) { }  static inline int tick_check_oneshot_change(int allow_nohz) { return 0; }  static inline void tick_check_idle(int cpu) { } +static inline int tick_oneshot_mode_active(void) { return 0; }  #endif /* !CONFIG_GENERIC_CLOCKEVENTS */  # ifdef CONFIG_NO_HZ diff --git a/include/linux/time.h b/include/linux/time.h index 242f62499bb..ea16c1a01d5 100644 --- a/include/linux/time.h +++ b/include/linux/time.h @@ -113,6 +113,21 @@ struct timespec current_kernel_time(void);  #define CURRENT_TIME		(current_kernel_time())  #define CURRENT_TIME_SEC	((struct timespec) { get_seconds(), 0 }) +/* Some architectures do not supply their own clocksource. + * This is mainly the case in architectures that get their + * inter-tick times by reading the counter on their interval + * timer. Since these timers wrap every tick, they're not really + * useful as clocksources. Wrapping them to act like one is possible + * but not very efficient. So we provide a callout these arches + * can implement for use with the jiffies clocksource to provide + * finer then tick granular time. + */ +#ifdef CONFIG_ARCH_USES_GETTIMEOFFSET +extern u32 arch_gettimeoffset(void); +#else +static inline u32 arch_gettimeoffset(void) { return 0; } +#endif +  extern void do_gettimeofday(struct timeval *tv);  extern int do_settimeofday(struct timespec *tv);  extern int do_sys_settimeofday(struct timespec *tv, struct timezone *tz); diff --git a/include/linux/timer.h b/include/linux/timer.h index 6cdb6f3331f..ccf882eed8f 100644 --- a/include/linux/timer.h +++ b/include/linux/timer.h @@ -163,7 +163,10 @@ extern void add_timer_on(struct timer_list *timer, int cpu);  extern int del_timer(struct timer_list * timer);  extern int mod_timer(struct timer_list *timer, unsigned long expires);  extern int mod_timer_pending(struct timer_list *timer, unsigned long expires); +extern int mod_timer_pinned(struct timer_list *timer, unsigned long expires); +#define TIMER_NOT_PINNED	0 +#define TIMER_PINNED		1  /*   * The jiffies value which is added to now, when there is no timer   * in the timer wheel: diff --git a/include/linux/timex.h b/include/linux/timex.h index aa3475fcff6..9910e3bd5b3 100644 --- a/include/linux/timex.h +++ b/include/linux/timex.h @@ -170,17 +170,37 @@ struct timex {  #include <asm/timex.h>  /* - * SHIFT_KG and SHIFT_KF establish the damping of the PLL and are chosen - * for a slightly underdamped convergence characteristic. SHIFT_KH - * establishes the damping of the FLL and is chosen by wisdom and black - * art. + * SHIFT_PLL is used as a dampening factor to define how much we + * adjust the frequency correction for a given offset in PLL mode. + * It also used in dampening the offset correction, to define how + * much of the current value in time_offset we correct for each + * second. Changing this value changes the stiffness of the ntp + * adjustment code. A lower value makes it more flexible, reducing + * NTP convergence time. A higher value makes it stiffer, increasing + * convergence time, but making the clock more stable.   * - * MAXTC establishes the maximum time constant of the PLL. With the - * SHIFT_KG and SHIFT_KF values given and a time constant range from - * zero to MAXTC, the PLL will converge in 15 minutes to 16 hours, - * respectively. + * In David Mills' nanokernel reference implementation SHIFT_PLL is 4. + * However this seems to increase convergence time much too long. + * + * https://lists.ntp.org/pipermail/hackers/2008-January/003487.html + * + * In the above mailing list discussion, it seems the value of 4 + * was appropriate for other Unix systems with HZ=100, and that + * SHIFT_PLL should be decreased as HZ increases. However, Linux's + * clock steering implementation is HZ independent. + * + * Through experimentation, a SHIFT_PLL value of 2 was found to allow + * for fast convergence (very similar to the NTPv3 code used prior to + * v2.6.19), with good clock stability. + * + * + * SHIFT_FLL is used as a dampening factor to define how much we + * adjust the frequency correction for a given offset in FLL mode. + * In David Mills' nanokernel reference implementation SHIFT_FLL is 2. + * + * MAXTC establishes the maximum time constant of the PLL.   */ -#define SHIFT_PLL	4	/* PLL frequency factor (shift) */ +#define SHIFT_PLL	2	/* PLL frequency factor (shift) */  #define SHIFT_FLL	2	/* FLL frequency factor (shift) */  #define MAXTC		10	/* maximum time constant (shift) */ @@ -192,10 +212,10 @@ struct timex {  #define SHIFT_USEC 16		/* frequency offset scale (shift) */  #define PPM_SCALE ((s64)NSEC_PER_USEC << (NTP_SCALE_SHIFT - SHIFT_USEC))  #define PPM_SCALE_INV_SHIFT 19 -#define PPM_SCALE_INV ((1ll << (PPM_SCALE_INV_SHIFT + NTP_SCALE_SHIFT)) / \ +#define PPM_SCALE_INV ((1LL << (PPM_SCALE_INV_SHIFT + NTP_SCALE_SHIFT)) / \  		       PPM_SCALE + 1) -#define MAXPHASE 500000000l	/* max phase error (ns) */ +#define MAXPHASE 500000000L	/* max phase error (ns) */  #define MAXFREQ 500000		/* max frequency error (ns/s) */  #define MAXFREQ_SCALED ((s64)MAXFREQ << NTP_SCALE_SHIFT)  #define MINSEC 256		/* min interval between updates (s) */ diff --git a/include/linux/trace_seq.h b/include/linux/trace_seq.h new file mode 100644 index 00000000000..c68bccba207 --- /dev/null +++ b/include/linux/trace_seq.h @@ -0,0 +1,92 @@ +#ifndef _LINUX_TRACE_SEQ_H +#define _LINUX_TRACE_SEQ_H + +#include <linux/fs.h> + +/* + * Trace sequences are used to allow a function to call several other functions + * to create a string of data to use (up to a max of PAGE_SIZE. + */ + +struct trace_seq { +	unsigned char		buffer[PAGE_SIZE]; +	unsigned int		len; +	unsigned int		readpos; +}; + +static inline void +trace_seq_init(struct trace_seq *s) +{ +	s->len = 0; +	s->readpos = 0; +} + +/* + * Currently only defined when tracing is enabled. + */ +#ifdef CONFIG_TRACING +extern int trace_seq_printf(struct trace_seq *s, const char *fmt, ...) +	__attribute__ ((format (printf, 2, 3))); +extern int trace_seq_vprintf(struct trace_seq *s, const char *fmt, va_list args) +	__attribute__ ((format (printf, 2, 0))); +extern int +trace_seq_bprintf(struct trace_seq *s, const char *fmt, const u32 *binary); +extern void trace_print_seq(struct seq_file *m, struct trace_seq *s); +extern ssize_t trace_seq_to_user(struct trace_seq *s, char __user *ubuf, +				 size_t cnt); +extern int trace_seq_puts(struct trace_seq *s, const char *str); +extern int trace_seq_putc(struct trace_seq *s, unsigned char c); +extern int trace_seq_putmem(struct trace_seq *s, const void *mem, size_t len); +extern int trace_seq_putmem_hex(struct trace_seq *s, const void *mem, +				size_t len); +extern void *trace_seq_reserve(struct trace_seq *s, size_t len); +extern int trace_seq_path(struct trace_seq *s, struct path *path); + +#else /* CONFIG_TRACING */ +static inline int trace_seq_printf(struct trace_seq *s, const char *fmt, ...) +{ +	return 0; +} +static inline int +trace_seq_bprintf(struct trace_seq *s, const char *fmt, const u32 *binary) +{ +	return 0; +} + +static inline void trace_print_seq(struct seq_file *m, struct trace_seq *s) +{ +} +static inline ssize_t trace_seq_to_user(struct trace_seq *s, char __user *ubuf, +				 size_t cnt) +{ +	return 0; +} +static inline int trace_seq_puts(struct trace_seq *s, const char *str) +{ +	return 0; +} +static inline int trace_seq_putc(struct trace_seq *s, unsigned char c) +{ +	return 0; +} +static inline int +trace_seq_putmem(struct trace_seq *s, const void *mem, size_t len) +{ +	return 0; +} +static inline int trace_seq_putmem_hex(struct trace_seq *s, const void *mem, +				       size_t len) +{ +	return 0; +} +static inline void *trace_seq_reserve(struct trace_seq *s, size_t len) +{ +	return NULL; +} +static inline int trace_seq_path(struct trace_seq *s, struct path *path) +{ +	return 0; +} +#endif /* CONFIG_TRACING */ + +#endif /* _LINUX_TRACE_SEQ_H */ diff --git a/include/linux/tracehook.h b/include/linux/tracehook.h index c7aa154f4bf..eb96603d92d 100644 --- a/include/linux/tracehook.h +++ b/include/linux/tracehook.h @@ -259,14 +259,12 @@ static inline void tracehook_finish_clone(struct task_struct *child,  /**   * tracehook_report_clone - in parent, new child is about to start running - * @trace:		return value from tracehook_prepare_clone()   * @regs:		parent's user register state   * @clone_flags:	flags from parent's system call   * @pid:		new child's PID in the parent's namespace   * @child:		new child task   * - * Called after a child is set up, but before it has been started - * running.  @trace is the value returned by tracehook_prepare_clone(). + * Called after a child is set up, but before it has been started running.   * This is not a good place to block, because the child has not started   * yet.  Suspend the child here if desired, and then block in   * tracehook_report_clone_complete().  This must prevent the child from @@ -276,13 +274,14 @@ static inline void tracehook_finish_clone(struct task_struct *child,   *   * Called with no locks held, but the child cannot run until this returns.   */ -static inline void tracehook_report_clone(int trace, struct pt_regs *regs, +static inline void tracehook_report_clone(struct pt_regs *regs,  					  unsigned long clone_flags,  					  pid_t pid, struct task_struct *child)  { -	if (unlikely(trace) || unlikely(clone_flags & CLONE_PTRACE)) { +	if (unlikely(task_ptrace(child))) {  		/* -		 * The child starts up with an immediate SIGSTOP. +		 * It doesn't matter who attached/attaching to this +		 * task, the pending SIGSTOP is right in any case.  		 */  		sigaddset(&child->pending.signal, SIGSTOP);  		set_tsk_thread_flag(child, TIF_SIGPENDING); diff --git a/include/linux/tracepoint.h b/include/linux/tracepoint.h index d35a7ee7611..14df7e635d4 100644 --- a/include/linux/tracepoint.h +++ b/include/linux/tracepoint.h @@ -31,6 +31,8 @@ struct tracepoint {  					 * Keep in sync with vmlinux.lds.h.  					 */ +#ifndef DECLARE_TRACE +  #define TP_PROTO(args...)	args  #define TP_ARGS(args...)		args @@ -114,6 +116,7 @@ static inline void tracepoint_update_probe_range(struct tracepoint *begin,  	struct tracepoint *end)  { }  #endif /* CONFIG_TRACEPOINTS */ +#endif /* DECLARE_TRACE */  /*   * Connect a probe to a tracepoint. @@ -154,10 +157,8 @@ static inline void tracepoint_synchronize_unregister(void)  }  #define PARAMS(args...) args -#define TRACE_FORMAT(name, proto, args, fmt)		\ -	DECLARE_TRACE(name, PARAMS(proto), PARAMS(args)) - +#ifndef TRACE_EVENT  /*   * For use with the TRACE_EVENT macro:   * @@ -262,5 +263,6 @@ static inline void tracepoint_synchronize_unregister(void)  #define TRACE_EVENT(name, proto, args, struct, assign, print)	\  	DECLARE_TRACE(name, PARAMS(proto), PARAMS(args)) +#endif  #endif diff --git a/include/linux/tty.h b/include/linux/tty.h index fc39db95499..1488d8c81aa 100644 --- a/include/linux/tty.h +++ b/include/linux/tty.h @@ -185,7 +185,7 @@ struct tty_port;  struct tty_port_operations {  	/* Return 1 if the carrier is raised */  	int (*carrier_raised)(struct tty_port *port); -	void (*raise_dtr_rts)(struct tty_port *port); +	void (*dtr_rts)(struct tty_port *port, int raise);  };  struct tty_port { @@ -201,6 +201,9 @@ struct tty_port {  	unsigned char		*xmit_buf;	/* Optional buffer */  	int			close_delay;	/* Close port delay */  	int			closing_wait;	/* Delay for output */ +	int			drain_delay;	/* Set to zero if no pure time +						   based drain is needed else +						   set to size of fifo */  };  /* @@ -223,8 +226,11 @@ struct tty_struct {  	struct tty_driver *driver;  	const struct tty_operations *ops;  	int index; -	/* The ldisc objects are protected by tty_ldisc_lock at the moment */ -	struct tty_ldisc ldisc; + +	/* Protects ldisc changes: Lock tty not pty */ +	struct mutex ldisc_mutex; +	struct tty_ldisc *ldisc; +  	struct mutex termios_mutex;  	spinlock_t ctrl_lock;  	/* Termios values are protected by the termios mutex */ @@ -311,6 +317,7 @@ struct tty_struct {  #define TTY_CLOSING 		7	/* ->close() in progress */  #define TTY_LDISC 		9	/* Line discipline attached */  #define TTY_LDISC_CHANGING 	10	/* Line discipline changing */ +#define TTY_LDISC_OPEN	 	11	/* Line discipline is open */  #define TTY_HW_COOK_OUT 	14	/* Hardware can do output cooking */  #define TTY_HW_COOK_IN 		15	/* Hardware can do input cooking */  #define TTY_PTY_LOCK 		16	/* pty private */ @@ -403,6 +410,7 @@ extern int tty_termios_hw_change(struct ktermios *a, struct ktermios *b);  extern struct tty_ldisc *tty_ldisc_ref(struct tty_struct *);  extern void tty_ldisc_deref(struct tty_ldisc *);  extern struct tty_ldisc *tty_ldisc_ref_wait(struct tty_struct *); +extern void tty_ldisc_hangup(struct tty_struct *tty);  extern const struct file_operations tty_ldiscs_proc_fops;  extern void tty_wakeup(struct tty_struct *tty); @@ -425,6 +433,9 @@ extern struct tty_struct *tty_init_dev(struct tty_driver *driver, int idx,  extern void tty_release_dev(struct file *filp);  extern int tty_init_termios(struct tty_struct *tty); +extern struct tty_struct *tty_pair_get_tty(struct tty_struct *tty); +extern struct tty_struct *tty_pair_get_pty(struct tty_struct *tty); +  extern struct mutex tty_mutex;  extern void tty_write_unlock(struct tty_struct *tty); @@ -438,6 +449,7 @@ extern struct tty_struct *tty_port_tty_get(struct tty_port *port);  extern void tty_port_tty_set(struct tty_port *port, struct tty_struct *tty);  extern int tty_port_carrier_raised(struct tty_port *port);  extern void tty_port_raise_dtr_rts(struct tty_port *port); +extern void tty_port_lower_dtr_rts(struct tty_port *port);  extern void tty_port_hangup(struct tty_port *port);  extern int tty_port_block_til_ready(struct tty_port *port,  				struct tty_struct *tty, struct file *filp); diff --git a/include/linux/tty_driver.h b/include/linux/tty_driver.h index bcba84ea2d8..3566129384a 100644 --- a/include/linux/tty_driver.h +++ b/include/linux/tty_driver.h @@ -127,7 +127,8 @@   * 	the line discipline are close to full, and it should somehow   * 	signal that no more characters should be sent to the tty.   * - *	Optional: Always invoke via tty_throttle(); + *	Optional: Always invoke via tty_throttle(), called under the + *	termios lock.   *    * void (*unthrottle)(struct tty_struct * tty);   * @@ -135,7 +136,8 @@   * 	that characters can now be sent to the tty without fear of   * 	overrunning the input buffers of the line disciplines.   *  - *	Optional: Always invoke via tty_unthrottle(); + *	Optional: Always invoke via tty_unthrottle(), called under the + *	termios lock.   *   * void (*stop)(struct tty_struct *tty);   * diff --git a/include/linux/ultrasound.h b/include/linux/ultrasound.h index 6b7703e75ce..71339dc531c 100644 --- a/include/linux/ultrasound.h +++ b/include/linux/ultrasound.h @@ -34,7 +34,7 @@   *		_GUS_VOICEOFF	- Stops voice (no parameters)   *		_GUS_VOICEFADE	- Stops the voice smoothly.   *		_GUS_VOICEMODE	- Alters the voice mode, don't start or stop voice (P1=voice mode) - *		_GUS_VOICEBALA	- Sets voice balence (P1, 0=left, 7=middle and 15=right, default 7) + *		_GUS_VOICEBALA	- Sets voice balance (P1, 0=left, 7=middle and 15=right, default 7)   *		_GUS_VOICEFREQ	- Sets voice (sample) playback frequency (P1=Hz)   *		_GUS_VOICEVOL	- Sets voice volume (P1=volume, 0xfff=max, 0xeff=half, 0x000=off)   *		_GUS_VOICEVOL2	- Sets voice volume (P1=volume, 0xfff=max, 0xeff=half, 0x000=off) diff --git a/include/linux/usb/cdc.h b/include/linux/usb/cdc.h index 3c86ed25a04..c24124a42ce 100644 --- a/include/linux/usb/cdc.h +++ b/include/linux/usb/cdc.h @@ -17,6 +17,7 @@  #define USB_CDC_SUBCLASS_DMM			0x09  #define USB_CDC_SUBCLASS_MDLM			0x0a  #define USB_CDC_SUBCLASS_OBEX			0x0b +#define USB_CDC_SUBCLASS_EEM			0x0c  #define USB_CDC_PROTO_NONE			0 @@ -28,6 +29,8 @@  #define USB_CDC_ACM_PROTO_AT_CDMA		6  #define USB_CDC_ACM_PROTO_VENDOR		0xff +#define USB_CDC_PROTO_EEM			7 +  /*-------------------------------------------------------------------------*/  /* diff --git a/include/linux/usb/serial.h b/include/linux/usb/serial.h index 625e9e4639c..8cdfed738fe 100644 --- a/include/linux/usb/serial.h +++ b/include/linux/usb/serial.h @@ -224,8 +224,7 @@ struct usb_serial_driver {  	/* Called by console with tty = NULL and by tty */  	int  (*open)(struct tty_struct *tty,  			struct usb_serial_port *port, struct file *filp); -	void (*close)(struct tty_struct *tty, -			struct usb_serial_port *port, struct file *filp); +	void (*close)(struct usb_serial_port *port);  	int  (*write)(struct tty_struct *tty, struct usb_serial_port *port,  			const unsigned char *buf, int count);  	/* Called only by the tty layer */ @@ -241,6 +240,10 @@ struct usb_serial_driver {  	int  (*tiocmget)(struct tty_struct *tty, struct file *file);  	int  (*tiocmset)(struct tty_struct *tty, struct file *file,  			 unsigned int set, unsigned int clear); +	/* Called by the tty layer for port level work. There may or may not +	   be an attached tty at this point */ +	void (*dtr_rts)(struct usb_serial_port *port, int on); +	int  (*carrier_raised)(struct usb_serial_port *port);  	/* USB events */  	void (*read_int_callback)(struct urb *urb);  	void (*write_int_callback)(struct urb *urb); @@ -283,8 +286,7 @@ extern int usb_serial_generic_open(struct tty_struct *tty,  		struct usb_serial_port *port, struct file *filp);  extern int usb_serial_generic_write(struct tty_struct *tty,  	struct usb_serial_port *port, const unsigned char *buf, int count); -extern void usb_serial_generic_close(struct tty_struct *tty, -			struct usb_serial_port *port, struct file *filp); +extern void usb_serial_generic_close(struct usb_serial_port *port);  extern int usb_serial_generic_resume(struct usb_serial *serial);  extern int usb_serial_generic_write_room(struct tty_struct *tty);  extern int usb_serial_generic_chars_in_buffer(struct tty_struct *tty); diff --git a/include/linux/usb/usbnet.h b/include/linux/usb/usbnet.h index 36fabb95c7d..5d44059f6d6 100644 --- a/include/linux/usb/usbnet.h +++ b/include/linux/usb/usbnet.h @@ -183,6 +183,7 @@ extern void usbnet_tx_timeout (struct net_device *net);  extern int usbnet_change_mtu (struct net_device *net, int new_mtu);  extern int usbnet_get_endpoints(struct usbnet *, struct usb_interface *); +extern int usbnet_get_ethernet_addr(struct usbnet *, int);  extern void usbnet_defer_kevent (struct usbnet *, int);  extern void usbnet_skb_return (struct usbnet *, struct sk_buff *);  extern void usbnet_unlink_rx_urbs(struct usbnet *); diff --git a/include/linux/virtio.h b/include/linux/virtio.h index 06005fa9e98..4fca4f5440b 100644 --- a/include/linux/virtio.h +++ b/include/linux/virtio.h @@ -10,14 +10,17 @@  /**   * virtqueue - a queue to register buffers for sending or receiving. + * @list: the chain of virtqueues for this device   * @callback: the function to call when buffers are consumed (can be NULL). + * @name: the name of this virtqueue (mainly for debugging)   * @vdev: the virtio device this queue was created for.   * @vq_ops: the operations for this virtqueue (see below).   * @priv: a pointer for the virtqueue implementation to use.   */ -struct virtqueue -{ +struct virtqueue { +	struct list_head list;  	void (*callback)(struct virtqueue *vq); +	const char *name;  	struct virtio_device *vdev;  	struct virtqueue_ops *vq_ops;  	void *priv; @@ -76,15 +79,16 @@ struct virtqueue_ops {   * @dev: underlying device.   * @id: the device type identification (used to match it with a driver).   * @config: the configuration ops for this device. + * @vqs: the list of virtqueues for this device.   * @features: the features supported by both driver and device.   * @priv: private pointer for the driver's use.   */ -struct virtio_device -{ +struct virtio_device {  	int index;  	struct device dev;  	struct virtio_device_id id;  	struct virtio_config_ops *config; +	struct list_head vqs;  	/* Note that this is a Linux set_bit-style bitmap. */  	unsigned long features[1];  	void *priv; @@ -99,8 +103,7 @@ void unregister_virtio_device(struct virtio_device *dev);   * @id_table: the ids serviced by this driver.   * @feature_table: an array of feature numbers supported by this device.   * @feature_table_size: number of entries in the feature table array. - * @probe: the function to call when a device is found.  Returns a token for - *    remove, or PTR_ERR(). + * @probe: the function to call when a device is found.  Returns 0 or -errno.   * @remove: the function when a device is removed.   * @config_changed: optional function to call when the device configuration   *    changes; may be called in interrupt context. diff --git a/include/linux/virtio_blk.h b/include/linux/virtio_blk.h index 94c56d29869..be7d255fc7c 100644 --- a/include/linux/virtio_blk.h +++ b/include/linux/virtio_blk.h @@ -15,6 +15,10 @@  #define VIRTIO_BLK_F_GEOMETRY	4	/* Legacy geometry available  */  #define VIRTIO_BLK_F_RO		5	/* Disk is read-only */  #define VIRTIO_BLK_F_BLK_SIZE	6	/* Block size of disk is available*/ +#define VIRTIO_BLK_F_SCSI	7	/* Supports scsi command passthru */ +#define VIRTIO_BLK_F_IDENTIFY	8	/* ATA IDENTIFY supported */ + +#define VIRTIO_BLK_ID_BYTES	(sizeof(__u16[256]))	/* IDENTIFY DATA */  struct virtio_blk_config  { @@ -32,6 +36,7 @@ struct virtio_blk_config  	} geometry;  	/* block size of device (if VIRTIO_BLK_F_BLK_SIZE) */  	__u32 blk_size; +	__u8 identify[VIRTIO_BLK_ID_BYTES];  } __attribute__((packed));  /* These two define direction. */ @@ -55,6 +60,13 @@ struct virtio_blk_outhdr  	__u64 sector;  }; +struct virtio_scsi_inhdr { +	__u32 errors; +	__u32 data_len; +	__u32 sense_len; +	__u32 residual; +}; +  /* And this is the final byte of the write scatter-gather list. */  #define VIRTIO_BLK_S_OK		0  #define VIRTIO_BLK_S_IOERR	1 diff --git a/include/linux/virtio_config.h b/include/linux/virtio_config.h index bf8ec283b23..99f514575f6 100644 --- a/include/linux/virtio_config.h +++ b/include/linux/virtio_config.h @@ -29,6 +29,7 @@  #define VIRTIO_F_NOTIFY_ON_EMPTY	24  #ifdef __KERNEL__ +#include <linux/err.h>  #include <linux/virtio.h>  /** @@ -49,15 +50,26 @@   * @set_status: write the status byte   *	vdev: the virtio_device   *	status: the new status byte + * @request_vqs: request the specified number of virtqueues + *	vdev: the virtio_device + *	max_vqs: the max number of virtqueues we want + *      If supplied, must call before any virtqueues are instantiated. + *      To modify the max number of virtqueues after request_vqs has been + *      called, call free_vqs and then request_vqs with a new value. + * @free_vqs: cleanup resources allocated by request_vqs + *	vdev: the virtio_device + *      If supplied, must call after all virtqueues have been deleted.   * @reset: reset the device   *	vdev: the virtio device   *	After this, status and feature negotiation must be done again - * @find_vq: find a virtqueue and instantiate it. + * @find_vqs: find virtqueues and instantiate them.   *	vdev: the virtio_device - *	index: the 0-based virtqueue number in case there's more than one. - *	callback: the virqtueue callback - *	Returns the new virtqueue or ERR_PTR() (eg. -ENOENT). - * @del_vq: free a virtqueue found by find_vq(). + *	nvqs: the number of virtqueues to find + *	vqs: on success, includes new virtqueues + *	callbacks: array of callbacks, for each virtqueue + *	names: array of virtqueue names (mainly for debugging) + *	Returns 0 on success or error status + * @del_vqs: free virtqueues found by find_vqs().   * @get_features: get the array of feature bits for this device.   *	vdev: the virtio_device   *	Returns the first 32 feature bits (all we currently need). @@ -66,6 +78,7 @@   *	This gives the final feature bits for the device: it can change   *	the dev->feature bits if it wants.   */ +typedef void vq_callback_t(struct virtqueue *);  struct virtio_config_ops  {  	void (*get)(struct virtio_device *vdev, unsigned offset, @@ -75,10 +88,11 @@ struct virtio_config_ops  	u8 (*get_status)(struct virtio_device *vdev);  	void (*set_status)(struct virtio_device *vdev, u8 status);  	void (*reset)(struct virtio_device *vdev); -	struct virtqueue *(*find_vq)(struct virtio_device *vdev, -				     unsigned index, -				     void (*callback)(struct virtqueue *)); -	void (*del_vq)(struct virtqueue *vq); +	int (*find_vqs)(struct virtio_device *, unsigned nvqs, +			struct virtqueue *vqs[], +			vq_callback_t *callbacks[], +			const char *names[]); +	void (*del_vqs)(struct virtio_device *);  	u32 (*get_features)(struct virtio_device *vdev);  	void (*finalize_features)(struct virtio_device *vdev);  }; @@ -99,7 +113,9 @@ static inline bool virtio_has_feature(const struct virtio_device *vdev,  	if (__builtin_constant_p(fbit))  		BUILD_BUG_ON(fbit >= 32); -	virtio_check_driver_offered_feature(vdev, fbit); +	if (fbit < VIRTIO_TRANSPORT_F_START) +		virtio_check_driver_offered_feature(vdev, fbit); +  	return test_bit(fbit, vdev->features);  } @@ -126,5 +142,18 @@ static inline int virtio_config_buf(struct virtio_device *vdev,  	vdev->config->get(vdev, offset, buf, len);  	return 0;  } + +static inline +struct virtqueue *virtio_find_single_vq(struct virtio_device *vdev, +					vq_callback_t *c, const char *n) +{ +	vq_callback_t *callbacks[] = { c }; +	const char *names[] = { n }; +	struct virtqueue *vq; +	int err = vdev->config->find_vqs(vdev, 1, &vq, callbacks, names); +	if (err < 0) +		return ERR_PTR(err); +	return vq; +}  #endif /* __KERNEL__ */  #endif /* _LINUX_VIRTIO_CONFIG_H */ diff --git a/include/linux/virtio_net.h b/include/linux/virtio_net.h index 242348bb376..cec79adbe3e 100644 --- a/include/linux/virtio_net.h +++ b/include/linux/virtio_net.h @@ -4,6 +4,7 @@   * compatible drivers/servers. */  #include <linux/types.h>  #include <linux/virtio_config.h> +#include <linux/if_ether.h>  /* The ID for virtio_net */  #define VIRTIO_ID_NET	1 diff --git a/include/linux/virtio_pci.h b/include/linux/virtio_pci.h index cd0fd5d181a..9a3d7c48c62 100644 --- a/include/linux/virtio_pci.h +++ b/include/linux/virtio_pci.h @@ -47,9 +47,17 @@  /* The bit of the ISR which indicates a device configuration change. */  #define VIRTIO_PCI_ISR_CONFIG		0x2 +/* MSI-X registers: only enabled if MSI-X is enabled. */ +/* A 16-bit vector for configuration changes. */ +#define VIRTIO_MSI_CONFIG_VECTOR        20 +/* A 16-bit vector for selected queue notifications. */ +#define VIRTIO_MSI_QUEUE_VECTOR         22 +/* Vector value used to disable MSI for queue */ +#define VIRTIO_MSI_NO_VECTOR            0xffff +  /* The remaining space is defined by each driver as the per-driver   * configuration space */ -#define VIRTIO_PCI_CONFIG		20 +#define VIRTIO_PCI_CONFIG(dev)		((dev)->msix_enabled ? 24 : 20)  /* Virtio ABI version, this must match exactly */  #define VIRTIO_PCI_ABI_VERSION		0 diff --git a/include/linux/virtio_ring.h b/include/linux/virtio_ring.h index 71e03722fb5..693e0ec5afa 100644 --- a/include/linux/virtio_ring.h +++ b/include/linux/virtio_ring.h @@ -14,6 +14,8 @@  #define VRING_DESC_F_NEXT	1  /* This marks a buffer as write-only (otherwise read-only). */  #define VRING_DESC_F_WRITE	2 +/* This means the buffer contains a list of buffer descriptors. */ +#define VRING_DESC_F_INDIRECT	4  /* The Host uses this in used->flags to advise the Guest: don't kick me when   * you add a buffer.  It's unreliable, so it's simply an optimization.  Guest @@ -24,6 +26,9 @@   * optimization.  */  #define VRING_AVAIL_F_NO_INTERRUPT	1 +/* We support indirect buffer descriptors */ +#define VIRTIO_RING_F_INDIRECT_DESC	28 +  /* Virtio ring descriptors: 16 bytes.  These can chain together via "next". */  struct vring_desc  { @@ -119,7 +124,8 @@ struct virtqueue *vring_new_virtqueue(unsigned int num,  				      struct virtio_device *vdev,  				      void *pages,  				      void (*notify)(struct virtqueue *vq), -				      void (*callback)(struct virtqueue *vq)); +				      void (*callback)(struct virtqueue *vq), +				      const char *name);  void vring_del_virtqueue(struct virtqueue *vq);  /* Filter out transport-specific feature bits. */  void vring_transport_features(struct virtio_device *vdev); diff --git a/include/linux/wait.h b/include/linux/wait.h index bc024632f36..6788e1a4d4c 100644 --- a/include/linux/wait.h +++ b/include/linux/wait.h @@ -132,8 +132,6 @@ static inline void __remove_wait_queue(wait_queue_head_t *head,  	list_del(&old->task_list);  } -void __wake_up_common(wait_queue_head_t *q, unsigned int mode, -			int nr_exclusive, int sync, void *key);  void __wake_up(wait_queue_head_t *q, unsigned int mode, int nr, void *key);  void __wake_up_locked_key(wait_queue_head_t *q, unsigned int mode, void *key);  void __wake_up_sync_key(wait_queue_head_t *q, unsigned int mode, int nr, diff --git a/include/linux/wimax.h b/include/linux/wimax.h index c89de7f4e5b..4fdcc563551 100644 --- a/include/linux/wimax.h +++ b/include/linux/wimax.h @@ -59,7 +59,7 @@ enum {  	 * M - Major: change if removing or modifying an existing call.  	 * m - minor: change when adding a new call  	 */ -	WIMAX_GNL_VERSION = 00, +	WIMAX_GNL_VERSION = 01,  	/* Generic NetLink attributes */  	WIMAX_GNL_ATTR_INVALID = 0x00,  	WIMAX_GNL_ATTR_MAX = 10, @@ -78,6 +78,7 @@ enum {  	WIMAX_GNL_OP_RFKILL,	/* Run wimax_rfkill() */  	WIMAX_GNL_OP_RESET,	/* Run wimax_rfkill() */  	WIMAX_GNL_RE_STATE_CHANGE,	/* Report: status change */ +	WIMAX_GNL_OP_STATE_GET,		/* Request for current state */  }; @@ -113,6 +114,10 @@ enum {  	WIMAX_GNL_RESET_IFIDX = 1,  }; +/* Atributes for wimax_state_get() */ +enum { +	WIMAX_GNL_STGET_IFIDX = 1, +};  /*   * Attributes for the Report State Change diff --git a/include/linux/wimax/i2400m.h b/include/linux/wimax/i2400m.h index d5148a7889a..433693ef2bb 100644 --- a/include/linux/wimax/i2400m.h +++ b/include/linux/wimax/i2400m.h @@ -266,7 +266,7 @@ enum i2400m_ro_type {  /* Misc constants */  enum { -	I2400M_PL_PAD = 16,	/* Payload data size alignment */ +	I2400M_PL_ALIGN = 16,	/* Payload data size alignment */  	I2400M_PL_SIZE_MAX = 0x3EFF,  	I2400M_MAX_PLS_IN_MSG = 60,  	/* protocol barkers: sync sequences; for notifications they diff --git a/include/linux/writeback.h b/include/linux/writeback.h index 9c1ed1fb6dd..3224820c851 100644 --- a/include/linux/writeback.h +++ b/include/linux/writeback.h @@ -79,7 +79,6 @@ struct writeback_control {  void writeback_inodes(struct writeback_control *wbc);  int inode_wait(void *);  void sync_inodes_sb(struct super_block *, int wait); -void sync_inodes(int wait);  /* writeback.h requires fs.h; it, too, is not included from here. */  static inline void wait_on_inode(struct inode *inode) @@ -168,8 +167,6 @@ void writeback_set_ratelimit(void);  /* pdflush.c */  extern int nr_pdflush_threads;	/* Global so it can be exported to sysctl  				   read-only. */ -extern int nr_pdflush_threads_max; /* Global so it can be exported to sysctl */ -extern int nr_pdflush_threads_min; /* Global so it can be exported to sysctl */  #endif		/* WRITEBACK_H */ | 
