diff options
Diffstat (limited to 'include')
135 files changed, 878 insertions, 637 deletions
| diff --git a/include/acpi/acpi_bus.h b/include/acpi/acpi_bus.h index f849be28e082..c9608b0b80c6 100644 --- a/include/acpi/acpi_bus.h +++ b/include/acpi/acpi_bus.h @@ -91,6 +91,9 @@ acpi_evaluate_dsm_typed(acpi_handle handle, const guid_t *guid, u64 rev,  bool acpi_dev_found(const char *hid);  bool acpi_dev_present(const char *hid, const char *uid, s64 hrv); +const char * +acpi_dev_get_first_match_name(const char *hid, const char *uid, s64 hrv); +  #ifdef CONFIG_ACPI  #include <linux/proc_fs.h> @@ -105,6 +108,7 @@ enum acpi_bus_device_type {  	ACPI_BUS_TYPE_THERMAL,  	ACPI_BUS_TYPE_POWER_BUTTON,  	ACPI_BUS_TYPE_SLEEP_BUTTON, +	ACPI_BUS_TYPE_ECDT_EC,  	ACPI_BUS_DEVICE_TYPE_COUNT  }; diff --git a/include/acpi/acpi_drivers.h b/include/acpi/acpi_drivers.h index 29c691265b49..14499757338f 100644 --- a/include/acpi/acpi_drivers.h +++ b/include/acpi/acpi_drivers.h @@ -58,6 +58,7 @@  #define ACPI_VIDEO_HID			"LNXVIDEO"  #define ACPI_BAY_HID			"LNXIOBAY"  #define ACPI_DOCK_HID			"LNXDOCK" +#define ACPI_ECDT_HID			"LNXEC"  /* Quirk for broken IBM BIOSes */  #define ACPI_SMBUS_IBM_HID		"SMBUSIBM" diff --git a/include/asm-generic/mm_hooks.h b/include/asm-generic/mm_hooks.h index ea189d88a3cc..8ac4e68a12f0 100644 --- a/include/asm-generic/mm_hooks.h +++ b/include/asm-generic/mm_hooks.h @@ -7,9 +7,10 @@  #ifndef _ASM_GENERIC_MM_HOOKS_H  #define _ASM_GENERIC_MM_HOOKS_H -static inline void arch_dup_mmap(struct mm_struct *oldmm, -				 struct mm_struct *mm) +static inline int arch_dup_mmap(struct mm_struct *oldmm, +				struct mm_struct *mm)  { +	return 0;  }  static inline void arch_exit_mmap(struct mm_struct *mm) diff --git a/include/asm-generic/pgtable.h b/include/asm-generic/pgtable.h index 757dc6ffc7ba..868e68561f91 100644 --- a/include/asm-generic/pgtable.h +++ b/include/asm-generic/pgtable.h @@ -805,15 +805,23 @@ static inline int pmd_trans_huge(pmd_t pmd)  {  	return 0;  } -#ifndef __HAVE_ARCH_PMD_WRITE +#ifndef pmd_write  static inline int pmd_write(pmd_t pmd)  {  	BUG();  	return 0;  } -#endif /* __HAVE_ARCH_PMD_WRITE */ +#endif /* pmd_write */  #endif /* CONFIG_TRANSPARENT_HUGEPAGE */ +#ifndef pud_write +static inline int pud_write(pud_t pud) +{ +	BUG(); +	return 0; +} +#endif /* pud_write */ +  #if !defined(CONFIG_TRANSPARENT_HUGEPAGE) || \  	(defined(CONFIG_TRANSPARENT_HUGEPAGE) && \  	 !defined(CONFIG_HAVE_ARCH_TRANSPARENT_HUGEPAGE_PUD)) @@ -1017,6 +1025,11 @@ static inline int pmd_clear_huge(pmd_t *pmd)  struct file;  int phys_mem_access_prot_allowed(struct file *file, unsigned long pfn,  			unsigned long size, pgprot_t *vma_prot); + +#ifndef CONFIG_X86_ESPFIX64 +static inline void init_espfix_bsp(void) { } +#endif +  #endif /* !__ASSEMBLY__ */  #ifndef io_remap_pfn_range diff --git a/include/crypto/if_alg.h b/include/crypto/if_alg.h index 6abf0a3604dc..f38227a78eae 100644 --- a/include/crypto/if_alg.h +++ b/include/crypto/if_alg.h @@ -18,6 +18,7 @@  #include <linux/if_alg.h>  #include <linux/scatterlist.h>  #include <linux/types.h> +#include <linux/atomic.h>  #include <net/sock.h>  #include <crypto/aead.h> @@ -150,7 +151,7 @@ struct af_alg_ctx {  	struct crypto_wait wait;  	size_t used; -	size_t rcvused; +	atomic_t rcvused;  	bool more;  	bool merge; @@ -215,7 +216,7 @@ static inline int af_alg_rcvbuf(struct sock *sk)  	struct af_alg_ctx *ctx = ask->private;  	return max_t(int, max_t(int, sk->sk_rcvbuf & PAGE_MASK, PAGE_SIZE) - -			  ctx->rcvused, 0); +		     atomic_read(&ctx->rcvused), 0);  }  /** @@ -242,6 +243,7 @@ int af_alg_sendmsg(struct socket *sock, struct msghdr *msg, size_t size,  		   unsigned int ivsize);  ssize_t af_alg_sendpage(struct socket *sock, struct page *page,  			int offset, size_t size, int flags); +void af_alg_free_resources(struct af_alg_async_req *areq);  void af_alg_async_cb(struct crypto_async_request *_req, int err);  unsigned int af_alg_poll(struct file *file, struct socket *sock,  			 poll_table *wait); diff --git a/include/crypto/internal/hash.h b/include/crypto/internal/hash.h index f0b44c16e88f..c2bae8da642c 100644 --- a/include/crypto/internal/hash.h +++ b/include/crypto/internal/hash.h @@ -82,6 +82,14 @@ int ahash_register_instance(struct crypto_template *tmpl,  			    struct ahash_instance *inst);  void ahash_free_instance(struct crypto_instance *inst); +int shash_no_setkey(struct crypto_shash *tfm, const u8 *key, +		    unsigned int keylen); + +static inline bool crypto_shash_alg_has_setkey(struct shash_alg *alg) +{ +	return alg->setkey != shash_no_setkey; +} +  int crypto_init_ahash_spawn(struct crypto_ahash_spawn *spawn,  			    struct hash_alg_common *alg,  			    struct crypto_instance *inst); diff --git a/include/crypto/mcryptd.h b/include/crypto/mcryptd.h index cceafa01f907..b67404fc4b34 100644 --- a/include/crypto/mcryptd.h +++ b/include/crypto/mcryptd.h @@ -27,6 +27,7 @@ static inline struct mcryptd_ahash *__mcryptd_ahash_cast(  struct mcryptd_cpu_queue {  	struct crypto_queue queue; +	spinlock_t q_lock;  	struct work_struct work;  }; diff --git a/include/drm/drm_connector.h b/include/drm/drm_connector.h index df9807a3caae..5971577016a2 100644 --- a/include/drm/drm_connector.h +++ b/include/drm/drm_connector.h @@ -24,6 +24,7 @@  #define __DRM_CONNECTOR_H__  #include <linux/list.h> +#include <linux/llist.h>  #include <linux/ctype.h>  #include <linux/hdmi.h>  #include <drm/drm_mode_object.h> @@ -916,6 +917,15 @@ struct drm_connector {  	uint8_t num_h_tile, num_v_tile;  	uint8_t tile_h_loc, tile_v_loc;  	uint16_t tile_h_size, tile_v_size; + +	/** +	 * @free_node: +	 * +	 * List used only by &drm_connector_iter to be able to clean up a +	 * connector from any context, in conjunction with +	 * &drm_mode_config.connector_free_work. +	 */ +	struct llist_node free_node;  };  #define obj_to_connector(x) container_of(x, struct drm_connector, base) diff --git a/include/drm/drm_edid.h b/include/drm/drm_edid.h index 6f35909b8add..efe6d5a8e834 100644 --- a/include/drm/drm_edid.h +++ b/include/drm/drm_edid.h @@ -362,7 +362,8 @@ void  drm_hdmi_avi_infoframe_quant_range(struct hdmi_avi_infoframe *frame,  				   const struct drm_display_mode *mode,  				   enum hdmi_quantization_range rgb_quant_range, -				   bool rgb_quant_range_selectable); +				   bool rgb_quant_range_selectable, +				   bool is_hdmi2_sink);  /**   * drm_eld_mnl - Get ELD monitor name length in bytes. @@ -464,6 +465,8 @@ struct edid *drm_get_edid(struct drm_connector *connector,  struct edid *drm_get_edid_switcheroo(struct drm_connector *connector,  				     struct i2c_adapter *adapter);  struct edid *drm_edid_duplicate(const struct edid *edid); +void drm_reset_display_info(struct drm_connector *connector); +u32 drm_add_display_info(struct drm_connector *connector, const struct edid *edid);  int drm_add_edid_modes(struct drm_connector *connector, struct edid *edid);  u8 drm_match_cea_mode(const struct drm_display_mode *to_match); diff --git a/include/drm/drm_mode_config.h b/include/drm/drm_mode_config.h index b21e827c5c78..b0ce26d71296 100644 --- a/include/drm/drm_mode_config.h +++ b/include/drm/drm_mode_config.h @@ -27,6 +27,7 @@  #include <linux/types.h>  #include <linux/idr.h>  #include <linux/workqueue.h> +#include <linux/llist.h>  #include <drm/drm_modeset_lock.h> @@ -393,7 +394,7 @@ struct drm_mode_config {  	/**  	 * @connector_list_lock: Protects @num_connector and -	 * @connector_list. +	 * @connector_list and @connector_free_list.  	 */  	spinlock_t connector_list_lock;  	/** @@ -414,6 +415,21 @@ struct drm_mode_config {  	 */  	struct list_head connector_list;  	/** +	 * @connector_free_list: +	 * +	 * List of connector objects linked with &drm_connector.free_head. +	 * Protected by @connector_list_lock. Used by +	 * drm_for_each_connector_iter() and +	 * &struct drm_connector_list_iter to savely free connectors using +	 * @connector_free_work. +	 */ +	struct llist_head connector_free_list; +	/** +	 * @connector_free_work: Work to clean up @connector_free_list. +	 */ +	struct work_struct connector_free_work; + +	/**  	 * @num_encoder:  	 *  	 * Number of encoders on this device. This is invariant over the diff --git a/include/drm/ttm/ttm_page_alloc.h b/include/drm/ttm/ttm_page_alloc.h index 38a2b4770c35..593811362a91 100644 --- a/include/drm/ttm/ttm_page_alloc.h +++ b/include/drm/ttm/ttm_page_alloc.h @@ -59,11 +59,20 @@ int ttm_pool_populate(struct ttm_tt *ttm);  void ttm_pool_unpopulate(struct ttm_tt *ttm);  /** + * Populates and DMA maps pages to fullfil a ttm_dma_populate() request + */ +int ttm_populate_and_map_pages(struct device *dev, struct ttm_dma_tt *tt); + +/** + * Unpopulates and DMA unmaps pages as part of a + * ttm_dma_unpopulate() request */ +void ttm_unmap_and_unpopulate_pages(struct device *dev, struct ttm_dma_tt *tt); + +/**   * Output the state of pools to debugfs file   */  int ttm_page_alloc_debugfs(struct seq_file *m, void *data); -  #if defined(CONFIG_SWIOTLB) || defined(CONFIG_INTEL_IOMMU)  /**   * Initialize pool allocator. @@ -83,17 +92,6 @@ int ttm_dma_page_alloc_debugfs(struct seq_file *m, void *data);  int ttm_dma_populate(struct ttm_dma_tt *ttm_dma, struct device *dev);  void ttm_dma_unpopulate(struct ttm_dma_tt *ttm_dma, struct device *dev); - -/** - * Populates and DMA maps pages to fullfil a ttm_dma_populate() request - */ -int ttm_populate_and_map_pages(struct device *dev, struct ttm_dma_tt *tt); - -/** - * Unpopulates and DMA unmaps pages as part of a - * ttm_dma_unpopulate() request */ -void ttm_unmap_and_unpopulate_pages(struct device *dev, struct ttm_dma_tt *tt); -  #else  static inline int ttm_dma_page_alloc_init(struct ttm_mem_global *glob,  					  unsigned max_pages) @@ -116,16 +114,6 @@ static inline void ttm_dma_unpopulate(struct ttm_dma_tt *ttm_dma,  				      struct device *dev)  {  } - -static inline int ttm_populate_and_map_pages(struct device *dev, struct ttm_dma_tt *tt) -{ -	return -ENOMEM; -} - -static inline void ttm_unmap_and_unpopulate_pages(struct device *dev, struct ttm_dma_tt *tt) -{ -} -  #endif  #endif diff --git a/include/kvm/arm_arch_timer.h b/include/kvm/arm_arch_timer.h index 01ee473517e2..9da6ce22803f 100644 --- a/include/kvm/arm_arch_timer.h +++ b/include/kvm/arm_arch_timer.h @@ -62,7 +62,7 @@ struct arch_timer_cpu {  	bool			enabled;  }; -int kvm_timer_hyp_init(void); +int kvm_timer_hyp_init(bool);  int kvm_timer_enable(struct kvm_vcpu *vcpu);  int kvm_timer_vcpu_reset(struct kvm_vcpu *vcpu);  void kvm_timer_vcpu_init(struct kvm_vcpu *vcpu); @@ -93,7 +93,4 @@ void kvm_timer_init_vhe(void);  #define vcpu_vtimer(v)	(&(v)->arch.timer_cpu.vtimer)  #define vcpu_ptimer(v)	(&(v)->arch.timer_cpu.ptimer) -void enable_el1_phys_timer_access(void); -void disable_el1_phys_timer_access(void); -  #endif diff --git a/include/linux/acpi.h b/include/linux/acpi.h index dc1ebfeeb5ec..d918f1ea84e6 100644 --- a/include/linux/acpi.h +++ b/include/linux/acpi.h @@ -640,6 +640,12 @@ static inline bool acpi_dev_present(const char *hid, const char *uid, s64 hrv)  	return false;  } +static inline const char * +acpi_dev_get_first_match_name(const char *hid, const char *uid, s64 hrv) +{ +	return NULL; +} +  static inline bool is_acpi_node(struct fwnode_handle *fwnode)  {  	return false; diff --git a/include/linux/bio.h b/include/linux/bio.h index 82f0c8fd7be8..23d29b39f71e 100644 --- a/include/linux/bio.h +++ b/include/linux/bio.h @@ -492,6 +492,8 @@ extern unsigned int bvec_nr_vecs(unsigned short idx);  #define bio_set_dev(bio, bdev) 			\  do {						\ +	if ((bio)->bi_disk != (bdev)->bd_disk)	\ +		bio_clear_flag(bio, BIO_THROTTLED);\  	(bio)->bi_disk = (bdev)->bd_disk;	\  	(bio)->bi_partno = (bdev)->bd_partno;	\  } while (0) diff --git a/include/linux/blk_types.h b/include/linux/blk_types.h index a1e628e032da..9e7d8bd776d2 100644 --- a/include/linux/blk_types.h +++ b/include/linux/blk_types.h @@ -50,8 +50,6 @@ struct blk_issue_stat {  struct bio {  	struct bio		*bi_next;	/* request queue link */  	struct gendisk		*bi_disk; -	u8			bi_partno; -	blk_status_t		bi_status;  	unsigned int		bi_opf;		/* bottom bits req flags,  						 * top bits REQ_OP. Use  						 * accessors. @@ -59,8 +57,8 @@ struct bio {  	unsigned short		bi_flags;	/* status, etc and bvec pool number */  	unsigned short		bi_ioprio;  	unsigned short		bi_write_hint; - -	struct bvec_iter	bi_iter; +	blk_status_t		bi_status; +	u8			bi_partno;  	/* Number of segments in this BIO after  	 * physical address coalescing is performed. @@ -74,8 +72,9 @@ struct bio {  	unsigned int		bi_seg_front_size;  	unsigned int		bi_seg_back_size; -	atomic_t		__bi_remaining; +	struct bvec_iter	bi_iter; +	atomic_t		__bi_remaining;  	bio_end_io_t		*bi_end_io;  	void			*bi_private; diff --git a/include/linux/blkdev.h b/include/linux/blkdev.h index 8089ca17db9a..0ce8a372d506 100644 --- a/include/linux/blkdev.h +++ b/include/linux/blkdev.h @@ -135,7 +135,7 @@ typedef __u32 __bitwise req_flags_t;  struct request {  	struct list_head queuelist;  	union { -		call_single_data_t csd; +		struct __call_single_data csd;  		u64 fifo_time;  	}; @@ -241,14 +241,24 @@ struct request {  	struct request *next_rq;  }; +static inline bool blk_op_is_scsi(unsigned int op) +{ +	return op == REQ_OP_SCSI_IN || op == REQ_OP_SCSI_OUT; +} + +static inline bool blk_op_is_private(unsigned int op) +{ +	return op == REQ_OP_DRV_IN || op == REQ_OP_DRV_OUT; +} +  static inline bool blk_rq_is_scsi(struct request *rq)  { -	return req_op(rq) == REQ_OP_SCSI_IN || req_op(rq) == REQ_OP_SCSI_OUT; +	return blk_op_is_scsi(req_op(rq));  }  static inline bool blk_rq_is_private(struct request *rq)  { -	return req_op(rq) == REQ_OP_DRV_IN || req_op(rq) == REQ_OP_DRV_OUT; +	return blk_op_is_private(req_op(rq));  }  static inline bool blk_rq_is_passthrough(struct request *rq) @@ -256,6 +266,13 @@ static inline bool blk_rq_is_passthrough(struct request *rq)  	return blk_rq_is_scsi(rq) || blk_rq_is_private(rq);  } +static inline bool bio_is_passthrough(struct bio *bio) +{ +	unsigned op = bio_op(bio); + +	return blk_op_is_scsi(op) || blk_op_is_private(op); +} +  static inline unsigned short req_get_ioprio(struct request *req)  {  	return req->ioprio; @@ -948,7 +965,7 @@ extern int blk_rq_prep_clone(struct request *rq, struct request *rq_src,  extern void blk_rq_unprep_clone(struct request *rq);  extern blk_status_t blk_insert_cloned_request(struct request_queue *q,  				     struct request *rq); -extern int blk_rq_append_bio(struct request *rq, struct bio *bio); +extern int blk_rq_append_bio(struct request *rq, struct bio **bio);  extern void blk_delay_queue(struct request_queue *, unsigned long);  extern void blk_queue_split(struct request_queue *, struct bio **);  extern void blk_recount_segments(struct request_queue *, struct bio *); diff --git a/include/linux/bpf.h b/include/linux/bpf.h index e55e4255a210..0b25cf87b6d6 100644 --- a/include/linux/bpf.h +++ b/include/linux/bpf.h @@ -43,7 +43,14 @@ struct bpf_map_ops {  };  struct bpf_map { -	atomic_t refcnt; +	/* 1st cacheline with read-mostly members of which some +	 * are also accessed in fast-path (e.g. ops, max_entries). +	 */ +	const struct bpf_map_ops *ops ____cacheline_aligned; +	struct bpf_map *inner_map_meta; +#ifdef CONFIG_SECURITY +	void *security; +#endif  	enum bpf_map_type map_type;  	u32 key_size;  	u32 value_size; @@ -52,15 +59,17 @@ struct bpf_map {  	u32 pages;  	u32 id;  	int numa_node; -	struct user_struct *user; -	const struct bpf_map_ops *ops; -	struct work_struct work; +	bool unpriv_array; +	/* 7 bytes hole */ + +	/* 2nd cacheline with misc members to avoid false sharing +	 * particularly with refcounting. +	 */ +	struct user_struct *user ____cacheline_aligned; +	atomic_t refcnt;  	atomic_t usercnt; -	struct bpf_map *inner_map_meta; +	struct work_struct work;  	char name[BPF_OBJ_NAME_LEN]; -#ifdef CONFIG_SECURITY -	void *security; -#endif  };  /* function argument constraints */ @@ -221,6 +230,7 @@ struct bpf_prog_aux {  struct bpf_array {  	struct bpf_map map;  	u32 elem_size; +	u32 index_mask;  	/* 'ownership' of prog_array is claimed by the first program that  	 * is going to use this map or by the first program which FD is stored  	 * in the map to make sure that all callers and callees have the same @@ -419,6 +429,8 @@ static inline int bpf_map_attr_numa_node(const union bpf_attr *attr)  		attr->numa_node : NUMA_NO_NODE;  } +struct bpf_prog *bpf_prog_get_type_path(const char *name, enum bpf_prog_type type); +  #else /* !CONFIG_BPF_SYSCALL */  static inline struct bpf_prog *bpf_prog_get(u32 ufd)  { @@ -506,6 +518,12 @@ static inline int cpu_map_enqueue(struct bpf_cpu_map_entry *rcpu,  {  	return 0;  } + +static inline struct bpf_prog *bpf_prog_get_type_path(const char *name, +				enum bpf_prog_type type) +{ +	return ERR_PTR(-EOPNOTSUPP); +}  #endif /* CONFIG_BPF_SYSCALL */  static inline struct bpf_prog *bpf_prog_get_type(u32 ufd, @@ -514,6 +532,8 @@ static inline struct bpf_prog *bpf_prog_get_type(u32 ufd,  	return bpf_prog_get_type_dev(ufd, type, false);  } +bool bpf_prog_get_ok(struct bpf_prog *, enum bpf_prog_type *, bool); +  int bpf_prog_offload_compile(struct bpf_prog *prog);  void bpf_prog_offload_destroy(struct bpf_prog *prog); diff --git a/include/linux/bpf_verifier.h b/include/linux/bpf_verifier.h index c561b986bab0..1632bb13ad8a 100644 --- a/include/linux/bpf_verifier.h +++ b/include/linux/bpf_verifier.h @@ -15,11 +15,11 @@   * In practice this is far bigger than any realistic pointer offset; this limit   * ensures that umax_value + (int)off + (int)size cannot overflow a u64.   */ -#define BPF_MAX_VAR_OFF	(1ULL << 31) +#define BPF_MAX_VAR_OFF	(1 << 29)  /* Maximum variable size permitted for ARG_CONST_SIZE[_OR_ZERO].  This ensures   * that converting umax_value to int cannot overflow.   */ -#define BPF_MAX_VAR_SIZ	INT_MAX +#define BPF_MAX_VAR_SIZ	(1 << 29)  /* Liveness marks, used for registers and spilled-regs (in stack slots).   * Read marks propagate upwards until they find a write mark; they record that diff --git a/include/linux/compiler-gcc.h b/include/linux/compiler-gcc.h index 2272ded07496..631354acfa72 100644 --- a/include/linux/compiler-gcc.h +++ b/include/linux/compiler-gcc.h @@ -219,7 +219,7 @@  /* Mark a function definition as prohibited from being cloned. */  #define __noclone	__attribute__((__noclone__, __optimize__("no-tracer"))) -#ifdef RANDSTRUCT_PLUGIN +#if defined(RANDSTRUCT_PLUGIN) && !defined(__CHECKER__)  #define __randomize_layout __attribute__((randomize_layout))  #define __no_randomize_layout __attribute__((no_randomize_layout))  #endif diff --git a/include/linux/compiler.h b/include/linux/compiler.h index 188ed9f65517..52e611ab9a6c 100644 --- a/include/linux/compiler.h +++ b/include/linux/compiler.h @@ -220,21 +220,21 @@ static __always_inline void __write_once_size(volatile void *p, void *res, int s  /*   * Prevent the compiler from merging or refetching reads or writes. The   * compiler is also forbidden from reordering successive instances of - * READ_ONCE, WRITE_ONCE and ACCESS_ONCE (see below), but only when the - * compiler is aware of some particular ordering.  One way to make the - * compiler aware of ordering is to put the two invocations of READ_ONCE, - * WRITE_ONCE or ACCESS_ONCE() in different C statements. + * READ_ONCE and WRITE_ONCE, but only when the compiler is aware of some + * particular ordering. One way to make the compiler aware of ordering is to + * put the two invocations of READ_ONCE or WRITE_ONCE in different C + * statements.   * - * In contrast to ACCESS_ONCE these two macros will also work on aggregate - * data types like structs or unions. If the size of the accessed data - * type exceeds the word size of the machine (e.g., 32 bits or 64 bits) - * READ_ONCE() and WRITE_ONCE() will fall back to memcpy(). There's at - * least two memcpy()s: one for the __builtin_memcpy() and then one for - * the macro doing the copy of variable - '__u' allocated on the stack. + * These two macros will also work on aggregate data types like structs or + * unions. If the size of the accessed data type exceeds the word size of + * the machine (e.g., 32 bits or 64 bits) READ_ONCE() and WRITE_ONCE() will + * fall back to memcpy(). There's at least two memcpy()s: one for the + * __builtin_memcpy() and then one for the macro doing the copy of variable + * - '__u' allocated on the stack.   *   * Their two major use cases are: (1) Mediating communication between   * process-level code and irq/NMI handlers, all running on the same CPU, - * and (2) Ensuring that the compiler does not  fold, spindle, or otherwise + * and (2) Ensuring that the compiler does not fold, spindle, or otherwise   * mutilate accesses that either do not require ordering or that interact   * with an explicit memory barrier or atomic instruction that provides the   * required ordering. @@ -327,29 +327,4 @@ static __always_inline void __write_once_size(volatile void *p, void *res, int s  	compiletime_assert(__native_word(t),				\  		"Need native word sized stores/loads for atomicity.") -/* - * Prevent the compiler from merging or refetching accesses.  The compiler - * is also forbidden from reordering successive instances of ACCESS_ONCE(), - * but only when the compiler is aware of some particular ordering.  One way - * to make the compiler aware of ordering is to put the two invocations of - * ACCESS_ONCE() in different C statements. - * - * ACCESS_ONCE will only work on scalar types. For union types, ACCESS_ONCE - * on a union member will work as long as the size of the member matches the - * size of the union and the size is smaller than word size. - * - * The major use cases of ACCESS_ONCE used to be (1) Mediating communication - * between process-level code and irq/NMI handlers, all running on the same CPU, - * and (2) Ensuring that the compiler does not  fold, spindle, or otherwise - * mutilate accesses that either do not require ordering or that interact - * with an explicit memory barrier or atomic instruction that provides the - * required ordering. - * - * If possible use READ_ONCE()/WRITE_ONCE() instead. - */ -#define __ACCESS_ONCE(x) ({ \ -	 __maybe_unused typeof(x) __var = (__force typeof(x)) 0; \ -	(volatile typeof(x) *)&(x); }) -#define ACCESS_ONCE(x) (*__ACCESS_ONCE(x)) -  #endif /* __LINUX_COMPILER_H */ diff --git a/include/linux/completion.h b/include/linux/completion.h index 0662a417febe..519e94915d18 100644 --- a/include/linux/completion.h +++ b/include/linux/completion.h @@ -10,9 +10,6 @@   */  #include <linux/wait.h> -#ifdef CONFIG_LOCKDEP_COMPLETIONS -#include <linux/lockdep.h> -#endif  /*   * struct completion - structure used to maintain state for a "completion" @@ -29,58 +26,15 @@  struct completion {  	unsigned int done;  	wait_queue_head_t wait; -#ifdef CONFIG_LOCKDEP_COMPLETIONS -	struct lockdep_map_cross map; -#endif  }; -#ifdef CONFIG_LOCKDEP_COMPLETIONS -static inline void complete_acquire(struct completion *x) -{ -	lock_acquire_exclusive((struct lockdep_map *)&x->map, 0, 0, NULL, _RET_IP_); -} - -static inline void complete_release(struct completion *x) -{ -	lock_release((struct lockdep_map *)&x->map, 0, _RET_IP_); -} - -static inline void complete_release_commit(struct completion *x) -{ -	lock_commit_crosslock((struct lockdep_map *)&x->map); -} - -#define init_completion_map(x, m)					\ -do {									\ -	lockdep_init_map_crosslock((struct lockdep_map *)&(x)->map,	\ -			(m)->name, (m)->key, 0);				\ -	__init_completion(x);						\ -} while (0) - -#define init_completion(x)						\ -do {									\ -	static struct lock_class_key __key;				\ -	lockdep_init_map_crosslock((struct lockdep_map *)&(x)->map,	\ -			"(completion)" #x,				\ -			&__key, 0);					\ -	__init_completion(x);						\ -} while (0) -#else  #define init_completion_map(x, m) __init_completion(x)  #define init_completion(x) __init_completion(x)  static inline void complete_acquire(struct completion *x) {}  static inline void complete_release(struct completion *x) {} -static inline void complete_release_commit(struct completion *x) {} -#endif -#ifdef CONFIG_LOCKDEP_COMPLETIONS -#define COMPLETION_INITIALIZER(work) \ -	{ 0, __WAIT_QUEUE_HEAD_INITIALIZER((work).wait), \ -	STATIC_CROSS_LOCKDEP_MAP_INIT("(completion)" #work, &(work)) } -#else  #define COMPLETION_INITIALIZER(work) \  	{ 0, __WAIT_QUEUE_HEAD_INITIALIZER((work).wait) } -#endif  #define COMPLETION_INITIALIZER_ONSTACK_MAP(work, map) \  	(*({ init_completion_map(&(work), &(map)); &(work); })) diff --git a/include/linux/cpu.h b/include/linux/cpu.h index a04ef7c15c6a..7b01bc11c692 100644 --- a/include/linux/cpu.h +++ b/include/linux/cpu.h @@ -47,6 +47,13 @@ extern void cpu_remove_dev_attr(struct device_attribute *attr);  extern int cpu_add_dev_attr_group(struct attribute_group *attrs);  extern void cpu_remove_dev_attr_group(struct attribute_group *attrs); +extern ssize_t cpu_show_meltdown(struct device *dev, +				 struct device_attribute *attr, char *buf); +extern ssize_t cpu_show_spectre_v1(struct device *dev, +				   struct device_attribute *attr, char *buf); +extern ssize_t cpu_show_spectre_v2(struct device *dev, +				   struct device_attribute *attr, char *buf); +  extern __printf(4, 5)  struct device *cpu_device_create(struct device *parent, void *drvdata,  				 const struct attribute_group **groups, diff --git a/include/linux/cpuhotplug.h b/include/linux/cpuhotplug.h index 201ab7267986..1a32e558eb11 100644 --- a/include/linux/cpuhotplug.h +++ b/include/linux/cpuhotplug.h @@ -86,7 +86,7 @@ enum cpuhp_state {  	CPUHP_MM_ZSWP_POOL_PREPARE,  	CPUHP_KVM_PPC_BOOK3S_PREPARE,  	CPUHP_ZCOMP_PREPARE, -	CPUHP_TIMERS_DEAD, +	CPUHP_TIMERS_PREPARE,  	CPUHP_MIPS_SOC_PREPARE,  	CPUHP_BP_PREPARE_DYN,  	CPUHP_BP_PREPARE_DYN_END		= CPUHP_BP_PREPARE_DYN + 20, diff --git a/include/linux/crash_core.h b/include/linux/crash_core.h index 06097ef30449..b511f6d24b42 100644 --- a/include/linux/crash_core.h +++ b/include/linux/crash_core.h @@ -42,6 +42,8 @@ phys_addr_t paddr_vmcoreinfo_note(void);  	vmcoreinfo_append_str("PAGESIZE=%ld\n", value)  #define VMCOREINFO_SYMBOL(name) \  	vmcoreinfo_append_str("SYMBOL(%s)=%lx\n", #name, (unsigned long)&name) +#define VMCOREINFO_SYMBOL_ARRAY(name) \ +	vmcoreinfo_append_str("SYMBOL(%s)=%lx\n", #name, (unsigned long)name)  #define VMCOREINFO_SIZE(name) \  	vmcoreinfo_append_str("SIZE(%s)=%lu\n", #name, \  			      (unsigned long)sizeof(name)) diff --git a/include/linux/cred.h b/include/linux/cred.h index 099058e1178b..631286535d0f 100644 --- a/include/linux/cred.h +++ b/include/linux/cred.h @@ -83,6 +83,7 @@ extern int set_current_groups(struct group_info *);  extern void set_groups(struct cred *, struct group_info *);  extern int groups_search(const struct group_info *, kgid_t);  extern bool may_setgroups(void); +extern void groups_sort(struct group_info *);  /*   * The security context of a task diff --git a/include/linux/debugfs.h b/include/linux/debugfs.h index f36ecc2a5712..3b0ba54cc4d5 100644 --- a/include/linux/debugfs.h +++ b/include/linux/debugfs.h @@ -216,6 +216,8 @@ static inline void debugfs_remove(struct dentry *dentry)  static inline void debugfs_remove_recursive(struct dentry *dentry)  { } +const struct file_operations *debugfs_real_fops(const struct file *filp); +  static inline int debugfs_file_get(struct dentry *dentry)  {  	return 0; diff --git a/include/linux/delayacct.h b/include/linux/delayacct.h index 4178d2493547..5e335b6203f4 100644 --- a/include/linux/delayacct.h +++ b/include/linux/delayacct.h @@ -71,7 +71,7 @@ extern void delayacct_init(void);  extern void __delayacct_tsk_init(struct task_struct *);  extern void __delayacct_tsk_exit(struct task_struct *);  extern void __delayacct_blkio_start(void); -extern void __delayacct_blkio_end(void); +extern void __delayacct_blkio_end(struct task_struct *);  extern int __delayacct_add_tsk(struct taskstats *, struct task_struct *);  extern __u64 __delayacct_blkio_ticks(struct task_struct *);  extern void __delayacct_freepages_start(void); @@ -122,10 +122,10 @@ static inline void delayacct_blkio_start(void)  		__delayacct_blkio_start();  } -static inline void delayacct_blkio_end(void) +static inline void delayacct_blkio_end(struct task_struct *p)  {  	if (current->delays) -		__delayacct_blkio_end(); +		__delayacct_blkio_end(p);  	delayacct_clear_flag(DELAYACCT_PF_BLKIO);  } @@ -169,7 +169,7 @@ static inline void delayacct_tsk_free(struct task_struct *tsk)  {}  static inline void delayacct_blkio_start(void)  {} -static inline void delayacct_blkio_end(void) +static inline void delayacct_blkio_end(struct task_struct *p)  {}  static inline int delayacct_add_tsk(struct taskstats *d,  					struct task_struct *tsk) diff --git a/include/linux/dma-mapping.h b/include/linux/dma-mapping.h index e8f8e8fb244d..81ed9b2d84dc 100644 --- a/include/linux/dma-mapping.h +++ b/include/linux/dma-mapping.h @@ -704,7 +704,6 @@ static inline void *dma_zalloc_coherent(struct device *dev, size_t size,  	return ret;  } -#ifdef CONFIG_HAS_DMA  static inline int dma_get_cache_alignment(void)  {  #ifdef ARCH_DMA_MINALIGN @@ -712,7 +711,6 @@ static inline int dma_get_cache_alignment(void)  #endif  	return 1;  } -#endif  /* flags for the coherent memory api */  #define DMA_MEMORY_EXCLUSIVE		0x01 diff --git a/include/linux/efi.h b/include/linux/efi.h index d813f7b04da7..29fdf8029cf6 100644 --- a/include/linux/efi.h +++ b/include/linux/efi.h @@ -140,11 +140,13 @@ struct efi_boot_memmap {  struct capsule_info {  	efi_capsule_header_t	header; +	efi_capsule_header_t	*capsule;  	int			reset_type;  	long			index;  	size_t			count;  	size_t			total_size; -	phys_addr_t		*pages; +	struct page		**pages; +	phys_addr_t		*phys;  	size_t			page_bytes_remain;  }; diff --git a/include/linux/fs.h b/include/linux/fs.h index 2995a271ec46..511fbaabf624 100644 --- a/include/linux/fs.h +++ b/include/linux/fs.h @@ -1872,7 +1872,7 @@ struct super_operations {   */  #define __IS_FLG(inode, flg)	((inode)->i_sb->s_flags & (flg)) -static inline bool sb_rdonly(const struct super_block *sb) { return sb->s_flags & MS_RDONLY; } +static inline bool sb_rdonly(const struct super_block *sb) { return sb->s_flags & SB_RDONLY; }  #define IS_RDONLY(inode)	sb_rdonly((inode)->i_sb)  #define IS_SYNC(inode)		(__IS_FLG(inode, SB_SYNCHRONOUS) || \  					((inode)->i_flags & S_SYNC)) @@ -3088,7 +3088,8 @@ static inline int vfs_lstat(const char __user *name, struct kstat *stat)  static inline int vfs_fstatat(int dfd, const char __user *filename,  			      struct kstat *stat, int flags)  { -	return vfs_statx(dfd, filename, flags, stat, STATX_BASIC_STATS); +	return vfs_statx(dfd, filename, flags | AT_NO_AUTOMOUNT, +			 stat, STATX_BASIC_STATS);  }  static inline int vfs_fstat(int fd, struct kstat *stat)  { @@ -3194,6 +3195,20 @@ static inline bool vma_is_dax(struct vm_area_struct *vma)  	return vma->vm_file && IS_DAX(vma->vm_file->f_mapping->host);  } +static inline bool vma_is_fsdax(struct vm_area_struct *vma) +{ +	struct inode *inode; + +	if (!vma->vm_file) +		return false; +	if (!vma_is_dax(vma)) +		return false; +	inode = file_inode(vma->vm_file); +	if (inode->i_mode == S_IFCHR) +		return false; /* device-dax */ +	return true; +} +  static inline int iocb_flags(struct file *file)  {  	int res = 0; diff --git a/include/linux/fscache.h b/include/linux/fscache.h index f4ff47d4a893..fe0c349684fa 100644 --- a/include/linux/fscache.h +++ b/include/linux/fscache.h @@ -755,7 +755,7 @@ bool fscache_maybe_release_page(struct fscache_cookie *cookie,  {  	if (fscache_cookie_valid(cookie) && PageFsCache(page))  		return __fscache_maybe_release_page(cookie, page, gfp); -	return false; +	return true;  }  /** diff --git a/include/linux/gpio/driver.h b/include/linux/gpio/driver.h index 55e672592fa9..7258cd676df4 100644 --- a/include/linux/gpio/driver.h +++ b/include/linux/gpio/driver.h @@ -66,9 +66,10 @@ struct gpio_irq_chip {  	/**  	 * @lock_key:  	 * -	 * Per GPIO IRQ chip lockdep class. +	 * Per GPIO IRQ chip lockdep classes.  	 */  	struct lock_class_key *lock_key; +	struct lock_class_key *request_key;  	/**  	 * @parent_handler: @@ -323,7 +324,8 @@ extern const char *gpiochip_is_requested(struct gpio_chip *chip,  /* add/remove chips */  extern int gpiochip_add_data_with_key(struct gpio_chip *chip, void *data, -				      struct lock_class_key *lock_key); +				      struct lock_class_key *lock_key, +				      struct lock_class_key *request_key);  /**   * gpiochip_add_data() - register a gpio_chip @@ -350,11 +352,13 @@ extern int gpiochip_add_data_with_key(struct gpio_chip *chip, void *data,   */  #ifdef CONFIG_LOCKDEP  #define gpiochip_add_data(chip, data) ({		\ -		static struct lock_class_key key;	\ -		gpiochip_add_data_with_key(chip, data, &key);	\ +		static struct lock_class_key lock_key;	\ +		static struct lock_class_key request_key;	  \ +		gpiochip_add_data_with_key(chip, data, &lock_key, \ +					   &request_key);	  \  	})  #else -#define gpiochip_add_data(chip, data) gpiochip_add_data_with_key(chip, data, NULL) +#define gpiochip_add_data(chip, data) gpiochip_add_data_with_key(chip, data, NULL, NULL)  #endif  static inline int gpiochip_add(struct gpio_chip *chip) @@ -429,7 +433,8 @@ int gpiochip_irqchip_add_key(struct gpio_chip *gpiochip,  			     irq_flow_handler_t handler,  			     unsigned int type,  			     bool threaded, -			     struct lock_class_key *lock_key); +			     struct lock_class_key *lock_key, +			     struct lock_class_key *request_key);  #ifdef CONFIG_LOCKDEP @@ -445,10 +450,12 @@ static inline int gpiochip_irqchip_add(struct gpio_chip *gpiochip,  				       irq_flow_handler_t handler,  				       unsigned int type)  { -	static struct lock_class_key key; +	static struct lock_class_key lock_key; +	static struct lock_class_key request_key;  	return gpiochip_irqchip_add_key(gpiochip, irqchip, first_irq, -					handler, type, false, &key); +					handler, type, false, +					&lock_key, &request_key);  }  static inline int gpiochip_irqchip_add_nested(struct gpio_chip *gpiochip, @@ -458,10 +465,12 @@ static inline int gpiochip_irqchip_add_nested(struct gpio_chip *gpiochip,  			  unsigned int type)  { -	static struct lock_class_key key; +	static struct lock_class_key lock_key; +	static struct lock_class_key request_key;  	return gpiochip_irqchip_add_key(gpiochip, irqchip, first_irq, -					handler, type, true, &key); +					handler, type, true, +					&lock_key, &request_key);  }  #else  static inline int gpiochip_irqchip_add(struct gpio_chip *gpiochip, @@ -471,7 +480,7 @@ static inline int gpiochip_irqchip_add(struct gpio_chip *gpiochip,  				       unsigned int type)  {  	return gpiochip_irqchip_add_key(gpiochip, irqchip, first_irq, -					handler, type, false, NULL); +					handler, type, false, NULL, NULL);  }  static inline int gpiochip_irqchip_add_nested(struct gpio_chip *gpiochip, @@ -481,7 +490,7 @@ static inline int gpiochip_irqchip_add_nested(struct gpio_chip *gpiochip,  			  unsigned int type)  {  	return gpiochip_irqchip_add_key(gpiochip, irqchip, first_irq, -					handler, type, true, NULL); +					handler, type, true, NULL, NULL);  }  #endif /* CONFIG_LOCKDEP */ diff --git a/include/linux/hugetlb.h b/include/linux/hugetlb.h index fbf5b31d47ee..82a25880714a 100644 --- a/include/linux/hugetlb.h +++ b/include/linux/hugetlb.h @@ -239,14 +239,6 @@ static inline int pgd_write(pgd_t pgd)  }  #endif -#ifndef pud_write -static inline int pud_write(pud_t pud) -{ -	BUG(); -	return 0; -} -#endif -  #define HUGETLB_ANON_FILE "anon_hugepage"  enum { diff --git a/include/linux/hyperv.h b/include/linux/hyperv.h index f3e97c5f94c9..6c9336626592 100644 --- a/include/linux/hyperv.h +++ b/include/linux/hyperv.h @@ -708,6 +708,7 @@ struct vmbus_channel {  	u8 monitor_bit;  	bool rescind; /* got rescind msg */ +	struct completion rescind_event;  	u32 ringbuffer_gpadlhandle; diff --git a/include/linux/idr.h b/include/linux/idr.h index 7c3a365f7e12..fa14f834e4ed 100644 --- a/include/linux/idr.h +++ b/include/linux/idr.h @@ -15,6 +15,7 @@  #include <linux/radix-tree.h>  #include <linux/gfp.h>  #include <linux/percpu.h> +#include <linux/bug.h>  struct idr {  	struct radix_tree_root	idr_rt; diff --git a/include/linux/iio/adc/stm32-dfsdm-adc.h b/include/linux/iio/adc/stm32-dfsdm-adc.h new file mode 100644 index 000000000000..e7dc7a542a4e --- /dev/null +++ b/include/linux/iio/adc/stm32-dfsdm-adc.h @@ -0,0 +1,18 @@ +/* SPDX-License-Identifier: GPL-2.0 */ +/* + * This file discribe the STM32 DFSDM IIO driver API for audio part + * + * Copyright (C) 2017, STMicroelectronics - All Rights Reserved + * Author(s): Arnaud Pouliquen <[email protected]>. + */ + +#ifndef STM32_DFSDM_ADC_H +#define STM32_DFSDM_ADC_H + +int stm32_dfsdm_get_buff_cb(struct iio_dev *iio_dev, +			    int (*cb)(const void *data, size_t size, +				      void *private), +			    void *private); +int stm32_dfsdm_release_buff_cb(struct iio_dev *iio_dev); + +#endif diff --git a/include/linux/iio/consumer.h b/include/linux/iio/consumer.h index 5e347a9805fd..9887f4f8e2a8 100644 --- a/include/linux/iio/consumer.h +++ b/include/linux/iio/consumer.h @@ -134,6 +134,17 @@ struct iio_cb_buffer *iio_channel_get_all_cb(struct device *dev,  						       void *private),  					     void *private);  /** + * iio_channel_cb_set_buffer_watermark() - set the buffer watermark. + * @cb_buffer:		The callback buffer from whom we want the channel + *			information. + * @watermark: buffer watermark in bytes. + * + * This function allows to configure the buffer watermark. + */ +int iio_channel_cb_set_buffer_watermark(struct iio_cb_buffer *cb_buffer, +					size_t watermark); + +/**   * iio_channel_release_all_cb() - release and unregister the callback.   * @cb_buffer:		The callback buffer that was allocated.   */ @@ -216,6 +227,32 @@ int iio_read_channel_average_raw(struct iio_channel *chan, int *val);  int iio_read_channel_processed(struct iio_channel *chan, int *val);  /** + * iio_write_channel_attribute() - Write values to the device attribute. + * @chan:	The channel being queried. + * @val:	Value being written. + * @val2:	Value being written.val2 use depends on attribute type. + * @attribute:	info attribute to be read. + * + * Returns an error code or 0. + */ +int iio_write_channel_attribute(struct iio_channel *chan, int val, +				int val2, enum iio_chan_info_enum attribute); + +/** + * iio_read_channel_attribute() - Read values from the device attribute. + * @chan:	The channel being queried. + * @val:	Value being written. + * @val2:	Value being written.Val2 use depends on attribute type. + * @attribute:	info attribute to be written. + * + * Returns an error code if failed. Else returns a description of what is in val + * and val2, such as IIO_VAL_INT_PLUS_MICRO telling us we have a value of val + * + val2/1e6 + */ +int iio_read_channel_attribute(struct iio_channel *chan, int *val, +			       int *val2, enum iio_chan_info_enum attribute); + +/**   * iio_write_channel_raw() - write to a given channel   * @chan:		The channel being queried.   * @val:		Value being written. diff --git a/include/linux/iio/hw-consumer.h b/include/linux/iio/hw-consumer.h new file mode 100644 index 000000000000..44d48bb1d39f --- /dev/null +++ b/include/linux/iio/hw-consumer.h @@ -0,0 +1,21 @@ +/* SPDX-License-Identifier: GPL-2.0 */ +/* + * Industrial I/O in kernel hardware consumer interface + * + * Copyright 2017 Analog Devices Inc. + *  Author: Lars-Peter Clausen <[email protected]> + */ + +#ifndef LINUX_IIO_HW_CONSUMER_H +#define LINUX_IIO_HW_CONSUMER_H + +struct iio_hw_consumer; + +struct iio_hw_consumer *iio_hw_consumer_alloc(struct device *dev); +void iio_hw_consumer_free(struct iio_hw_consumer *hwc); +struct iio_hw_consumer *devm_iio_hw_consumer_alloc(struct device *dev); +void devm_iio_hw_consumer_free(struct device *dev, struct iio_hw_consumer *hwc); +int iio_hw_consumer_enable(struct iio_hw_consumer *hwc); +void iio_hw_consumer_disable(struct iio_hw_consumer *hwc); + +#endif diff --git a/include/linux/iio/iio.h b/include/linux/iio/iio.h index 20b61347ea58..f12a61be1ede 100644 --- a/include/linux/iio/iio.h +++ b/include/linux/iio/iio.h @@ -20,34 +20,6 @@   * Currently assumes nano seconds.   */ -enum iio_chan_info_enum { -	IIO_CHAN_INFO_RAW = 0, -	IIO_CHAN_INFO_PROCESSED, -	IIO_CHAN_INFO_SCALE, -	IIO_CHAN_INFO_OFFSET, -	IIO_CHAN_INFO_CALIBSCALE, -	IIO_CHAN_INFO_CALIBBIAS, -	IIO_CHAN_INFO_PEAK, -	IIO_CHAN_INFO_PEAK_SCALE, -	IIO_CHAN_INFO_QUADRATURE_CORRECTION_RAW, -	IIO_CHAN_INFO_AVERAGE_RAW, -	IIO_CHAN_INFO_LOW_PASS_FILTER_3DB_FREQUENCY, -	IIO_CHAN_INFO_HIGH_PASS_FILTER_3DB_FREQUENCY, -	IIO_CHAN_INFO_SAMP_FREQ, -	IIO_CHAN_INFO_FREQUENCY, -	IIO_CHAN_INFO_PHASE, -	IIO_CHAN_INFO_HARDWAREGAIN, -	IIO_CHAN_INFO_HYSTERESIS, -	IIO_CHAN_INFO_INT_TIME, -	IIO_CHAN_INFO_ENABLE, -	IIO_CHAN_INFO_CALIBHEIGHT, -	IIO_CHAN_INFO_CALIBWEIGHT, -	IIO_CHAN_INFO_DEBOUNCE_COUNT, -	IIO_CHAN_INFO_DEBOUNCE_TIME, -	IIO_CHAN_INFO_CALIBEMISSIVITY, -	IIO_CHAN_INFO_OVERSAMPLING_RATIO, -}; -  enum iio_shared_by {  	IIO_SEPARATE,  	IIO_SHARED_BY_TYPE, diff --git a/include/linux/iio/timer/stm32-lptim-trigger.h b/include/linux/iio/timer/stm32-lptim-trigger.h index 34d59bfdce2d..464458d20b16 100644 --- a/include/linux/iio/timer/stm32-lptim-trigger.h +++ b/include/linux/iio/timer/stm32-lptim-trigger.h @@ -16,11 +16,14 @@  #define LPTIM2_OUT	"lptim2_out"  #define LPTIM3_OUT	"lptim3_out" -#if IS_ENABLED(CONFIG_IIO_STM32_LPTIMER_TRIGGER) +#if IS_REACHABLE(CONFIG_IIO_STM32_LPTIMER_TRIGGER)  bool is_stm32_lptim_trigger(struct iio_trigger *trig);  #else  static inline bool is_stm32_lptim_trigger(struct iio_trigger *trig)  { +#if IS_ENABLED(CONFIG_IIO_STM32_LPTIMER_TRIGGER) +	pr_warn_once("stm32 lptim_trigger not linked in\n"); +#endif  	return false;  }  #endif diff --git a/include/linux/iio/types.h b/include/linux/iio/types.h index 2aa7b6384d64..6eb3d683ef62 100644 --- a/include/linux/iio/types.h +++ b/include/linux/iio/types.h @@ -34,4 +34,32 @@ enum iio_available_type {  	IIO_AVAIL_RANGE,  }; +enum iio_chan_info_enum { +	IIO_CHAN_INFO_RAW = 0, +	IIO_CHAN_INFO_PROCESSED, +	IIO_CHAN_INFO_SCALE, +	IIO_CHAN_INFO_OFFSET, +	IIO_CHAN_INFO_CALIBSCALE, +	IIO_CHAN_INFO_CALIBBIAS, +	IIO_CHAN_INFO_PEAK, +	IIO_CHAN_INFO_PEAK_SCALE, +	IIO_CHAN_INFO_QUADRATURE_CORRECTION_RAW, +	IIO_CHAN_INFO_AVERAGE_RAW, +	IIO_CHAN_INFO_LOW_PASS_FILTER_3DB_FREQUENCY, +	IIO_CHAN_INFO_HIGH_PASS_FILTER_3DB_FREQUENCY, +	IIO_CHAN_INFO_SAMP_FREQ, +	IIO_CHAN_INFO_FREQUENCY, +	IIO_CHAN_INFO_PHASE, +	IIO_CHAN_INFO_HARDWAREGAIN, +	IIO_CHAN_INFO_HYSTERESIS, +	IIO_CHAN_INFO_INT_TIME, +	IIO_CHAN_INFO_ENABLE, +	IIO_CHAN_INFO_CALIBHEIGHT, +	IIO_CHAN_INFO_CALIBWEIGHT, +	IIO_CHAN_INFO_DEBOUNCE_COUNT, +	IIO_CHAN_INFO_DEBOUNCE_TIME, +	IIO_CHAN_INFO_CALIBEMISSIVITY, +	IIO_CHAN_INFO_OVERSAMPLING_RATIO, +}; +  #endif /* _IIO_TYPES_H_ */ diff --git a/include/linux/intel-pti.h b/include/linux/intel-pti.h new file mode 100644 index 000000000000..2710d72de3c9 --- /dev/null +++ b/include/linux/intel-pti.h @@ -0,0 +1,43 @@ +/* + *  Copyright (C) Intel 2011 + * + * 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. + * + * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ + * + * The PTI (Parallel Trace Interface) driver directs trace data routed from + * various parts in the system out through the Intel Penwell PTI port and + * out of the mobile device for analysis with a debugging tool + * (Lauterbach, Fido). This is part of a solution for the MIPI P1149.7, + * compact JTAG, standard. + * + * This header file will allow other parts of the OS to use the + * interface to write out it's contents for debugging a mobile system. + */ + +#ifndef LINUX_INTEL_PTI_H_ +#define LINUX_INTEL_PTI_H_ + +/* offset for last dword of any PTI message. Part of MIPI P1149.7 */ +#define PTI_LASTDWORD_DTS	0x30 + +/* basic structure used as a write address to the PTI HW */ +struct pti_masterchannel { +	u8 master; +	u8 channel; +}; + +/* the following functions are defined in misc/pti.c */ +void pti_writedata(struct pti_masterchannel *mc, u8 *buf, int count); +struct pti_masterchannel *pti_request_masterchannel(u8 type, +						    const char *thread_name); +void pti_release_masterchannel(struct pti_masterchannel *mc); + +#endif /* LINUX_INTEL_PTI_H_ */ diff --git a/include/linux/ipv6.h b/include/linux/ipv6.h index cb18c6290ca8..8415bf1a9776 100644 --- a/include/linux/ipv6.h +++ b/include/linux/ipv6.h @@ -273,7 +273,8 @@ struct ipv6_pinfo {  						 * 100: prefer care-of address  						 */  				dontfrag:1, -				autoflowlabel:1; +				autoflowlabel:1, +				autoflowlabel_set:1;  	__u8			min_hopcount;  	__u8			tclass;  	__be32			rcv_flowinfo; diff --git a/include/linux/irq.h b/include/linux/irq.h index e140f69163b6..a0231e96a578 100644 --- a/include/linux/irq.h +++ b/include/linux/irq.h @@ -212,6 +212,7 @@ struct irq_data {   *				  mask. Applies only to affinity managed irqs.   * IRQD_SINGLE_TARGET		- IRQ allows only a single affinity target   * IRQD_DEFAULT_TRIGGER_SET	- Expected trigger already been set + * IRQD_CAN_RESERVE		- Can use reservation mode   */  enum {  	IRQD_TRIGGER_MASK		= 0xf, @@ -233,6 +234,7 @@ enum {  	IRQD_MANAGED_SHUTDOWN		= (1 << 23),  	IRQD_SINGLE_TARGET		= (1 << 24),  	IRQD_DEFAULT_TRIGGER_SET	= (1 << 25), +	IRQD_CAN_RESERVE		= (1 << 26),  };  #define __irqd_to_state(d) ACCESS_PRIVATE((d)->common, state_use_accessors) @@ -377,6 +379,21 @@ static inline bool irqd_is_managed_and_shutdown(struct irq_data *d)  	return __irqd_to_state(d) & IRQD_MANAGED_SHUTDOWN;  } +static inline void irqd_set_can_reserve(struct irq_data *d) +{ +	__irqd_to_state(d) |= IRQD_CAN_RESERVE; +} + +static inline void irqd_clr_can_reserve(struct irq_data *d) +{ +	__irqd_to_state(d) &= ~IRQD_CAN_RESERVE; +} + +static inline bool irqd_can_reserve(struct irq_data *d) +{ +	return __irqd_to_state(d) & IRQD_CAN_RESERVE; +} +  #undef __irqd_to_state  static inline irq_hw_number_t irqd_to_hwirq(struct irq_data *d) diff --git a/include/linux/irqdesc.h b/include/linux/irqdesc.h index dd418955962b..25b33b664537 100644 --- a/include/linux/irqdesc.h +++ b/include/linux/irqdesc.h @@ -230,7 +230,7 @@ irq_set_chip_handler_name_locked(struct irq_data *data, struct irq_chip *chip,  	data->chip = chip;  } -static inline int irq_balancing_disabled(unsigned int irq) +static inline bool irq_balancing_disabled(unsigned int irq)  {  	struct irq_desc *desc; @@ -238,7 +238,7 @@ static inline int irq_balancing_disabled(unsigned int irq)  	return desc->status_use_accessors & IRQ_NO_BALANCING_MASK;  } -static inline int irq_is_percpu(unsigned int irq) +static inline bool irq_is_percpu(unsigned int irq)  {  	struct irq_desc *desc; @@ -246,7 +246,7 @@ static inline int irq_is_percpu(unsigned int irq)  	return desc->status_use_accessors & IRQ_PER_CPU;  } -static inline int irq_is_percpu_devid(unsigned int irq) +static inline bool irq_is_percpu_devid(unsigned int irq)  {  	struct irq_desc *desc; @@ -255,12 +255,15 @@ static inline int irq_is_percpu_devid(unsigned int irq)  }  static inline void -irq_set_lockdep_class(unsigned int irq, struct lock_class_key *class) +irq_set_lockdep_class(unsigned int irq, struct lock_class_key *lock_class, +		      struct lock_class_key *request_class)  {  	struct irq_desc *desc = irq_to_desc(irq); -	if (desc) -		lockdep_set_class(&desc->lock, class); +	if (desc) { +		lockdep_set_class(&desc->lock, lock_class); +		lockdep_set_class(&desc->request_mutex, request_class); +	}  }  #ifdef CONFIG_IRQ_PREFLOW_FASTEOI diff --git a/include/linux/irqdomain.h b/include/linux/irqdomain.h index a34355d19546..48c7e86bb556 100644 --- a/include/linux/irqdomain.h +++ b/include/linux/irqdomain.h @@ -113,7 +113,7 @@ struct irq_domain_ops {  		     unsigned int nr_irqs, void *arg);  	void (*free)(struct irq_domain *d, unsigned int virq,  		     unsigned int nr_irqs); -	int (*activate)(struct irq_domain *d, struct irq_data *irqd, bool early); +	int (*activate)(struct irq_domain *d, struct irq_data *irqd, bool reserve);  	void (*deactivate)(struct irq_domain *d, struct irq_data *irq_data);  	int (*translate)(struct irq_domain *d, struct irq_fwspec *fwspec,  			 unsigned long *out_hwirq, unsigned int *out_type); diff --git a/include/linux/irqflags.h b/include/linux/irqflags.h index 46cb57d5eb13..1b3996ff3f16 100644 --- a/include/linux/irqflags.h +++ b/include/linux/irqflags.h @@ -27,22 +27,18 @@  # define trace_hardirq_enter()			\  do {						\  	current->hardirq_context++;		\ -	crossrelease_hist_start(XHLOCK_HARD);	\  } while (0)  # define trace_hardirq_exit()			\  do {						\  	current->hardirq_context--;		\ -	crossrelease_hist_end(XHLOCK_HARD);	\  } while (0)  # define lockdep_softirq_enter()		\  do {						\  	current->softirq_context++;		\ -	crossrelease_hist_start(XHLOCK_SOFT);	\  } while (0)  # define lockdep_softirq_exit()			\  do {						\  	current->softirq_context--;		\ -	crossrelease_hist_end(XHLOCK_SOFT);	\  } while (0)  # define INIT_TRACE_IRQFLAGS	.softirqs_enabled = 1,  #else diff --git a/include/linux/kallsyms.h b/include/linux/kallsyms.h index 708f337d780b..bd118a6c60cb 100644 --- a/include/linux/kallsyms.h +++ b/include/linux/kallsyms.h @@ -14,12 +14,6 @@  #define KSYM_SYMBOL_LEN (sizeof("%s+%#lx/%#lx [%s]") + (KSYM_NAME_LEN - 1) + \  			 2*(BITS_PER_LONG*3/10) + (MODULE_NAME_LEN - 1) + 1) -#ifndef CONFIG_64BIT -# define KALLSYM_FMT "%08lx" -#else -# define KALLSYM_FMT "%016lx" -#endif -  struct module;  #ifdef CONFIG_KALLSYMS diff --git a/include/linux/kmemcheck.h b/include/linux/kmemcheck.h deleted file mode 100644 index ea32a7d3cf1b..000000000000 --- a/include/linux/kmemcheck.h +++ /dev/null @@ -1 +0,0 @@ -/* SPDX-License-Identifier: GPL-2.0 */ diff --git a/include/linux/kvm_host.h b/include/linux/kvm_host.h index 2e754b7c282c..6bdd4b9f6611 100644 --- a/include/linux/kvm_host.h +++ b/include/linux/kvm_host.h @@ -232,7 +232,7 @@ struct kvm_vcpu {  	struct mutex mutex;  	struct kvm_run *run; -	int guest_fpu_loaded, guest_xcr0_loaded; +	int guest_xcr0_loaded;  	struct swait_queue_head wq;  	struct pid __rcu *pid;  	int sigset_active; @@ -715,6 +715,9 @@ int kvm_vcpu_write_guest(struct kvm_vcpu *vcpu, gpa_t gpa, const void *data,  			 unsigned long len);  void kvm_vcpu_mark_page_dirty(struct kvm_vcpu *vcpu, gfn_t gfn); +void kvm_sigset_activate(struct kvm_vcpu *vcpu); +void kvm_sigset_deactivate(struct kvm_vcpu *vcpu); +  void kvm_vcpu_block(struct kvm_vcpu *vcpu);  void kvm_arch_vcpu_blocking(struct kvm_vcpu *vcpu);  void kvm_arch_vcpu_unblocking(struct kvm_vcpu *vcpu); diff --git a/include/lib/libgcc.h b/include/linux/libgcc.h index 32e1e0f4b2d0..32e1e0f4b2d0 100644 --- a/include/lib/libgcc.h +++ b/include/linux/libgcc.h diff --git a/include/linux/lockdep.h b/include/linux/lockdep.h index a842551fe044..3251d9c0d313 100644 --- a/include/linux/lockdep.h +++ b/include/linux/lockdep.h @@ -158,12 +158,6 @@ struct lockdep_map {  	int				cpu;  	unsigned long			ip;  #endif -#ifdef CONFIG_LOCKDEP_CROSSRELEASE -	/* -	 * Whether it's a crosslock. -	 */ -	int				cross; -#endif  };  static inline void lockdep_copy_map(struct lockdep_map *to, @@ -267,96 +261,9 @@ struct held_lock {  	unsigned int hardirqs_off:1;  	unsigned int references:12;					/* 32 bits */  	unsigned int pin_count; -#ifdef CONFIG_LOCKDEP_CROSSRELEASE -	/* -	 * Generation id. -	 * -	 * A value of cross_gen_id will be stored when holding this, -	 * which is globally increased whenever each crosslock is held. -	 */ -	unsigned int gen_id; -#endif -}; - -#ifdef CONFIG_LOCKDEP_CROSSRELEASE -#define MAX_XHLOCK_TRACE_ENTRIES 5 - -/* - * This is for keeping locks waiting for commit so that true dependencies - * can be added at commit step. - */ -struct hist_lock { -	/* -	 * Id for each entry in the ring buffer. This is used to -	 * decide whether the ring buffer was overwritten or not. -	 * -	 * For example, -	 * -	 *           |<----------- hist_lock ring buffer size ------->| -	 *           pppppppppppppppppppppiiiiiiiiiiiiiiiiiiiiiiiiiiiii -	 * wrapped > iiiiiiiiiiiiiiiiiiiiiiiiiii....................... -	 * -	 *           where 'p' represents an acquisition in process -	 *           context, 'i' represents an acquisition in irq -	 *           context. -	 * -	 * In this example, the ring buffer was overwritten by -	 * acquisitions in irq context, that should be detected on -	 * rollback or commit. -	 */ -	unsigned int hist_id; - -	/* -	 * Seperate stack_trace data. This will be used at commit step. -	 */ -	struct stack_trace	trace; -	unsigned long		trace_entries[MAX_XHLOCK_TRACE_ENTRIES]; - -	/* -	 * Seperate hlock instance. This will be used at commit step. -	 * -	 * TODO: Use a smaller data structure containing only necessary -	 * data. However, we should make lockdep code able to handle the -	 * smaller one first. -	 */ -	struct held_lock	hlock;  };  /* - * To initialize a lock as crosslock, lockdep_init_map_crosslock() should - * be called instead of lockdep_init_map(). - */ -struct cross_lock { -	/* -	 * When more than one acquisition of crosslocks are overlapped, -	 * we have to perform commit for them based on cross_gen_id of -	 * the first acquisition, which allows us to add more true -	 * dependencies. -	 * -	 * Moreover, when no acquisition of a crosslock is in progress, -	 * we should not perform commit because the lock might not exist -	 * any more, which might cause incorrect memory access. So we -	 * have to track the number of acquisitions of a crosslock. -	 */ -	int nr_acquire; - -	/* -	 * Seperate hlock instance. This will be used at commit step. -	 * -	 * TODO: Use a smaller data structure containing only necessary -	 * data. However, we should make lockdep code able to handle the -	 * smaller one first. -	 */ -	struct held_lock	hlock; -}; - -struct lockdep_map_cross { -	struct lockdep_map map; -	struct cross_lock xlock; -}; -#endif - -/*   * Initialization, self-test and debugging-output methods:   */  extern void lockdep_info(void); @@ -560,37 +467,6 @@ enum xhlock_context_t {  	XHLOCK_CTX_NR,  }; -#ifdef CONFIG_LOCKDEP_CROSSRELEASE -extern void lockdep_init_map_crosslock(struct lockdep_map *lock, -				       const char *name, -				       struct lock_class_key *key, -				       int subclass); -extern void lock_commit_crosslock(struct lockdep_map *lock); - -/* - * What we essencially have to initialize is 'nr_acquire'. Other members - * will be initialized in add_xlock(). - */ -#define STATIC_CROSS_LOCK_INIT() \ -	{ .nr_acquire = 0,} - -#define STATIC_CROSS_LOCKDEP_MAP_INIT(_name, _key) \ -	{ .map.name = (_name), .map.key = (void *)(_key), \ -	  .map.cross = 1, .xlock = STATIC_CROSS_LOCK_INIT(), } - -/* - * To initialize a lockdep_map statically use this macro. - * Note that _name must not be NULL. - */ -#define STATIC_LOCKDEP_MAP_INIT(_name, _key) \ -	{ .name = (_name), .key = (void *)(_key), .cross = 0, } - -extern void crossrelease_hist_start(enum xhlock_context_t c); -extern void crossrelease_hist_end(enum xhlock_context_t c); -extern void lockdep_invariant_state(bool force); -extern void lockdep_init_task(struct task_struct *task); -extern void lockdep_free_task(struct task_struct *task); -#else /* !CROSSRELEASE */  #define lockdep_init_map_crosslock(m, n, k, s) do {} while (0)  /*   * To initialize a lockdep_map statically use this macro. @@ -599,12 +475,9 @@ extern void lockdep_free_task(struct task_struct *task);  #define STATIC_LOCKDEP_MAP_INIT(_name, _key) \  	{ .name = (_name), .key = (void *)(_key), } -static inline void crossrelease_hist_start(enum xhlock_context_t c) {} -static inline void crossrelease_hist_end(enum xhlock_context_t c) {}  static inline void lockdep_invariant_state(bool force) {}  static inline void lockdep_init_task(struct task_struct *task) {}  static inline void lockdep_free_task(struct task_struct *task) {} -#endif /* CROSSRELEASE */  #ifdef CONFIG_LOCK_STAT diff --git a/include/linux/mfd/rtsx_pci.h b/include/linux/mfd/rtsx_pci.h index a2a1318a3d0c..c3d3f04d8cc6 100644 --- a/include/linux/mfd/rtsx_pci.h +++ b/include/linux/mfd/rtsx_pci.h @@ -915,10 +915,10 @@ enum PDEV_STAT  {PDEV_STAT_IDLE, PDEV_STAT_RUN};  #define LTR_L1SS_PWR_GATE_CHECK_CARD_EN	BIT(6)  enum dev_aspm_mode { -	DEV_ASPM_DISABLE = 0,  	DEV_ASPM_DYNAMIC,  	DEV_ASPM_BACKDOOR,  	DEV_ASPM_STATIC, +	DEV_ASPM_DISABLE,  };  /* diff --git a/include/linux/migrate.h b/include/linux/migrate.h index 895ec0c4942e..a2246cf670ba 100644 --- a/include/linux/migrate.h +++ b/include/linux/migrate.h @@ -54,7 +54,7 @@ static inline struct page *new_page_nodemask(struct page *page,  	new_page = __alloc_pages_nodemask(gfp_mask, order,  				preferred_nid, nodemask); -	if (new_page && PageTransHuge(page)) +	if (new_page && PageTransHuge(new_page))  		prep_transhuge_page(new_page);  	return new_page; diff --git a/include/linux/mlx5/driver.h b/include/linux/mlx5/driver.h index a886b51511ab..a0610427e168 100644 --- a/include/linux/mlx5/driver.h +++ b/include/linux/mlx5/driver.h @@ -36,6 +36,7 @@  #include <linux/kernel.h>  #include <linux/completion.h>  #include <linux/pci.h> +#include <linux/irq.h>  #include <linux/spinlock_types.h>  #include <linux/semaphore.h>  #include <linux/slab.h> @@ -556,6 +557,7 @@ struct mlx5_core_sriov {  };  struct mlx5_irq_info { +	cpumask_var_t mask;  	char name[MLX5_MAX_IRQ_NAME];  }; @@ -1048,7 +1050,7 @@ int mlx5_create_map_eq(struct mlx5_core_dev *dev, struct mlx5_eq *eq, u8 vecidx,  		       enum mlx5_eq_type type);  int mlx5_destroy_unmap_eq(struct mlx5_core_dev *dev, struct mlx5_eq *eq);  int mlx5_start_eqs(struct mlx5_core_dev *dev); -int mlx5_stop_eqs(struct mlx5_core_dev *dev); +void mlx5_stop_eqs(struct mlx5_core_dev *dev);  int mlx5_vector2eqn(struct mlx5_core_dev *dev, int vector, int *eqn,  		    unsigned int *irqn);  int mlx5_core_attach_mcg(struct mlx5_core_dev *dev, union ib_gid *mgid, u32 qpn); @@ -1164,6 +1166,10 @@ int mlx5_cmd_create_vport_lag(struct mlx5_core_dev *dev);  int mlx5_cmd_destroy_vport_lag(struct mlx5_core_dev *dev);  bool mlx5_lag_is_active(struct mlx5_core_dev *dev);  struct net_device *mlx5_lag_get_roce_netdev(struct mlx5_core_dev *dev); +int mlx5_lag_query_cong_counters(struct mlx5_core_dev *dev, +				 u64 *values, +				 int num_counters, +				 size_t *offsets);  struct mlx5_uars_page *mlx5_get_uars_page(struct mlx5_core_dev *mdev);  void mlx5_put_uars_page(struct mlx5_core_dev *mdev, struct mlx5_uars_page *up); @@ -1226,7 +1232,23 @@ enum {  static inline const struct cpumask *  mlx5_get_vector_affinity(struct mlx5_core_dev *dev, int vector)  { -	return pci_irq_get_affinity(dev->pdev, MLX5_EQ_VEC_COMP_BASE + vector); +	const struct cpumask *mask; +	struct irq_desc *desc; +	unsigned int irq; +	int eqn; +	int err; + +	err = mlx5_vector2eqn(dev, vector, &eqn, &irq); +	if (err) +		return NULL; + +	desc = irq_to_desc(irq); +#ifdef CONFIG_GENERIC_IRQ_EFFECTIVE_AFF_MASK +	mask = irq_data_get_effective_affinity_mask(&desc->irq_data); +#else +	mask = desc->irq_common_data.affinity; +#endif +	return mask;  }  #endif /* MLX5_DRIVER_H */ diff --git a/include/linux/mlx5/mlx5_ifc.h b/include/linux/mlx5/mlx5_ifc.h index 38a7577a9ce7..1391a82da98e 100644 --- a/include/linux/mlx5/mlx5_ifc.h +++ b/include/linux/mlx5/mlx5_ifc.h @@ -147,7 +147,7 @@ enum {  	MLX5_CMD_OP_ALLOC_Q_COUNTER               = 0x771,  	MLX5_CMD_OP_DEALLOC_Q_COUNTER             = 0x772,  	MLX5_CMD_OP_QUERY_Q_COUNTER               = 0x773, -	MLX5_CMD_OP_SET_RATE_LIMIT                = 0x780, +	MLX5_CMD_OP_SET_PP_RATE_LIMIT             = 0x780,  	MLX5_CMD_OP_QUERY_RATE_LIMIT              = 0x781,  	MLX5_CMD_OP_CREATE_SCHEDULING_ELEMENT      = 0x782,  	MLX5_CMD_OP_DESTROY_SCHEDULING_ELEMENT     = 0x783, @@ -1027,8 +1027,9 @@ struct mlx5_ifc_cmd_hca_cap_bits {  	u8         log_max_wq_sz[0x5];  	u8         nic_vport_change_event[0x1]; -	u8         disable_local_lb[0x1]; -	u8         reserved_at_3e2[0x9]; +	u8         disable_local_lb_uc[0x1]; +	u8         disable_local_lb_mc[0x1]; +	u8         reserved_at_3e3[0x8];  	u8         log_max_vlan_list[0x5];  	u8         reserved_at_3f0[0x3];  	u8         log_max_current_mc_list[0x5]; @@ -7239,7 +7240,7 @@ struct mlx5_ifc_add_vxlan_udp_dport_in_bits {  	u8         vxlan_udp_port[0x10];  }; -struct mlx5_ifc_set_rate_limit_out_bits { +struct mlx5_ifc_set_pp_rate_limit_out_bits {  	u8         status[0x8];  	u8         reserved_at_8[0x18]; @@ -7248,7 +7249,7 @@ struct mlx5_ifc_set_rate_limit_out_bits {  	u8         reserved_at_40[0x40];  }; -struct mlx5_ifc_set_rate_limit_in_bits { +struct mlx5_ifc_set_pp_rate_limit_in_bits {  	u8         opcode[0x10];  	u8         reserved_at_10[0x10]; @@ -7261,6 +7262,8 @@ struct mlx5_ifc_set_rate_limit_in_bits {  	u8         reserved_at_60[0x20];  	u8         rate_limit[0x20]; + +	u8         reserved_at_a0[0x160];  };  struct mlx5_ifc_access_register_out_bits { diff --git a/include/linux/mm.h b/include/linux/mm.h index ee073146aaa7..ea818ff739cd 100644 --- a/include/linux/mm.h +++ b/include/linux/mm.h @@ -377,6 +377,7 @@ enum page_entry_size {  struct vm_operations_struct {  	void (*open)(struct vm_area_struct * area);  	void (*close)(struct vm_area_struct * area); +	int (*split)(struct vm_area_struct * area, unsigned long addr);  	int (*mremap)(struct vm_area_struct * area);  	int (*fault)(struct vm_fault *vmf);  	int (*huge_fault)(struct vm_fault *vmf, enum page_entry_size pe_size); @@ -1379,6 +1380,19 @@ long get_user_pages_locked(unsigned long start, unsigned long nr_pages,  		    unsigned int gup_flags, struct page **pages, int *locked);  long get_user_pages_unlocked(unsigned long start, unsigned long nr_pages,  		    struct page **pages, unsigned int gup_flags); +#ifdef CONFIG_FS_DAX +long get_user_pages_longterm(unsigned long start, unsigned long nr_pages, +			    unsigned int gup_flags, struct page **pages, +			    struct vm_area_struct **vmas); +#else +static inline long get_user_pages_longterm(unsigned long start, +		unsigned long nr_pages, unsigned int gup_flags, +		struct page **pages, struct vm_area_struct **vmas) +{ +	return get_user_pages(start, nr_pages, gup_flags, pages, vmas); +} +#endif /* CONFIG_FS_DAX */ +  int get_user_pages_fast(unsigned long start, int nr_pages, int write,  			struct page **pages); diff --git a/include/linux/netlink.h b/include/linux/netlink.h index 49b4257ce1ea..f3075d6c7e82 100644 --- a/include/linux/netlink.h +++ b/include/linux/netlink.h @@ -85,7 +85,7 @@ struct netlink_ext_ack {   * to the lack of an output buffer.)   */  #define NL_SET_ERR_MSG(extack, msg) do {		\ -	static const char __msg[] = (msg);		\ +	static const char __msg[] = msg;		\  	struct netlink_ext_ack *__extack = (extack);	\  							\  	if (__extack)					\ @@ -101,7 +101,7 @@ struct netlink_ext_ack {  } while (0)  #define NL_SET_ERR_MSG_ATTR(extack, attr, msg) do {	\ -	static const char __msg[] = (msg);		\ +	static const char __msg[] = msg;		\  	struct netlink_ext_ack *__extack = (extack);	\  							\  	if (__extack) {					\ diff --git a/include/linux/oom.h b/include/linux/oom.h index 01c91d874a57..5bad038ac012 100644 --- a/include/linux/oom.h +++ b/include/linux/oom.h @@ -67,6 +67,15 @@ static inline bool tsk_is_oom_victim(struct task_struct * tsk)  }  /* + * Use this helper if tsk->mm != mm and the victim mm needs a special + * handling. This is guaranteed to stay true after once set. + */ +static inline bool mm_is_oom_victim(struct mm_struct *mm) +{ +	return test_bit(MMF_OOM_VICTIM, &mm->flags); +} + +/*   * Checks whether a page fault on the given mm is still reliable.   * This is no longer true if the oom reaper started to reap the   * address space which is reflected by MMF_UNSTABLE flag set in diff --git a/include/linux/pci.h b/include/linux/pci.h index 0403894147a3..c170c9250c8b 100644 --- a/include/linux/pci.h +++ b/include/linux/pci.h @@ -1674,6 +1674,9 @@ static inline struct pci_dev *pci_get_slot(struct pci_bus *bus,  static inline struct pci_dev *pci_get_bus_and_slot(unsigned int bus,  						unsigned int devfn)  { return NULL; } +static inline struct pci_dev *pci_get_domain_bus_and_slot(int domain, +					unsigned int bus, unsigned int devfn) +{ return NULL; }  static inline int pci_domain_nr(struct pci_bus *bus) { return 0; }  static inline struct pci_dev *pci_dev_get(struct pci_dev *dev) { return NULL; } diff --git a/include/linux/perf_event.h b/include/linux/perf_event.h index 2c9c87d8a0c1..7546822a1d74 100644 --- a/include/linux/perf_event.h +++ b/include/linux/perf_event.h @@ -15,6 +15,7 @@  #define _LINUX_PERF_EVENT_H  #include <uapi/linux/perf_event.h> +#include <uapi/linux/bpf_perf_event.h>  /*   * Kernel-internal data types and definitions: @@ -787,7 +788,7 @@ struct perf_output_handle {  };  struct bpf_perf_event_data_kern { -	struct pt_regs *regs; +	bpf_user_pt_regs_t *regs;  	struct perf_sample_data *data;  	struct perf_event *event;  }; @@ -1177,6 +1178,9 @@ extern void perf_bp_event(struct perf_event *event, void *data);  		(user_mode(regs) ? PERF_RECORD_MISC_USER : PERF_RECORD_MISC_KERNEL)  # define perf_instruction_pointer(regs)	instruction_pointer(regs)  #endif +#ifndef perf_arch_bpf_user_pt_regs +# define perf_arch_bpf_user_pt_regs(regs) regs +#endif  static inline bool has_branch_stack(struct perf_event *event)  { diff --git a/include/linux/pm.h b/include/linux/pm.h index 65d39115f06d..492ed473ba7e 100644 --- a/include/linux/pm.h +++ b/include/linux/pm.h @@ -765,6 +765,7 @@ extern int pm_generic_poweroff_late(struct device *dev);  extern int pm_generic_poweroff(struct device *dev);  extern void pm_generic_complete(struct device *dev); +extern void dev_pm_skip_next_resume_phases(struct device *dev);  extern bool dev_pm_smart_suspend_and_suspended(struct device *dev);  #else /* !CONFIG_PM_SLEEP */ diff --git a/include/linux/pti.h b/include/linux/pti.h index b3ea01a3197e..0174883a935a 100644 --- a/include/linux/pti.h +++ b/include/linux/pti.h @@ -1,43 +1,11 @@ -/* - *  Copyright (C) Intel 2011 - * - * 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. - * - * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ - * - * The PTI (Parallel Trace Interface) driver directs trace data routed from - * various parts in the system out through the Intel Penwell PTI port and - * out of the mobile device for analysis with a debugging tool - * (Lauterbach, Fido). This is part of a solution for the MIPI P1149.7, - * compact JTAG, standard. - * - * This header file will allow other parts of the OS to use the - * interface to write out it's contents for debugging a mobile system. - */ +// SPDX-License-Identifier: GPL-2.0 +#ifndef _INCLUDE_PTI_H +#define _INCLUDE_PTI_H -#ifndef PTI_H_ -#define PTI_H_ +#ifdef CONFIG_PAGE_TABLE_ISOLATION +#include <asm/pti.h> +#else +static inline void pti_init(void) { } +#endif -/* offset for last dword of any PTI message. Part of MIPI P1149.7 */ -#define PTI_LASTDWORD_DTS	0x30 - -/* basic structure used as a write address to the PTI HW */ -struct pti_masterchannel { -	u8 master; -	u8 channel; -}; - -/* the following functions are defined in misc/pti.c */ -void pti_writedata(struct pti_masterchannel *mc, u8 *buf, int count); -struct pti_masterchannel *pti_request_masterchannel(u8 type, -						    const char *thread_name); -void pti_release_masterchannel(struct pti_masterchannel *mc); - -#endif /*PTI_H_*/ +#endif diff --git a/include/linux/ptr_ring.h b/include/linux/ptr_ring.h index 37b4bb2545b3..d72b2e7dd500 100644 --- a/include/linux/ptr_ring.h +++ b/include/linux/ptr_ring.h @@ -101,12 +101,18 @@ static inline bool ptr_ring_full_bh(struct ptr_ring *r)  /* Note: callers invoking this in a loop must use a compiler barrier,   * for example cpu_relax(). Callers must hold producer_lock. + * Callers are responsible for making sure pointer that is being queued + * points to a valid data.   */  static inline int __ptr_ring_produce(struct ptr_ring *r, void *ptr)  {  	if (unlikely(!r->size) || r->queue[r->producer])  		return -ENOSPC; +	/* Make sure the pointer we are storing points to a valid data. */ +	/* Pairs with smp_read_barrier_depends in __ptr_ring_consume. */ +	smp_wmb(); +  	r->queue[r->producer++] = ptr;  	if (unlikely(r->producer >= r->size))  		r->producer = 0; @@ -168,6 +174,15 @@ static inline int ptr_ring_produce_bh(struct ptr_ring *r, void *ptr)   * if they dereference the pointer - see e.g. PTR_RING_PEEK_CALL.   * If ring is never resized, and if the pointer is merely   * tested, there's no need to take the lock - see e.g.  __ptr_ring_empty. + * However, if called outside the lock, and if some other CPU + * consumes ring entries at the same time, the value returned + * is not guaranteed to be correct. + * In this case - to avoid incorrectly detecting the ring + * as empty - the CPU consuming the ring entries is responsible + * for either consuming all ring entries until the ring is empty, + * or synchronizing with some other CPU and causing it to + * execute __ptr_ring_peek and/or consume the ring enteries + * after the synchronization point.   */  static inline void *__ptr_ring_peek(struct ptr_ring *r)  { @@ -176,10 +191,7 @@ static inline void *__ptr_ring_peek(struct ptr_ring *r)  	return NULL;  } -/* Note: callers invoking this in a loop must use a compiler barrier, - * for example cpu_relax(). Callers must take consumer_lock - * if the ring is ever resized - see e.g. ptr_ring_empty. - */ +/* See __ptr_ring_peek above for locking rules. */  static inline bool __ptr_ring_empty(struct ptr_ring *r)  {  	return !__ptr_ring_peek(r); @@ -275,6 +287,9 @@ static inline void *__ptr_ring_consume(struct ptr_ring *r)  	if (ptr)  		__ptr_ring_discard_one(r); +	/* Make sure anyone accessing data through the pointer is up to date. */ +	/* Pairs with smp_wmb in __ptr_ring_produce. */ +	smp_read_barrier_depends();  	return ptr;  } diff --git a/include/linux/rbtree.h b/include/linux/rbtree.h index d574361943ea..fcbeed4053ef 100644 --- a/include/linux/rbtree.h +++ b/include/linux/rbtree.h @@ -99,6 +99,8 @@ extern void rb_replace_node(struct rb_node *victim, struct rb_node *new,  			    struct rb_root *root);  extern void rb_replace_node_rcu(struct rb_node *victim, struct rb_node *new,  				struct rb_root *root); +extern void rb_replace_node_cached(struct rb_node *victim, struct rb_node *new, +				   struct rb_root_cached *root);  static inline void rb_link_node(struct rb_node *node, struct rb_node *parent,  				struct rb_node **rb_link) diff --git a/include/linux/rculist_nulls.h b/include/linux/rculist_nulls.h index a328e8181e49..e4b257ff881b 100644 --- a/include/linux/rculist_nulls.h +++ b/include/linux/rculist_nulls.h @@ -101,44 +101,6 @@ static inline void hlist_nulls_add_head_rcu(struct hlist_nulls_node *n,  }  /** - * hlist_nulls_add_tail_rcu - * @n: the element to add to the hash list. - * @h: the list to add to. - * - * Description: - * Adds the specified element to the end of the specified hlist_nulls, - * while permitting racing traversals.  NOTE: tail insertion requires - * list traversal. - * - * The caller must take whatever precautions are necessary - * (such as holding appropriate locks) to avoid racing - * with another list-mutation primitive, such as hlist_nulls_add_head_rcu() - * or hlist_nulls_del_rcu(), running on this same list. - * However, it is perfectly legal to run concurrently with - * the _rcu list-traversal primitives, such as - * hlist_nulls_for_each_entry_rcu(), used to prevent memory-consistency - * problems on Alpha CPUs.  Regardless of the type of CPU, the - * list-traversal primitive must be guarded by rcu_read_lock(). - */ -static inline void hlist_nulls_add_tail_rcu(struct hlist_nulls_node *n, -					struct hlist_nulls_head *h) -{ -	struct hlist_nulls_node *i, *last = NULL; - -	for (i = hlist_nulls_first_rcu(h); !is_a_nulls(i); -	     i = hlist_nulls_next_rcu(i)) -		last = i; - -	if (last) { -		n->next = last->next; -		n->pprev = &last->next; -		rcu_assign_pointer(hlist_nulls_next_rcu(last), n); -	} else { -		hlist_nulls_add_head_rcu(n, h); -	} -} - -/**   * hlist_nulls_for_each_entry_rcu - iterate over rcu list of given type   * @tpos:	the type * to use as a loop cursor.   * @pos:	the &struct hlist_nulls_node to use as a loop cursor. diff --git a/include/linux/rwlock_types.h b/include/linux/rwlock_types.h index cc0072e93e36..857a72ceb794 100644 --- a/include/linux/rwlock_types.h +++ b/include/linux/rwlock_types.h @@ -10,9 +10,6 @@   */  typedef struct {  	arch_rwlock_t raw_lock; -#ifdef CONFIG_GENERIC_LOCKBREAK -	unsigned int break_lock; -#endif  #ifdef CONFIG_DEBUG_SPINLOCK  	unsigned int magic, owner_cpu;  	void *owner; diff --git a/include/linux/sched.h b/include/linux/sched.h index 21991d668d35..d2588263a989 100644 --- a/include/linux/sched.h +++ b/include/linux/sched.h @@ -849,17 +849,6 @@ struct task_struct {  	struct held_lock		held_locks[MAX_LOCK_DEPTH];  #endif -#ifdef CONFIG_LOCKDEP_CROSSRELEASE -#define MAX_XHLOCKS_NR 64UL -	struct hist_lock *xhlocks; /* Crossrelease history locks */ -	unsigned int xhlock_idx; -	/* For restoring at history boundaries */ -	unsigned int xhlock_idx_hist[XHLOCK_CTX_NR]; -	unsigned int hist_id; -	/* For overwrite check at each context exit */ -	unsigned int hist_id_save[XHLOCK_CTX_NR]; -#endif -  #ifdef CONFIG_UBSAN  	unsigned int			in_ubsan;  #endif @@ -1503,7 +1492,11 @@ static inline void set_task_comm(struct task_struct *tsk, const char *from)  	__set_task_comm(tsk, from, false);  } -extern char *get_task_comm(char *to, struct task_struct *tsk); +extern char *__get_task_comm(char *to, size_t len, struct task_struct *tsk); +#define get_task_comm(buf, tsk) ({			\ +	BUILD_BUG_ON(sizeof(buf) != TASK_COMM_LEN);	\ +	__get_task_comm(buf, sizeof(buf), tsk);		\ +})  #ifdef CONFIG_SMP  void scheduler_ipi(void); diff --git a/include/linux/sched/coredump.h b/include/linux/sched/coredump.h index 9c8847395b5e..ec912d01126f 100644 --- a/include/linux/sched/coredump.h +++ b/include/linux/sched/coredump.h @@ -70,6 +70,7 @@ static inline int get_dumpable(struct mm_struct *mm)  #define MMF_UNSTABLE		22	/* mm is unstable for copy_from_user */  #define MMF_HUGE_ZERO_PAGE	23      /* mm has ever used the global huge zero page */  #define MMF_DISABLE_THP		24	/* disable THP for all VMAs */ +#define MMF_OOM_VICTIM		25	/* mm is the oom victim */  #define MMF_DISABLE_THP_MASK	(1 << MMF_DISABLE_THP)  #define MMF_INIT_MASK		(MMF_DUMPABLE_MASK | MMF_DUMP_FILTER_MASK |\ diff --git a/include/linux/serdev.h b/include/linux/serdev.h index e69402d4a8ae..d609e6dc5bad 100644 --- a/include/linux/serdev.h +++ b/include/linux/serdev.h @@ -184,7 +184,7 @@ static inline int serdev_controller_receive_buf(struct serdev_controller *ctrl,  	struct serdev_device *serdev = ctrl->serdev;  	if (!serdev || !serdev->ops->receive_buf) -		return -EINVAL; +		return 0;  	return serdev->ops->receive_buf(serdev, data, count);  } diff --git a/include/linux/sh_eth.h b/include/linux/sh_eth.h index ff3642d267f7..94081e9a5010 100644 --- a/include/linux/sh_eth.h +++ b/include/linux/sh_eth.h @@ -17,7 +17,6 @@ struct sh_eth_plat_data {  	unsigned char mac_addr[ETH_ALEN];  	unsigned no_ether_link:1;  	unsigned ether_link_active_low:1; -	unsigned needs_init:1;  };  #endif diff --git a/include/linux/skbuff.h b/include/linux/skbuff.h index bc486ef23f20..a38c80e9f91e 100644 --- a/include/linux/skbuff.h +++ b/include/linux/skbuff.h @@ -1406,8 +1406,7 @@ static inline struct sk_buff *skb_get(struct sk_buff *skb)  }  /* - * If users == 1, we are the only owner and are can avoid redundant - * atomic change. + * If users == 1, we are the only owner and can avoid redundant atomic changes.   */  /** diff --git a/include/linux/spi/spi.h b/include/linux/spi/spi.h index 7b2170bfd6e7..bc6bb325d1bf 100644 --- a/include/linux/spi/spi.h +++ b/include/linux/spi/spi.h @@ -126,7 +126,7 @@ void spi_statistics_add_transfer_stats(struct spi_statistics *stats,   *	for that name.  This appears in the sysfs "modalias" attribute   *	for driver coldplugging, and in uevents used for hotplugging   * @cs_gpio: gpio number of the chipselect line (optional, -ENOENT when - *	when not using a GPIO line) + *	not using a GPIO line)   *   * @statistics: statistics for the spi_device   * diff --git a/include/linux/spinlock.h b/include/linux/spinlock.h index a39186194cd6..3bf273538840 100644 --- a/include/linux/spinlock.h +++ b/include/linux/spinlock.h @@ -107,16 +107,11 @@ do {								\  #define raw_spin_is_locked(lock)	arch_spin_is_locked(&(lock)->raw_lock) -#ifdef CONFIG_GENERIC_LOCKBREAK -#define raw_spin_is_contended(lock) ((lock)->break_lock) -#else -  #ifdef arch_spin_is_contended  #define raw_spin_is_contended(lock)	arch_spin_is_contended(&(lock)->raw_lock)  #else  #define raw_spin_is_contended(lock)	(((void)(lock), 0))  #endif /*arch_spin_is_contended*/ -#endif  /*   * This barrier must provide two things: diff --git a/include/linux/spinlock_types.h b/include/linux/spinlock_types.h index 73548eb13a5d..24b4e6f2c1a2 100644 --- a/include/linux/spinlock_types.h +++ b/include/linux/spinlock_types.h @@ -19,9 +19,6 @@  typedef struct raw_spinlock {  	arch_spinlock_t raw_lock; -#ifdef CONFIG_GENERIC_LOCKBREAK -	unsigned int break_lock; -#endif  #ifdef CONFIG_DEBUG_SPINLOCK  	unsigned int magic, owner_cpu;  	void *owner; diff --git a/include/linux/string.h b/include/linux/string.h index 410ecf17de3c..cfd83eb2f926 100644 --- a/include/linux/string.h +++ b/include/linux/string.h @@ -259,7 +259,10 @@ __FORTIFY_INLINE __kernel_size_t strlen(const char *p)  {  	__kernel_size_t ret;  	size_t p_size = __builtin_object_size(p, 0); -	if (p_size == (size_t)-1) + +	/* Work around gcc excess stack consumption issue */ +	if (p_size == (size_t)-1 || +	    (__builtin_constant_p(p[p_size - 1]) && p[p_size - 1] == '\0'))  		return __builtin_strlen(p);  	ret = strnlen(p, p_size);  	if (p_size <= ret) diff --git a/include/linux/sunrpc/cache.h b/include/linux/sunrpc/cache.h index 270bad0e1bed..40d2822f0e2f 100644 --- a/include/linux/sunrpc/cache.h +++ b/include/linux/sunrpc/cache.h @@ -213,7 +213,7 @@ extern void __init cache_initialize(void);  extern int cache_register_net(struct cache_detail *cd, struct net *net);  extern void cache_unregister_net(struct cache_detail *cd, struct net *net); -extern struct cache_detail *cache_create_net(struct cache_detail *tmpl, struct net *net); +extern struct cache_detail *cache_create_net(const struct cache_detail *tmpl, struct net *net);  extern void cache_destroy_net(struct cache_detail *cd, struct net *net);  extern void sunrpc_init_cache_detail(struct cache_detail *cd); diff --git a/include/linux/sysfs.h b/include/linux/sysfs.h index e32dfe098e82..40839c02d28c 100644 --- a/include/linux/sysfs.h +++ b/include/linux/sysfs.h @@ -117,6 +117,12 @@ struct attribute_group {  	.show	= _name##_show,						\  } +#define __ATTR_RO_MODE(_name, _mode) {					\ +	.attr	= { .name = __stringify(_name),				\ +		    .mode = VERIFY_OCTAL_PERMISSIONS(_mode) },		\ +	.show	= _name##_show,						\ +} +  #define __ATTR_WO(_name) {						\  	.attr	= { .name = __stringify(_name), .mode = S_IWUSR },	\  	.store	= _name##_store,					\ diff --git a/include/linux/tcp.h b/include/linux/tcp.h index df5d97a85e1a..ca4a6361389b 100644 --- a/include/linux/tcp.h +++ b/include/linux/tcp.h @@ -224,7 +224,8 @@ struct tcp_sock {  		rate_app_limited:1,  /* rate_{delivered,interval_us} limited? */  		fastopen_connect:1, /* FASTOPEN_CONNECT sockopt */  		fastopen_no_cookie:1, /* Allow send/recv SYN+data without a cookie */ -		unused:3; +		is_sack_reneg:1,    /* in recovery from loss with SACK reneg? */ +		unused:2;  	u8	nonagle     : 4,/* Disable Nagle algorithm?             */  		thin_lto    : 1,/* Use linear timeouts for thin streams */  		unused1	    : 1, diff --git a/include/linux/tick.h b/include/linux/tick.h index f442d1a42025..7cc35921218e 100644 --- a/include/linux/tick.h +++ b/include/linux/tick.h @@ -119,6 +119,7 @@ extern void tick_nohz_idle_exit(void);  extern void tick_nohz_irq_exit(void);  extern ktime_t tick_nohz_get_sleep_length(void);  extern unsigned long tick_nohz_get_idle_calls(void); +extern unsigned long tick_nohz_get_idle_calls_cpu(int cpu);  extern u64 get_cpu_idle_time_us(int cpu, u64 *last_update_time);  extern u64 get_cpu_iowait_time_us(int cpu, u64 *last_update_time);  #else /* !CONFIG_NO_HZ_COMMON */ diff --git a/include/linux/timer.h b/include/linux/timer.h index 04af640ea95b..2448f9cc48a3 100644 --- a/include/linux/timer.h +++ b/include/linux/timer.h @@ -207,9 +207,11 @@ unsigned long round_jiffies_up(unsigned long j);  unsigned long round_jiffies_up_relative(unsigned long j);  #ifdef CONFIG_HOTPLUG_CPU +int timers_prepare_cpu(unsigned int cpu);  int timers_dead_cpu(unsigned int cpu);  #else -#define timers_dead_cpu NULL +#define timers_prepare_cpu	NULL +#define timers_dead_cpu		NULL  #endif  #endif diff --git a/include/linux/trace.h b/include/linux/trace.h index d24991c1fef3..b95ffb2188ab 100644 --- a/include/linux/trace.h +++ b/include/linux/trace.h @@ -18,7 +18,7 @@   */  struct trace_export {  	struct trace_export __rcu	*next; -	void (*write)(const void *, unsigned int); +	void (*write)(struct trace_export *, const void *, unsigned int);  };  int register_ftrace_export(struct trace_export *export); diff --git a/include/linux/usb/usbnet.h b/include/linux/usb/usbnet.h index a69877734c4e..e2ec3582e549 100644 --- a/include/linux/usb/usbnet.h +++ b/include/linux/usb/usbnet.h @@ -82,6 +82,7 @@ struct usbnet {  #		define EVENT_RX_KILL	10  #		define EVENT_LINK_CHANGE	11  #		define EVENT_SET_RX_MODE	12 +#		define EVENT_NO_IP_ALIGN	13  };  static inline struct usb_driver *driver_of(struct usb_interface *intf) diff --git a/include/linux/vermagic.h b/include/linux/vermagic.h index bae807eb2933..853291714ae0 100644 --- a/include/linux/vermagic.h +++ b/include/linux/vermagic.h @@ -31,11 +31,17 @@  #else  #define MODULE_RANDSTRUCT_PLUGIN  #endif +#ifdef RETPOLINE +#define MODULE_VERMAGIC_RETPOLINE "retpoline " +#else +#define MODULE_VERMAGIC_RETPOLINE "" +#endif  #define VERMAGIC_STRING 						\  	UTS_RELEASE " "							\  	MODULE_VERMAGIC_SMP MODULE_VERMAGIC_PREEMPT 			\  	MODULE_VERMAGIC_MODULE_UNLOAD MODULE_VERMAGIC_MODVERSIONS	\  	MODULE_ARCH_VERMAGIC						\ -	MODULE_RANDSTRUCT_PLUGIN +	MODULE_RANDSTRUCT_PLUGIN					\ +	MODULE_VERMAGIC_RETPOLINE diff --git a/include/net/arp.h b/include/net/arp.h index dc8cd47f883b..977aabfcdc03 100644 --- a/include/net/arp.h +++ b/include/net/arp.h @@ -20,6 +20,9 @@ static inline u32 arp_hashfn(const void *pkey, const struct net_device *dev, u32  static inline struct neighbour *__ipv4_neigh_lookup_noref(struct net_device *dev, u32 key)  { +	if (dev->flags & (IFF_LOOPBACK | IFF_POINTOPOINT)) +		key = INADDR_ANY; +  	return ___neigh_lookup_noref(&arp_tbl, neigh_key_eq32, arp_hashfn, &key, dev);  } diff --git a/include/net/cfg80211.h b/include/net/cfg80211.h index 8b8118a7fadb..fb94a8bd8ab5 100644 --- a/include/net/cfg80211.h +++ b/include/net/cfg80211.h @@ -815,6 +815,8 @@ struct cfg80211_csa_settings {  	u8 count;  }; +#define CFG80211_MAX_NUM_DIFFERENT_CHANNELS 10 +  /**   * struct iface_combination_params - input parameters for interface combinations   * @@ -3226,7 +3228,6 @@ struct cfg80211_ops {   * @WIPHY_FLAG_IBSS_RSN: The device supports IBSS RSN.   * @WIPHY_FLAG_MESH_AUTH: The device supports mesh authentication by routing   *	auth frames to userspace. See @NL80211_MESH_SETUP_USERSPACE_AUTH. - * @WIPHY_FLAG_SUPPORTS_SCHED_SCAN: The device supports scheduled scans.   * @WIPHY_FLAG_SUPPORTS_FW_ROAM: The device supports roaming feature in the   *	firmware.   * @WIPHY_FLAG_AP_UAPSD: The device supports uapsd on AP. diff --git a/include/net/gue.h b/include/net/gue.h index 2fdb29ca74c2..fdad41469b65 100644 --- a/include/net/gue.h +++ b/include/net/gue.h @@ -44,10 +44,10 @@ struct guehdr {  #else  #error  "Please fix <asm/byteorder.h>"  #endif -			__u8    proto_ctype; -			__u16   flags; +			__u8	proto_ctype; +			__be16	flags;  		}; -		__u32 word; +		__be32	word;  	};  }; @@ -84,11 +84,10 @@ static inline size_t guehdr_priv_flags_len(__be32 flags)   * if there is an unknown standard or private flags, or the options length for   * the flags exceeds the options length specific in hlen of the GUE header.   */ -static inline int validate_gue_flags(struct guehdr *guehdr, -				     size_t optlen) +static inline int validate_gue_flags(struct guehdr *guehdr, size_t optlen)  { +	__be16 flags = guehdr->flags;  	size_t len; -	__be32 flags = guehdr->flags;  	if (flags & ~GUE_FLAGS_ALL)  		return 1; @@ -101,12 +100,13 @@ static inline int validate_gue_flags(struct guehdr *guehdr,  		/* Private flags are last four bytes accounted in  		 * guehdr_flags_len  		 */ -		flags = *(__be32 *)((void *)&guehdr[1] + len - GUE_LEN_PRIV); +		__be32 pflags = *(__be32 *)((void *)&guehdr[1] + +					    len - GUE_LEN_PRIV); -		if (flags & ~GUE_PFLAGS_ALL) +		if (pflags & ~GUE_PFLAGS_ALL)  			return 1; -		len += guehdr_priv_flags_len(flags); +		len += guehdr_priv_flags_len(pflags);  		if (len > optlen)  			return 1;  	} diff --git a/include/net/ip.h b/include/net/ip.h index 9896f46cbbf1..af8addbaa3c1 100644 --- a/include/net/ip.h +++ b/include/net/ip.h @@ -34,6 +34,7 @@  #include <net/flow_dissector.h>  #define IPV4_MAX_PMTU		65535U		/* RFC 2675, Section 5.1 */ +#define IPV4_MIN_MTU		68			/* RFC 791 */  struct sock; diff --git a/include/net/mac80211.h b/include/net/mac80211.h index cc9073e45be9..eec143cca1c0 100644 --- a/include/net/mac80211.h +++ b/include/net/mac80211.h @@ -4470,18 +4470,24 @@ struct sk_buff *ieee80211_pspoll_get(struct ieee80211_hw *hw,   * ieee80211_nullfunc_get - retrieve a nullfunc template   * @hw: pointer obtained from ieee80211_alloc_hw().   * @vif: &struct ieee80211_vif pointer from the add_interface callback. + * @qos_ok: QoS NDP is acceptable to the caller, this should be set + *	if at all possible   *   * Creates a Nullfunc template which can, for example, uploaded to   * hardware. The template must be updated after association so that correct   * BSSID and address is used.   * + * If @qos_ndp is set and the association is to an AP with QoS/WMM, the + * returned packet will be QoS NDP. + *   * Note: Caller (or hardware) is responsible for setting the   * &IEEE80211_FCTL_PM bit as well as Duration and Sequence Control fields.   *   * Return: The nullfunc template. %NULL on error.   */  struct sk_buff *ieee80211_nullfunc_get(struct ieee80211_hw *hw, -				       struct ieee80211_vif *vif); +				       struct ieee80211_vif *vif, +				       bool qos_ok);  /**   * ieee80211_probereq_get - retrieve a Probe Request template diff --git a/include/net/pkt_cls.h b/include/net/pkt_cls.h index 0105445cab83..8e08b6da72f3 100644 --- a/include/net/pkt_cls.h +++ b/include/net/pkt_cls.h @@ -694,9 +694,7 @@ struct tc_cls_matchall_offload {  };  enum tc_clsbpf_command { -	TC_CLSBPF_ADD, -	TC_CLSBPF_REPLACE, -	TC_CLSBPF_DESTROY, +	TC_CLSBPF_OFFLOAD,  	TC_CLSBPF_STATS,  }; @@ -705,6 +703,7 @@ struct tc_cls_bpf_offload {  	enum tc_clsbpf_command command;  	struct tcf_exts *exts;  	struct bpf_prog *prog; +	struct bpf_prog *oldprog;  	const char *name;  	bool exts_integrated;  	u32 gen_flags; diff --git a/include/net/red.h b/include/net/red.h index 9a9347710701..9665582c4687 100644 --- a/include/net/red.h +++ b/include/net/red.h @@ -168,6 +168,17 @@ static inline void red_set_vars(struct red_vars *v)  	v->qcount	= -1;  } +static inline bool red_check_params(u32 qth_min, u32 qth_max, u8 Wlog) +{ +	if (fls(qth_min) + Wlog > 32) +		return false; +	if (fls(qth_max) + Wlog > 32) +		return false; +	if (qth_max < qth_min) +		return false; +	return true; +} +  static inline void red_set_parms(struct red_parms *p,  				 u32 qth_min, u32 qth_max, u8 Wlog, u8 Plog,  				 u8 Scell_log, u8 *stab, u32 max_P) @@ -179,7 +190,7 @@ static inline void red_set_parms(struct red_parms *p,  	p->qth_max	= qth_max << Wlog;  	p->Wlog		= Wlog;  	p->Plog		= Plog; -	if (delta < 0) +	if (delta <= 0)  		delta = 1;  	p->qth_delta	= delta;  	if (!max_P) { diff --git a/include/net/sch_generic.h b/include/net/sch_generic.h index 65d0d25f2648..becf86aa4ac6 100644 --- a/include/net/sch_generic.h +++ b/include/net/sch_generic.h @@ -71,6 +71,7 @@ struct Qdisc {  				      * qdisc_tree_decrease_qlen() should stop.  				      */  #define TCQ_F_INVISIBLE		0x80 /* invisible by default in dump */ +#define TCQ_F_OFFLOADED		0x200 /* qdisc is offloaded to HW */  	u32			limit;  	const struct Qdisc_ops	*ops;  	struct qdisc_size_table	__rcu *stab; @@ -178,6 +179,7 @@ struct Qdisc_ops {  	const struct Qdisc_class_ops	*cl_ops;  	char			id[IFNAMSIZ];  	int			priv_size; +	unsigned int		static_flags;  	int 			(*enqueue)(struct sk_buff *skb,  					   struct Qdisc *sch, @@ -443,6 +445,7 @@ void qdisc_tree_reduce_backlog(struct Qdisc *qdisc, unsigned int n,  			       unsigned int len);  struct Qdisc *qdisc_alloc(struct netdev_queue *dev_queue,  			  const struct Qdisc_ops *ops); +void qdisc_free(struct Qdisc *qdisc);  struct Qdisc *qdisc_create_dflt(struct netdev_queue *dev_queue,  				const struct Qdisc_ops *ops, u32 parentid);  void __qdisc_calculate_pkt_len(struct sk_buff *skb, diff --git a/include/net/sctp/checksum.h b/include/net/sctp/checksum.h index 4a5b9a306c69..32ee65a30aff 100644 --- a/include/net/sctp/checksum.h +++ b/include/net/sctp/checksum.h @@ -48,31 +48,32 @@ static inline __wsum sctp_csum_update(const void *buff, int len, __wsum sum)  	/* This uses the crypto implementation of crc32c, which is either  	 * implemented w/ hardware support or resolves to __crc32c_le().  	 */ -	return crc32c(sum, buff, len); +	return (__force __wsum)crc32c((__force __u32)sum, buff, len);  }  static inline __wsum sctp_csum_combine(__wsum csum, __wsum csum2,  				       int offset, int len)  { -	return __crc32c_le_combine(csum, csum2, len); +	return (__force __wsum)__crc32c_le_combine((__force __u32)csum, +						   (__force __u32)csum2, len);  }  static inline __le32 sctp_compute_cksum(const struct sk_buff *skb,  					unsigned int offset)  {  	struct sctphdr *sh = sctp_hdr(skb); -        __le32 ret, old = sh->checksum;  	const struct skb_checksum_ops ops = {  		.update  = sctp_csum_update,  		.combine = sctp_csum_combine,  	}; +	__le32 old = sh->checksum; +	__wsum new;  	sh->checksum = 0; -	ret = cpu_to_le32(~__skb_checksum(skb, offset, skb->len - offset, -					  ~(__u32)0, &ops)); +	new = ~__skb_checksum(skb, offset, skb->len - offset, ~(__wsum)0, &ops);  	sh->checksum = old; -	return ret; +	return cpu_to_le32((__force __u32)new);  }  #endif /* __sctp_checksum_h__ */ diff --git a/include/net/sctp/sctp.h b/include/net/sctp/sctp.h index 749a42882437..906a9c0efa71 100644 --- a/include/net/sctp/sctp.h +++ b/include/net/sctp/sctp.h @@ -195,6 +195,11 @@ void sctp_remaddr_proc_exit(struct net *net);  int sctp_offload_init(void);  /* + * sctp/stream_sched.c + */ +void sctp_sched_ops_init(void); + +/*   * sctp/stream.c   */  int sctp_send_reset_streams(struct sctp_association *asoc, diff --git a/include/net/sctp/stream_sched.h b/include/net/sctp/stream_sched.h index c676550a4c7d..5c5da48f65e7 100644 --- a/include/net/sctp/stream_sched.h +++ b/include/net/sctp/stream_sched.h @@ -69,4 +69,9 @@ void sctp_sched_dequeue_common(struct sctp_outq *q, struct sctp_chunk *ch);  int sctp_sched_init_sid(struct sctp_stream *stream, __u16 sid, gfp_t gfp);  struct sctp_sched_ops *sctp_sched_ops_from_stream(struct sctp_stream *stream); +void sctp_sched_ops_register(enum sctp_sched_type sched, +			     struct sctp_sched_ops *sched_ops); +void sctp_sched_ops_prio_init(void); +void sctp_sched_ops_rr_init(void); +  #endif /* __sctp_stream_sched_h__ */ diff --git a/include/net/sctp/structs.h b/include/net/sctp/structs.h index 16f949eef52f..9a5ccf03a59b 100644 --- a/include/net/sctp/structs.h +++ b/include/net/sctp/structs.h @@ -503,7 +503,8 @@ struct sctp_datamsg {  	/* Did the messenge fail to send? */  	int send_error;  	u8 send_failed:1, -	   can_delay;	    /* should this message be Nagle delayed */ +	   can_delay:1,	/* should this message be Nagle delayed */ +	   abandoned:1;	/* should this message be abandoned */  };  struct sctp_datamsg *sctp_datamsg_from_user(struct sctp_association *, @@ -965,7 +966,7 @@ void sctp_transport_burst_limited(struct sctp_transport *);  void sctp_transport_burst_reset(struct sctp_transport *);  unsigned long sctp_transport_timeout(struct sctp_transport *);  void sctp_transport_reset(struct sctp_transport *t); -void sctp_transport_update_pmtu(struct sctp_transport *t, u32 pmtu); +bool sctp_transport_update_pmtu(struct sctp_transport *t, u32 pmtu);  void sctp_transport_immediate_rtx(struct sctp_transport *);  void sctp_transport_dst_release(struct sctp_transport *t);  void sctp_transport_dst_confirm(struct sctp_transport *t); diff --git a/include/net/sock.h b/include/net/sock.h index 79e1a2c7912c..7a7b14e9628a 100644 --- a/include/net/sock.h +++ b/include/net/sock.h @@ -685,11 +685,7 @@ static inline void sk_add_node_rcu(struct sock *sk, struct hlist_head *list)  static inline void __sk_nulls_add_node_rcu(struct sock *sk, struct hlist_nulls_head *list)  { -	if (IS_ENABLED(CONFIG_IPV6) && sk->sk_reuseport && -	    sk->sk_family == AF_INET6) -		hlist_nulls_add_tail_rcu(&sk->sk_nulls_node, list); -	else -		hlist_nulls_add_head_rcu(&sk->sk_nulls_node, list); +	hlist_nulls_add_head_rcu(&sk->sk_nulls_node, list);  }  static inline void sk_nulls_add_node_rcu(struct sock *sk, struct hlist_nulls_head *list) @@ -1518,6 +1514,11 @@ static inline bool sock_owned_by_user(const struct sock *sk)  	return sk->sk_lock.owned;  } +static inline bool sock_owned_by_user_nocheck(const struct sock *sk) +{ +	return sk->sk_lock.owned; +} +  /* no reclassification while locks are held */  static inline bool sock_allow_reclassification(const struct sock *csk)  { diff --git a/include/net/tc_act/tc_sample.h b/include/net/tc_act/tc_sample.h index 524cee4f4c81..01dbfea32672 100644 --- a/include/net/tc_act/tc_sample.h +++ b/include/net/tc_act/tc_sample.h @@ -14,7 +14,6 @@ struct tcf_sample {  	struct psample_group __rcu *psample_group;  	u32 psample_group_num;  	struct list_head tcfm_list; -	struct rcu_head rcu;  };  #define to_sample(a) ((struct tcf_sample *)a) diff --git a/include/net/tcp.h b/include/net/tcp.h index 4e09398009c1..6da880d2f022 100644 --- a/include/net/tcp.h +++ b/include/net/tcp.h @@ -844,12 +844,11 @@ static inline int tcp_v6_sdif(const struct sk_buff *skb)  }  #endif -/* TCP_SKB_CB reference means this can not be used from early demux */  static inline bool inet_exact_dif_match(struct net *net, struct sk_buff *skb)  {  #if IS_ENABLED(CONFIG_NET_L3_MASTER_DEV)  	if (!net->ipv4.sysctl_tcp_l3mdev_accept && -	    skb && ipv4_l3mdev_skb(TCP_SKB_CB(skb)->header.h4.flags)) +	    skb && ipv4_l3mdev_skb(IPCB(skb)->flags))  		return true;  #endif  	return false; @@ -1056,7 +1055,7 @@ void tcp_rate_skb_sent(struct sock *sk, struct sk_buff *skb);  void tcp_rate_skb_delivered(struct sock *sk, struct sk_buff *skb,  			    struct rate_sample *rs);  void tcp_rate_gen(struct sock *sk, u32 delivered, u32 lost, -		  struct rate_sample *rs); +		  bool is_sack_reneg, struct rate_sample *rs);  void tcp_rate_check_app_limited(struct sock *sk);  /* These functions determine how the current flow behaves in respect of SACK diff --git a/include/net/tls.h b/include/net/tls.h index 936cfc5cab7d..9185e53a743c 100644 --- a/include/net/tls.h +++ b/include/net/tls.h @@ -170,7 +170,7 @@ static inline bool tls_is_pending_open_record(struct tls_context *tls_ctx)  static inline void tls_err_abort(struct sock *sk)  { -	sk->sk_err = -EBADMSG; +	sk->sk_err = EBADMSG;  	sk->sk_error_report(sk);  } diff --git a/include/net/vxlan.h b/include/net/vxlan.h index 13223396dc64..f96391e84a8a 100644 --- a/include/net/vxlan.h +++ b/include/net/vxlan.h @@ -146,7 +146,7 @@ struct vxlanhdr_gpe {  		np_applied:1,  		instance_applied:1,  		version:2, -reserved_flags2:2; +		reserved_flags2:2;  #elif defined(__BIG_ENDIAN_BITFIELD)  	u8	reserved_flags2:2,  		version:2, diff --git a/include/net/xfrm.h b/include/net/xfrm.h index dc28a98ce97c..ae35991b5877 100644 --- a/include/net/xfrm.h +++ b/include/net/xfrm.h @@ -1570,6 +1570,9 @@ int xfrm_init_state(struct xfrm_state *x);  int xfrm_prepare_input(struct xfrm_state *x, struct sk_buff *skb);  int xfrm_input(struct sk_buff *skb, int nexthdr, __be32 spi, int encap_type);  int xfrm_input_resume(struct sk_buff *skb, int nexthdr); +int xfrm_trans_queue(struct sk_buff *skb, +		     int (*finish)(struct net *, struct sock *, +				   struct sk_buff *));  int xfrm_output_resume(struct sk_buff *skb, int err);  int xfrm_output(struct sock *sk, struct sk_buff *skb);  int xfrm_inner_extract_output(struct xfrm_state *x, struct sk_buff *skb); diff --git a/include/scsi/libsas.h b/include/scsi/libsas.h index 0f9cbf96c093..6df6fe0c2198 100644 --- a/include/scsi/libsas.h +++ b/include/scsi/libsas.h @@ -159,11 +159,11 @@ struct expander_device {  struct sata_device {  	unsigned int class; -	struct smp_resp        rps_resp; /* report_phy_sata_resp */  	u8     port_no;        /* port number, if this is a PM (Port) */  	struct ata_port *ap;  	struct ata_host ata_host; +	struct smp_resp rps_resp ____cacheline_aligned; /* report_phy_sata_resp */  	u8     fis[ATA_RESP_FIS_SIZE];  }; diff --git a/include/sound/hdaudio_ext.h b/include/sound/hdaudio_ext.h index ca00130cb028..9c14e21dda85 100644 --- a/include/sound/hdaudio_ext.h +++ b/include/sound/hdaudio_ext.h @@ -193,7 +193,7 @@ struct hda_dai_map {   * @pvt_data - private data, for asoc contains asoc codec object   */  struct hdac_ext_device { -	struct hdac_device hdac; +	struct hdac_device hdev;  	struct hdac_ext_bus *ebus;  	/* soc-dai to nid map */ @@ -213,7 +213,7 @@ struct hdac_ext_dma_params {  	u8 stream_tag;  };  #define to_ehdac_device(dev) (container_of((dev), \ -				 struct hdac_ext_device, hdac)) +				 struct hdac_ext_device, hdev))  /*   * HD-audio codec base driver   */ diff --git a/include/sound/pcm.h b/include/sound/pcm.h index 24febf9e177c..e054c583d3b3 100644 --- a/include/sound/pcm.h +++ b/include/sound/pcm.h @@ -169,6 +169,10 @@ struct snd_pcm_ops {  #define SNDRV_PCM_FMTBIT_IMA_ADPCM	_SNDRV_PCM_FMTBIT(IMA_ADPCM)  #define SNDRV_PCM_FMTBIT_MPEG		_SNDRV_PCM_FMTBIT(MPEG)  #define SNDRV_PCM_FMTBIT_GSM		_SNDRV_PCM_FMTBIT(GSM) +#define SNDRV_PCM_FMTBIT_S20_LE	_SNDRV_PCM_FMTBIT(S20_LE) +#define SNDRV_PCM_FMTBIT_U20_LE	_SNDRV_PCM_FMTBIT(U20_LE) +#define SNDRV_PCM_FMTBIT_S20_BE	_SNDRV_PCM_FMTBIT(S20_BE) +#define SNDRV_PCM_FMTBIT_U20_BE	_SNDRV_PCM_FMTBIT(U20_BE)  #define SNDRV_PCM_FMTBIT_SPECIAL	_SNDRV_PCM_FMTBIT(SPECIAL)  #define SNDRV_PCM_FMTBIT_S24_3LE	_SNDRV_PCM_FMTBIT(S24_3LE)  #define SNDRV_PCM_FMTBIT_U24_3LE	_SNDRV_PCM_FMTBIT(U24_3LE) @@ -202,6 +206,8 @@ struct snd_pcm_ops {  #define SNDRV_PCM_FMTBIT_FLOAT		SNDRV_PCM_FMTBIT_FLOAT_LE  #define SNDRV_PCM_FMTBIT_FLOAT64	SNDRV_PCM_FMTBIT_FLOAT64_LE  #define SNDRV_PCM_FMTBIT_IEC958_SUBFRAME SNDRV_PCM_FMTBIT_IEC958_SUBFRAME_LE +#define SNDRV_PCM_FMTBIT_S20		SNDRV_PCM_FMTBIT_S20_LE +#define SNDRV_PCM_FMTBIT_U20		SNDRV_PCM_FMTBIT_U20_LE  #endif  #ifdef SNDRV_BIG_ENDIAN  #define SNDRV_PCM_FMTBIT_S16		SNDRV_PCM_FMTBIT_S16_BE @@ -213,6 +219,8 @@ struct snd_pcm_ops {  #define SNDRV_PCM_FMTBIT_FLOAT		SNDRV_PCM_FMTBIT_FLOAT_BE  #define SNDRV_PCM_FMTBIT_FLOAT64	SNDRV_PCM_FMTBIT_FLOAT64_BE  #define SNDRV_PCM_FMTBIT_IEC958_SUBFRAME SNDRV_PCM_FMTBIT_IEC958_SUBFRAME_BE +#define SNDRV_PCM_FMTBIT_S20		SNDRV_PCM_FMTBIT_S20_BE +#define SNDRV_PCM_FMTBIT_U20		SNDRV_PCM_FMTBIT_U20_BE  #endif  struct snd_pcm_file { diff --git a/include/sound/rt5514.h b/include/sound/rt5514.h index ef18494769ee..64d027dbaaca 100644 --- a/include/sound/rt5514.h +++ b/include/sound/rt5514.h @@ -14,6 +14,8 @@  struct rt5514_platform_data {  	unsigned int dmic_init_delay; +	const char *dsp_calib_clk_name; +	unsigned int dsp_calib_clk_rate;  };  #endif diff --git a/include/sound/rt5645.h b/include/sound/rt5645.h index d0c33a9972b9..f218c742f08e 100644 --- a/include/sound/rt5645.h +++ b/include/sound/rt5645.h @@ -25,6 +25,9 @@ struct rt5645_platform_data {  	bool level_trigger_irq;  	/* Invert JD1_1 status polarity */  	bool inv_jd1_1; + +	/* Value to asign to snd_soc_card.long_name */ +	const char *long_name;  };  #endif diff --git a/include/sound/soc-acpi-intel-match.h b/include/sound/soc-acpi-intel-match.h index 1a9191cd4bb3..9da6388c20a1 100644 --- a/include/sound/soc-acpi-intel-match.h +++ b/include/sound/soc-acpi-intel-match.h @@ -16,6 +16,7 @@  #ifndef __LINUX_SND_SOC_ACPI_INTEL_MATCH_H  #define __LINUX_SND_SOC_ACPI_INTEL_MATCH_H +#include <linux/module.h>  #include <linux/stddef.h>  #include <linux/acpi.h> diff --git a/include/sound/soc-acpi.h b/include/sound/soc-acpi.h index a7d8d335b043..082224275f52 100644 --- a/include/sound/soc-acpi.h +++ b/include/sound/soc-acpi.h @@ -17,6 +17,7 @@  #include <linux/stddef.h>  #include <linux/acpi.h> +#include <linux/mod_devicetable.h>  struct snd_soc_acpi_package_context {  	char *name;           /* package name */ @@ -26,17 +27,13 @@ struct snd_soc_acpi_package_context {  	bool data_valid;  }; +/* codec name is used in DAIs is i2c-<HID>:00 with HID being 8 chars */ +#define SND_ACPI_I2C_ID_LEN (4 + ACPI_ID_LEN + 3 + 1) +  #if IS_ENABLED(CONFIG_ACPI) -/* translation fron HID to I2C name, needed for DAI codec_name */ -const char *snd_soc_acpi_find_name_from_hid(const u8 hid[ACPI_ID_LEN]);  bool snd_soc_acpi_find_package_from_hid(const u8 hid[ACPI_ID_LEN],  				    struct snd_soc_acpi_package_context *ctx);  #else -static inline const char * -snd_soc_acpi_find_name_from_hid(const u8 hid[ACPI_ID_LEN]) -{ -	return NULL; -}  static inline bool  snd_soc_acpi_find_package_from_hid(const u8 hid[ACPI_ID_LEN],  				   struct snd_soc_acpi_package_context *ctx) @@ -49,9 +46,6 @@ snd_soc_acpi_find_package_from_hid(const u8 hid[ACPI_ID_LEN],  struct snd_soc_acpi_mach *  snd_soc_acpi_find_machine(struct snd_soc_acpi_mach *machines); -/* acpi check hid */ -bool snd_soc_acpi_check_hid(const u8 hid[ACPI_ID_LEN]); -  /**   * snd_soc_acpi_mach: ACPI-based machine descriptor. Most of the fields are   * related to the hardware, except for the firmware and topology file names. diff --git a/include/sound/soc-dai.h b/include/sound/soc-dai.h index 58acd00cae19..d970879944fc 100644 --- a/include/sound/soc-dai.h +++ b/include/sound/soc-dai.h @@ -102,6 +102,8 @@ struct snd_compr_stream;  			       SNDRV_PCM_FMTBIT_S16_BE |\  			       SNDRV_PCM_FMTBIT_S20_3LE |\  			       SNDRV_PCM_FMTBIT_S20_3BE |\ +			       SNDRV_PCM_FMTBIT_S20_LE |\ +			       SNDRV_PCM_FMTBIT_S20_BE |\  			       SNDRV_PCM_FMTBIT_S24_3LE |\  			       SNDRV_PCM_FMTBIT_S24_3BE |\                                 SNDRV_PCM_FMTBIT_S32_LE |\ diff --git a/include/sound/soc.h b/include/sound/soc.h index 1a7323238c49..747fd583b9dc 100644 --- a/include/sound/soc.h +++ b/include/sound/soc.h @@ -494,6 +494,8 @@ int soc_new_pcm(struct snd_soc_pcm_runtime *rtd, int num);  int snd_soc_new_compress(struct snd_soc_pcm_runtime *rtd, int num);  #endif +void snd_soc_disconnect_sync(struct device *dev); +  struct snd_pcm_substream *snd_soc_get_dai_substream(struct snd_soc_card *card,  		const char *dai_link, int stream);  struct snd_soc_pcm_runtime *snd_soc_get_pcm_runtime(struct snd_soc_card *card, @@ -802,6 +804,9 @@ struct snd_soc_component_driver {  	int (*suspend)(struct snd_soc_component *);  	int (*resume)(struct snd_soc_component *); +	unsigned int (*read)(struct snd_soc_component *, unsigned int); +	int (*write)(struct snd_soc_component *, unsigned int, unsigned int); +  	/* pcm creation and destruction */  	int (*pcm_new)(struct snd_soc_pcm_runtime *);  	void (*pcm_free)(struct snd_pcm *); @@ -836,7 +841,7 @@ struct snd_soc_component_driver {  	/* bits */  	unsigned int idle_bias_on:1;  	unsigned int suspend_bias_off:1; -	unsigned int pmdown_time:1; /* care pmdown_time at stop */ +	unsigned int use_pmdown_time:1; /* care pmdown_time at stop */  	unsigned int endianness:1;  	unsigned int non_legacy_dai_naming:1;  }; @@ -858,12 +863,10 @@ struct snd_soc_component {  	struct list_head card_aux_list; /* for auxiliary bound components */  	struct list_head card_list; -	struct snd_soc_dai_driver *dai_drv; -	int num_dai; -  	const struct snd_soc_component_driver *driver;  	struct list_head dai_list; +	int num_dai;  	int (*read)(struct snd_soc_component *, unsigned int, unsigned int *);  	int (*write)(struct snd_soc_component *, unsigned int, unsigned int); diff --git a/include/trace/events/clk.h b/include/trace/events/clk.h index 758607226bfd..2cd449328aee 100644 --- a/include/trace/events/clk.h +++ b/include/trace/events/clk.h @@ -134,12 +134,12 @@ DECLARE_EVENT_CLASS(clk_parent,  	TP_STRUCT__entry(  		__string(        name,           core->name                ) -		__string(        pname,          parent->name              ) +		__string(        pname, parent ? parent->name : "none"     )  	),  	TP_fast_assign(  		__assign_str(name, core->name); -		__assign_str(pname, parent->name); +		__assign_str(pname, parent ? parent->name : "none");  	),  	TP_printk("%s %s", __get_str(name), __get_str(pname)) diff --git a/include/trace/events/kvm.h b/include/trace/events/kvm.h index e4b0b8e09932..2c735a3e6613 100644 --- a/include/trace/events/kvm.h +++ b/include/trace/events/kvm.h @@ -211,7 +211,7 @@ TRACE_EVENT(kvm_ack_irq,  	{ KVM_TRACE_MMIO_WRITE, "write" }  TRACE_EVENT(kvm_mmio, -	TP_PROTO(int type, int len, u64 gpa, u64 val), +	TP_PROTO(int type, int len, u64 gpa, void *val),  	TP_ARGS(type, len, gpa, val),  	TP_STRUCT__entry( @@ -225,7 +225,10 @@ TRACE_EVENT(kvm_mmio,  		__entry->type		= type;  		__entry->len		= len;  		__entry->gpa		= gpa; -		__entry->val		= val; +		__entry->val		= 0; +		if (val) +			memcpy(&__entry->val, val, +			       min_t(u32, sizeof(__entry->val), len));  	),  	TP_printk("mmio %s len %u gpa 0x%llx val 0x%llx", diff --git a/include/trace/events/preemptirq.h b/include/trace/events/preemptirq.h index f5024c560d8f..9c4eb33c5a1d 100644 --- a/include/trace/events/preemptirq.h +++ b/include/trace/events/preemptirq.h @@ -56,15 +56,18 @@ DEFINE_EVENT(preemptirq_template, preempt_enable,  #include <trace/define_trace.h> -#else /* !CONFIG_PREEMPTIRQ_EVENTS */ +#endif /* !CONFIG_PREEMPTIRQ_EVENTS */ +#if !defined(CONFIG_PREEMPTIRQ_EVENTS) || defined(CONFIG_PROVE_LOCKING)  #define trace_irq_enable(...)  #define trace_irq_disable(...) -#define trace_preempt_enable(...) -#define trace_preempt_disable(...)  #define trace_irq_enable_rcuidle(...)  #define trace_irq_disable_rcuidle(...) +#endif + +#if !defined(CONFIG_PREEMPTIRQ_EVENTS) || !defined(CONFIG_DEBUG_PREEMPT) +#define trace_preempt_enable(...) +#define trace_preempt_disable(...)  #define trace_preempt_enable_rcuidle(...)  #define trace_preempt_disable_rcuidle(...) -  #endif diff --git a/include/trace/events/rxrpc.h b/include/trace/events/rxrpc.h index ebe96796027a..36cb50c111a6 100644 --- a/include/trace/events/rxrpc.h +++ b/include/trace/events/rxrpc.h @@ -49,6 +49,7 @@ enum rxrpc_conn_trace {  	rxrpc_conn_put_client,  	rxrpc_conn_put_service,  	rxrpc_conn_queued, +	rxrpc_conn_reap_service,  	rxrpc_conn_seen,  }; @@ -138,10 +139,24 @@ enum rxrpc_rtt_rx_trace {  enum rxrpc_timer_trace {  	rxrpc_timer_begin, +	rxrpc_timer_exp_ack, +	rxrpc_timer_exp_hard, +	rxrpc_timer_exp_idle, +	rxrpc_timer_exp_keepalive, +	rxrpc_timer_exp_lost_ack, +	rxrpc_timer_exp_normal, +	rxrpc_timer_exp_ping, +	rxrpc_timer_exp_resend,  	rxrpc_timer_expired,  	rxrpc_timer_init_for_reply,  	rxrpc_timer_init_for_send_reply, +	rxrpc_timer_restart,  	rxrpc_timer_set_for_ack, +	rxrpc_timer_set_for_hard, +	rxrpc_timer_set_for_idle, +	rxrpc_timer_set_for_keepalive, +	rxrpc_timer_set_for_lost_ack, +	rxrpc_timer_set_for_normal,  	rxrpc_timer_set_for_ping,  	rxrpc_timer_set_for_resend,  	rxrpc_timer_set_for_send, @@ -150,6 +165,7 @@ enum rxrpc_timer_trace {  enum rxrpc_propose_ack_trace {  	rxrpc_propose_ack_client_tx_end,  	rxrpc_propose_ack_input_data, +	rxrpc_propose_ack_ping_for_keepalive,  	rxrpc_propose_ack_ping_for_lost_ack,  	rxrpc_propose_ack_ping_for_lost_reply,  	rxrpc_propose_ack_ping_for_params, @@ -206,6 +222,7 @@ enum rxrpc_congest_change {  	EM(rxrpc_conn_put_client,		"PTc") \  	EM(rxrpc_conn_put_service,		"PTs") \  	EM(rxrpc_conn_queued,			"QUE") \ +	EM(rxrpc_conn_reap_service,		"RPs") \  	E_(rxrpc_conn_seen,			"SEE")  #define rxrpc_client_traces \ @@ -296,16 +313,31 @@ enum rxrpc_congest_change {  #define rxrpc_timer_traces \  	EM(rxrpc_timer_begin,			"Begin ") \  	EM(rxrpc_timer_expired,			"*EXPR*") \ +	EM(rxrpc_timer_exp_ack,			"ExpAck") \ +	EM(rxrpc_timer_exp_hard,		"ExpHrd") \ +	EM(rxrpc_timer_exp_idle,		"ExpIdl") \ +	EM(rxrpc_timer_exp_keepalive,		"ExpKA ") \ +	EM(rxrpc_timer_exp_lost_ack,		"ExpLoA") \ +	EM(rxrpc_timer_exp_normal,		"ExpNml") \ +	EM(rxrpc_timer_exp_ping,		"ExpPng") \ +	EM(rxrpc_timer_exp_resend,		"ExpRsn") \  	EM(rxrpc_timer_init_for_reply,		"IniRpl") \  	EM(rxrpc_timer_init_for_send_reply,	"SndRpl") \ +	EM(rxrpc_timer_restart,			"Restrt") \  	EM(rxrpc_timer_set_for_ack,		"SetAck") \ +	EM(rxrpc_timer_set_for_hard,		"SetHrd") \ +	EM(rxrpc_timer_set_for_idle,		"SetIdl") \ +	EM(rxrpc_timer_set_for_keepalive,	"KeepAl") \ +	EM(rxrpc_timer_set_for_lost_ack,	"SetLoA") \ +	EM(rxrpc_timer_set_for_normal,		"SetNml") \  	EM(rxrpc_timer_set_for_ping,		"SetPng") \  	EM(rxrpc_timer_set_for_resend,		"SetRTx") \ -	E_(rxrpc_timer_set_for_send,		"SetTx ") +	E_(rxrpc_timer_set_for_send,		"SetSnd")  #define rxrpc_propose_ack_traces \  	EM(rxrpc_propose_ack_client_tx_end,	"ClTxEnd") \  	EM(rxrpc_propose_ack_input_data,	"DataIn ") \ +	EM(rxrpc_propose_ack_ping_for_keepalive, "KeepAlv") \  	EM(rxrpc_propose_ack_ping_for_lost_ack,	"LostAck") \  	EM(rxrpc_propose_ack_ping_for_lost_reply, "LostRpl") \  	EM(rxrpc_propose_ack_ping_for_params,	"Params ") \ @@ -932,39 +964,47 @@ TRACE_EVENT(rxrpc_rtt_rx,  TRACE_EVENT(rxrpc_timer,  	    TP_PROTO(struct rxrpc_call *call, enum rxrpc_timer_trace why, -		     ktime_t now, unsigned long now_j), +		     unsigned long now), -	    TP_ARGS(call, why, now, now_j), +	    TP_ARGS(call, why, now),  	    TP_STRUCT__entry(  		    __field(struct rxrpc_call *,		call		)  		    __field(enum rxrpc_timer_trace,		why		) -		    __field_struct(ktime_t,			now		) -		    __field_struct(ktime_t,			expire_at	) -		    __field_struct(ktime_t,			ack_at		) -		    __field_struct(ktime_t,			resend_at	) -		    __field(unsigned long,			now_j		) -		    __field(unsigned long,			timer		) +		    __field(long,				now		) +		    __field(long,				ack_at		) +		    __field(long,				ack_lost_at	) +		    __field(long,				resend_at	) +		    __field(long,				ping_at		) +		    __field(long,				expect_rx_by	) +		    __field(long,				expect_req_by	) +		    __field(long,				expect_term_by	) +		    __field(long,				timer		)  			     ),  	    TP_fast_assign( -		    __entry->call	= call; -		    __entry->why	= why; -		    __entry->now	= now; -		    __entry->expire_at	= call->expire_at; -		    __entry->ack_at	= call->ack_at; -		    __entry->resend_at	= call->resend_at; -		    __entry->now_j	= now_j; -		    __entry->timer	= call->timer.expires; +		    __entry->call		= call; +		    __entry->why		= why; +		    __entry->now		= now; +		    __entry->ack_at		= call->ack_at; +		    __entry->ack_lost_at	= call->ack_lost_at; +		    __entry->resend_at		= call->resend_at; +		    __entry->expect_rx_by	= call->expect_rx_by; +		    __entry->expect_req_by	= call->expect_req_by; +		    __entry->expect_term_by	= call->expect_term_by; +		    __entry->timer		= call->timer.expires;  			   ), -	    TP_printk("c=%p %s x=%lld a=%lld r=%lld t=%ld", +	    TP_printk("c=%p %s a=%ld la=%ld r=%ld xr=%ld xq=%ld xt=%ld t=%ld",  		      __entry->call,  		      __print_symbolic(__entry->why, rxrpc_timer_traces), -		      ktime_to_ns(ktime_sub(__entry->expire_at, __entry->now)), -		      ktime_to_ns(ktime_sub(__entry->ack_at, __entry->now)), -		      ktime_to_ns(ktime_sub(__entry->resend_at, __entry->now)), -		      __entry->timer - __entry->now_j) +		      __entry->ack_at - __entry->now, +		      __entry->ack_lost_at - __entry->now, +		      __entry->resend_at - __entry->now, +		      __entry->expect_rx_by - __entry->now, +		      __entry->expect_req_by - __entry->now, +		      __entry->expect_term_by - __entry->now, +		      __entry->timer - __entry->now)  	    );  TRACE_EVENT(rxrpc_rx_lose, @@ -1080,7 +1120,7 @@ TRACE_EVENT(rxrpc_congest,  		    memcpy(&__entry->sum, summary, sizeof(__entry->sum));  			   ), -	    TP_printk("c=%p %08x %s %08x %s cw=%u ss=%u nr=%u,%u nw=%u,%u r=%u b=%u u=%u d=%u l=%x%s%s%s", +	    TP_printk("c=%p r=%08x %s q=%08x %s cw=%u ss=%u nr=%u,%u nw=%u,%u r=%u b=%u u=%u d=%u l=%x%s%s%s",  		      __entry->call,  		      __entry->ack_serial,  		      __print_symbolic(__entry->sum.ack_reason, rxrpc_ack_names), diff --git a/include/trace/events/tcp.h b/include/trace/events/tcp.h index 07cccca6cbf1..ab34c561f26b 100644 --- a/include/trace/events/tcp.h +++ b/include/trace/events/tcp.h @@ -25,6 +25,35 @@  		tcp_state_name(TCP_CLOSING),		\  		tcp_state_name(TCP_NEW_SYN_RECV)) +#define TP_STORE_V4MAPPED(__entry, saddr, daddr)		\ +	do {							\ +		struct in6_addr *pin6;				\ +								\ +		pin6 = (struct in6_addr *)__entry->saddr_v6;	\ +		ipv6_addr_set_v4mapped(saddr, pin6);		\ +		pin6 = (struct in6_addr *)__entry->daddr_v6;	\ +		ipv6_addr_set_v4mapped(daddr, pin6);		\ +	} while (0) + +#if IS_ENABLED(CONFIG_IPV6) +#define TP_STORE_ADDRS(__entry, saddr, daddr, saddr6, daddr6)		\ +	do {								\ +		if (sk->sk_family == AF_INET6) {			\ +			struct in6_addr *pin6;				\ +									\ +			pin6 = (struct in6_addr *)__entry->saddr_v6;	\ +			*pin6 = saddr6;					\ +			pin6 = (struct in6_addr *)__entry->daddr_v6;	\ +			*pin6 = daddr6;					\ +		} else {						\ +			TP_STORE_V4MAPPED(__entry, saddr, daddr);	\ +		}							\ +	} while (0) +#else +#define TP_STORE_ADDRS(__entry, saddr, daddr, saddr6, daddr6)	\ +	TP_STORE_V4MAPPED(__entry, saddr, daddr) +#endif +  /*   * tcp event with arguments sk and skb   * @@ -50,7 +79,6 @@ DECLARE_EVENT_CLASS(tcp_event_sk_skb,  	TP_fast_assign(  		struct inet_sock *inet = inet_sk(sk); -		struct in6_addr *pin6;  		__be32 *p32;  		__entry->skbaddr = skb; @@ -65,20 +93,8 @@ DECLARE_EVENT_CLASS(tcp_event_sk_skb,  		p32 = (__be32 *) __entry->daddr;  		*p32 =  inet->inet_daddr; -#if IS_ENABLED(CONFIG_IPV6) -		if (sk->sk_family == AF_INET6) { -			pin6 = (struct in6_addr *)__entry->saddr_v6; -			*pin6 = sk->sk_v6_rcv_saddr; -			pin6 = (struct in6_addr *)__entry->daddr_v6; -			*pin6 = sk->sk_v6_daddr; -		} else -#endif -		{ -			pin6 = (struct in6_addr *)__entry->saddr_v6; -			ipv6_addr_set_v4mapped(inet->inet_saddr, pin6); -			pin6 = (struct in6_addr *)__entry->daddr_v6; -			ipv6_addr_set_v4mapped(inet->inet_daddr, pin6); -		} +		TP_STORE_ADDRS(__entry, inet->inet_saddr, inet->inet_daddr, +			      sk->sk_v6_rcv_saddr, sk->sk_v6_daddr);  	),  	TP_printk("sport=%hu dport=%hu saddr=%pI4 daddr=%pI4 saddrv6=%pI6c daddrv6=%pI6c", @@ -127,7 +143,6 @@ DECLARE_EVENT_CLASS(tcp_event_sk,  	TP_fast_assign(  		struct inet_sock *inet = inet_sk(sk); -		struct in6_addr *pin6;  		__be32 *p32;  		__entry->skaddr = sk; @@ -141,20 +156,8 @@ DECLARE_EVENT_CLASS(tcp_event_sk,  		p32 = (__be32 *) __entry->daddr;  		*p32 =  inet->inet_daddr; -#if IS_ENABLED(CONFIG_IPV6) -		if (sk->sk_family == AF_INET6) { -			pin6 = (struct in6_addr *)__entry->saddr_v6; -			*pin6 = sk->sk_v6_rcv_saddr; -			pin6 = (struct in6_addr *)__entry->daddr_v6; -			*pin6 = sk->sk_v6_daddr; -		} else -#endif -		{ -			pin6 = (struct in6_addr *)__entry->saddr_v6; -			ipv6_addr_set_v4mapped(inet->inet_saddr, pin6); -			pin6 = (struct in6_addr *)__entry->daddr_v6; -			ipv6_addr_set_v4mapped(inet->inet_daddr, pin6); -		} +		TP_STORE_ADDRS(__entry, inet->inet_saddr, inet->inet_daddr, +			       sk->sk_v6_rcv_saddr, sk->sk_v6_daddr);  	),  	TP_printk("sport=%hu dport=%hu saddr=%pI4 daddr=%pI4 saddrv6=%pI6c daddrv6=%pI6c", @@ -197,7 +200,6 @@ TRACE_EVENT(tcp_set_state,  	TP_fast_assign(  		struct inet_sock *inet = inet_sk(sk); -		struct in6_addr *pin6;  		__be32 *p32;  		__entry->skaddr = sk; @@ -213,20 +215,8 @@ TRACE_EVENT(tcp_set_state,  		p32 = (__be32 *) __entry->daddr;  		*p32 =  inet->inet_daddr; -#if IS_ENABLED(CONFIG_IPV6) -		if (sk->sk_family == AF_INET6) { -			pin6 = (struct in6_addr *)__entry->saddr_v6; -			*pin6 = sk->sk_v6_rcv_saddr; -			pin6 = (struct in6_addr *)__entry->daddr_v6; -			*pin6 = sk->sk_v6_daddr; -		} else -#endif -		{ -			pin6 = (struct in6_addr *)__entry->saddr_v6; -			ipv6_addr_set_v4mapped(inet->inet_saddr, pin6); -			pin6 = (struct in6_addr *)__entry->daddr_v6; -			ipv6_addr_set_v4mapped(inet->inet_daddr, pin6); -		} +		TP_STORE_ADDRS(__entry, inet->inet_saddr, inet->inet_daddr, +			       sk->sk_v6_rcv_saddr, sk->sk_v6_daddr);  	),  	TP_printk("sport=%hu dport=%hu saddr=%pI4 daddr=%pI4 saddrv6=%pI6c daddrv6=%pI6c oldstate=%s newstate=%s", @@ -256,7 +246,6 @@ TRACE_EVENT(tcp_retransmit_synack,  	TP_fast_assign(  		struct inet_request_sock *ireq = inet_rsk(req); -		struct in6_addr *pin6;  		__be32 *p32;  		__entry->skaddr = sk; @@ -271,20 +260,8 @@ TRACE_EVENT(tcp_retransmit_synack,  		p32 = (__be32 *) __entry->daddr;  		*p32 = ireq->ir_rmt_addr; -#if IS_ENABLED(CONFIG_IPV6) -		if (sk->sk_family == AF_INET6) { -			pin6 = (struct in6_addr *)__entry->saddr_v6; -			*pin6 = ireq->ir_v6_loc_addr; -			pin6 = (struct in6_addr *)__entry->daddr_v6; -			*pin6 = ireq->ir_v6_rmt_addr; -		} else -#endif -		{ -			pin6 = (struct in6_addr *)__entry->saddr_v6; -			ipv6_addr_set_v4mapped(ireq->ir_loc_addr, pin6); -			pin6 = (struct in6_addr *)__entry->daddr_v6; -			ipv6_addr_set_v4mapped(ireq->ir_rmt_addr, pin6); -		} +		TP_STORE_ADDRS(__entry, ireq->ir_loc_addr, ireq->ir_rmt_addr, +			      ireq->ir_v6_loc_addr, ireq->ir_v6_rmt_addr);  	),  	TP_printk("sport=%hu dport=%hu saddr=%pI4 daddr=%pI4 saddrv6=%pI6c daddrv6=%pI6c", diff --git a/include/trace/events/xdp.h b/include/trace/events/xdp.h index 4cd0f05d0113..8989a92c571a 100644 --- a/include/trace/events/xdp.h +++ b/include/trace/events/xdp.h @@ -8,6 +8,7 @@  #include <linux/netdevice.h>  #include <linux/filter.h>  #include <linux/tracepoint.h> +#include <linux/bpf.h>  #define __XDP_ACT_MAP(FN)	\  	FN(ABORTED)		\ diff --git a/include/uapi/asm-generic/bpf_perf_event.h b/include/uapi/asm-generic/bpf_perf_event.h new file mode 100644 index 000000000000..53815d2cd047 --- /dev/null +++ b/include/uapi/asm-generic/bpf_perf_event.h @@ -0,0 +1,9 @@ +#ifndef _UAPI__ASM_GENERIC_BPF_PERF_EVENT_H__ +#define _UAPI__ASM_GENERIC_BPF_PERF_EVENT_H__ + +#include <linux/ptrace.h> + +/* Export kernel pt_regs structure */ +typedef struct pt_regs bpf_user_pt_regs_t; + +#endif /* _UAPI__ASM_GENERIC_BPF_PERF_EVENT_H__ */ diff --git a/include/uapi/linux/bcache.h b/include/uapi/linux/bcache.h index 90fc490f973f..821f71a2e48f 100644 --- a/include/uapi/linux/bcache.h +++ b/include/uapi/linux/bcache.h @@ -91,7 +91,7 @@ PTR_FIELD(PTR_GEN,			0,  8)  #define PTR_CHECK_DEV			((1 << PTR_DEV_BITS) - 1) -#define PTR(gen, offset, dev)						\ +#define MAKE_PTR(gen, offset, dev)					\  	((((__u64) dev) << 51) | ((__u64) offset) << 8 | gen)  /* Bkey utility code */ diff --git a/include/uapi/linux/bfs_fs.h b/include/uapi/linux/bfs_fs.h index 73445ef07dda..940b04772af8 100644 --- a/include/uapi/linux/bfs_fs.h +++ b/include/uapi/linux/bfs_fs.h @@ -76,7 +76,7 @@ struct bfs_super_block {  #define BFS_FILEBLOCKS(ip) \          ((ip)->i_sblock == 0 ? 0 : (le32_to_cpu((ip)->i_eblock) + 1) -  le32_to_cpu((ip)->i_sblock))  #define BFS_UNCLEAN(bfs_sb, sb)	\ -	((le32_to_cpu(bfs_sb->s_from) != -1) && (le32_to_cpu(bfs_sb->s_to) != -1) && !(sb->s_flags & MS_RDONLY)) +	((le32_to_cpu(bfs_sb->s_from) != -1) && (le32_to_cpu(bfs_sb->s_to) != -1) && !(sb->s_flags & SB_RDONLY))  #endif	/* _LINUX_BFS_FS_H */ diff --git a/include/uapi/linux/bpf_perf_event.h b/include/uapi/linux/bpf_perf_event.h index af549d4ecf1b..8f95303f9d80 100644 --- a/include/uapi/linux/bpf_perf_event.h +++ b/include/uapi/linux/bpf_perf_event.h @@ -8,11 +8,10 @@  #ifndef _UAPI__LINUX_BPF_PERF_EVENT_H__  #define _UAPI__LINUX_BPF_PERF_EVENT_H__ -#include <linux/types.h> -#include <linux/ptrace.h> +#include <asm/bpf_perf_event.h>  struct bpf_perf_event_data { -	struct pt_regs regs; +	bpf_user_pt_regs_t regs;  	__u64 sample_period;  }; diff --git a/include/uapi/linux/if_ether.h b/include/uapi/linux/if_ether.h index 3ee3bf7c8526..144de4d2f385 100644 --- a/include/uapi/linux/if_ether.h +++ b/include/uapi/linux/if_ether.h @@ -23,6 +23,7 @@  #define _UAPI_LINUX_IF_ETHER_H  #include <linux/types.h> +#include <linux/libc-compat.h>  /*   *	IEEE 802.3 Ethernet magic constants.  The frame sizes omit the preamble @@ -149,11 +150,13 @@   *	This is an Ethernet frame header.   */ +#if __UAPI_DEF_ETHHDR  struct ethhdr {  	unsigned char	h_dest[ETH_ALEN];	/* destination eth addr	*/  	unsigned char	h_source[ETH_ALEN];	/* source ether addr	*/  	__be16		h_proto;		/* packet type ID field	*/  } __attribute__((packed)); +#endif  #endif /* _UAPI_LINUX_IF_ETHER_H */ diff --git a/include/uapi/linux/kfd_ioctl.h b/include/uapi/linux/kfd_ioctl.h index 731d0df722e3..6e80501368ae 100644 --- a/include/uapi/linux/kfd_ioctl.h +++ b/include/uapi/linux/kfd_ioctl.h @@ -233,29 +233,29 @@ struct kfd_ioctl_wait_events_args {  };  struct kfd_ioctl_set_scratch_backing_va_args { -	uint64_t va_addr;	/* to KFD */ -	uint32_t gpu_id;	/* to KFD */ -	uint32_t pad; +	__u64 va_addr;	/* to KFD */ +	__u32 gpu_id;	/* to KFD */ +	__u32 pad;  };  struct kfd_ioctl_get_tile_config_args {  	/* to KFD: pointer to tile array */ -	uint64_t tile_config_ptr; +	__u64 tile_config_ptr;  	/* to KFD: pointer to macro tile array */ -	uint64_t macro_tile_config_ptr; +	__u64 macro_tile_config_ptr;  	/* to KFD: array size allocated by user mode  	 * from KFD: array size filled by kernel  	 */ -	uint32_t num_tile_configs; +	__u32 num_tile_configs;  	/* to KFD: array size allocated by user mode  	 * from KFD: array size filled by kernel  	 */ -	uint32_t num_macro_tile_configs; +	__u32 num_macro_tile_configs; -	uint32_t gpu_id;		/* to KFD */ -	uint32_t gb_addr_config;	/* from KFD */ -	uint32_t num_banks;		/* from KFD */ -	uint32_t num_ranks;		/* from KFD */ +	__u32 gpu_id;		/* to KFD */ +	__u32 gb_addr_config;	/* from KFD */ +	__u32 num_banks;		/* from KFD */ +	__u32 num_ranks;		/* from KFD */  	/* struct size can be extended later if needed  	 * without breaking ABI compatibility  	 */ diff --git a/include/uapi/linux/kvm.h b/include/uapi/linux/kvm.h index 282d7613fce8..8fb90a0819c3 100644 --- a/include/uapi/linux/kvm.h +++ b/include/uapi/linux/kvm.h @@ -630,9 +630,9 @@ struct kvm_s390_irq {  struct kvm_s390_irq_state {  	__u64 buf; -	__u32 flags; +	__u32 flags;        /* will stay unused for compatibility reasons */  	__u32 len; -	__u32 reserved[4]; +	__u32 reserved[4];  /* will stay unused for compatibility reasons */  };  /* for KVM_SET_GUEST_DEBUG */ @@ -932,6 +932,8 @@ struct kvm_ppc_resize_hpt {  #define KVM_CAP_HYPERV_SYNIC2 148  #define KVM_CAP_HYPERV_VP_INDEX 149  #define KVM_CAP_S390_AIS_MIGRATION 150 +#define KVM_CAP_PPC_GET_CPU_CHAR 151 +#define KVM_CAP_S390_BPB 152  #ifdef KVM_CAP_IRQ_ROUTING @@ -1261,6 +1263,8 @@ struct kvm_s390_ucas_mapping {  #define KVM_PPC_CONFIGURE_V3_MMU  _IOW(KVMIO,  0xaf, struct kvm_ppc_mmuv3_cfg)  /* Available with KVM_CAP_PPC_RADIX_MMU */  #define KVM_PPC_GET_RMMU_INFO	  _IOW(KVMIO,  0xb0, struct kvm_ppc_rmmu_info) +/* Available with KVM_CAP_PPC_GET_CPU_CHAR */ +#define KVM_PPC_GET_CPU_CHAR	  _IOR(KVMIO,  0xb1, struct kvm_ppc_cpu_char)  /* ioctl for vm fd */  #define KVM_CREATE_DEVICE	  _IOWR(KVMIO,  0xe0, struct kvm_create_device) diff --git a/include/uapi/linux/libc-compat.h b/include/uapi/linux/libc-compat.h index 282875cf8056..fc29efaa918c 100644 --- a/include/uapi/linux/libc-compat.h +++ b/include/uapi/linux/libc-compat.h @@ -168,47 +168,106 @@  /* If we did not see any headers from any supported C libraries,   * or we are being included in the kernel, then define everything - * that we need. */ + * that we need. Check for previous __UAPI_* definitions to give + * unsupported C libraries a way to opt out of any kernel definition. */  #else /* !defined(__GLIBC__) */  /* Definitions for if.h */ +#ifndef __UAPI_DEF_IF_IFCONF  #define __UAPI_DEF_IF_IFCONF 1 +#endif +#ifndef __UAPI_DEF_IF_IFMAP  #define __UAPI_DEF_IF_IFMAP 1 +#endif +#ifndef __UAPI_DEF_IF_IFNAMSIZ  #define __UAPI_DEF_IF_IFNAMSIZ 1 +#endif +#ifndef __UAPI_DEF_IF_IFREQ  #define __UAPI_DEF_IF_IFREQ 1 +#endif  /* Everything up to IFF_DYNAMIC, matches net/if.h until glibc 2.23 */ +#ifndef __UAPI_DEF_IF_NET_DEVICE_FLAGS  #define __UAPI_DEF_IF_NET_DEVICE_FLAGS 1 +#endif  /* For the future if glibc adds IFF_LOWER_UP, IFF_DORMANT and IFF_ECHO */ +#ifndef __UAPI_DEF_IF_NET_DEVICE_FLAGS_LOWER_UP_DORMANT_ECHO  #define __UAPI_DEF_IF_NET_DEVICE_FLAGS_LOWER_UP_DORMANT_ECHO 1 +#endif  /* Definitions for in.h */ +#ifndef __UAPI_DEF_IN_ADDR  #define __UAPI_DEF_IN_ADDR		1 +#endif +#ifndef __UAPI_DEF_IN_IPPROTO  #define __UAPI_DEF_IN_IPPROTO		1 +#endif +#ifndef __UAPI_DEF_IN_PKTINFO  #define __UAPI_DEF_IN_PKTINFO		1 +#endif +#ifndef __UAPI_DEF_IP_MREQ  #define __UAPI_DEF_IP_MREQ		1 +#endif +#ifndef __UAPI_DEF_SOCKADDR_IN  #define __UAPI_DEF_SOCKADDR_IN		1 +#endif +#ifndef __UAPI_DEF_IN_CLASS  #define __UAPI_DEF_IN_CLASS		1 +#endif  /* Definitions for in6.h */ +#ifndef __UAPI_DEF_IN6_ADDR  #define __UAPI_DEF_IN6_ADDR		1 +#endif +#ifndef __UAPI_DEF_IN6_ADDR_ALT  #define __UAPI_DEF_IN6_ADDR_ALT		1 +#endif +#ifndef __UAPI_DEF_SOCKADDR_IN6  #define __UAPI_DEF_SOCKADDR_IN6		1 +#endif +#ifndef __UAPI_DEF_IPV6_MREQ  #define __UAPI_DEF_IPV6_MREQ		1 +#endif +#ifndef __UAPI_DEF_IPPROTO_V6  #define __UAPI_DEF_IPPROTO_V6		1 +#endif +#ifndef __UAPI_DEF_IPV6_OPTIONS  #define __UAPI_DEF_IPV6_OPTIONS		1 +#endif +#ifndef __UAPI_DEF_IN6_PKTINFO  #define __UAPI_DEF_IN6_PKTINFO		1 +#endif +#ifndef __UAPI_DEF_IP6_MTUINFO  #define __UAPI_DEF_IP6_MTUINFO		1 +#endif  /* Definitions for ipx.h */ +#ifndef __UAPI_DEF_SOCKADDR_IPX  #define __UAPI_DEF_SOCKADDR_IPX			1 +#endif +#ifndef __UAPI_DEF_IPX_ROUTE_DEFINITION  #define __UAPI_DEF_IPX_ROUTE_DEFINITION		1 +#endif +#ifndef __UAPI_DEF_IPX_INTERFACE_DEFINITION  #define __UAPI_DEF_IPX_INTERFACE_DEFINITION	1 +#endif +#ifndef __UAPI_DEF_IPX_CONFIG_DATA  #define __UAPI_DEF_IPX_CONFIG_DATA		1 +#endif +#ifndef __UAPI_DEF_IPX_ROUTE_DEF  #define __UAPI_DEF_IPX_ROUTE_DEF		1 +#endif  /* Definitions for xattr.h */ +#ifndef __UAPI_DEF_XATTR  #define __UAPI_DEF_XATTR		1 +#endif  #endif /* __GLIBC__ */ +/* Definitions for if_ether.h */ +/* allow libcs like musl to deactivate this, glibc does not implement this. */ +#ifndef __UAPI_DEF_ETHHDR +#define __UAPI_DEF_ETHHDR		1 +#endif +  #endif /* _UAPI_LIBC_COMPAT_H */ diff --git a/include/uapi/linux/netfilter/nf_conntrack_common.h b/include/uapi/linux/netfilter/nf_conntrack_common.h index 3fea7709a441..57ccfb32e87f 100644 --- a/include/uapi/linux/netfilter/nf_conntrack_common.h +++ b/include/uapi/linux/netfilter/nf_conntrack_common.h @@ -36,7 +36,7 @@ enum ip_conntrack_info {  #define NF_CT_STATE_INVALID_BIT			(1 << 0)  #define NF_CT_STATE_BIT(ctinfo)			(1 << ((ctinfo) % IP_CT_IS_REPLY + 1)) -#define NF_CT_STATE_UNTRACKED_BIT		(1 << (IP_CT_UNTRACKED + 1)) +#define NF_CT_STATE_UNTRACKED_BIT		(1 << 6)  /* Bitset representing status of connection. */  enum ip_conntrack_status { diff --git a/include/uapi/linux/openvswitch.h b/include/uapi/linux/openvswitch.h index 4265d7f9e1f2..dcfab5e3b55c 100644 --- a/include/uapi/linux/openvswitch.h +++ b/include/uapi/linux/openvswitch.h @@ -363,7 +363,6 @@ enum ovs_tunnel_key_attr {  	OVS_TUNNEL_KEY_ATTR_IPV6_SRC,		/* struct in6_addr src IPv6 address. */  	OVS_TUNNEL_KEY_ATTR_IPV6_DST,		/* struct in6_addr dst IPv6 address. */  	OVS_TUNNEL_KEY_ATTR_PAD, -	OVS_TUNNEL_KEY_ATTR_ERSPAN_OPTS,	/* be32 ERSPAN index. */  	__OVS_TUNNEL_KEY_ATTR_MAX  }; diff --git a/include/uapi/linux/pkt_sched.h b/include/uapi/linux/pkt_sched.h index af3cc2f4e1ad..37b5096ae97b 100644 --- a/include/uapi/linux/pkt_sched.h +++ b/include/uapi/linux/pkt_sched.h @@ -256,7 +256,6 @@ struct tc_red_qopt {  #define TC_RED_ECN		1  #define TC_RED_HARDDROP		2  #define TC_RED_ADAPTATIVE	4 -#define TC_RED_OFFLOADED	8  };  struct tc_red_xstats { diff --git a/include/uapi/linux/rtnetlink.h b/include/uapi/linux/rtnetlink.h index d8b5f80c2ea6..843e29aa3cac 100644 --- a/include/uapi/linux/rtnetlink.h +++ b/include/uapi/linux/rtnetlink.h @@ -557,6 +557,7 @@ enum {  	TCA_PAD,  	TCA_DUMP_INVISIBLE,  	TCA_CHAIN, +	TCA_HW_OFFLOAD,  	__TCA_MAX  }; diff --git a/include/uapi/linux/rxrpc.h b/include/uapi/linux/rxrpc.h index 9d4afea308a4..9335d92c14a4 100644 --- a/include/uapi/linux/rxrpc.h +++ b/include/uapi/linux/rxrpc.h @@ -59,6 +59,7 @@ enum rxrpc_cmsg_type {  	RXRPC_EXCLUSIVE_CALL	= 10,	/* s-: Call should be on exclusive connection */  	RXRPC_UPGRADE_SERVICE	= 11,	/* s-: Request service upgrade for client call */  	RXRPC_TX_LENGTH		= 12,	/* s-: Total length of Tx data */ +	RXRPC_SET_CALL_TIMEOUT	= 13,	/* s-: Set one or more call timeouts */  	RXRPC__SUPPORTED  }; diff --git a/include/uapi/linux/usb/ch9.h b/include/uapi/linux/usb/ch9.h index 41a0a81b01e6..c4c79aa331bd 100644 --- a/include/uapi/linux/usb/ch9.h +++ b/include/uapi/linux/usb/ch9.h @@ -880,6 +880,8 @@ struct usb_wireless_cap_descriptor {	/* Ultra Wide Band */  	__u8  bReserved;  } __attribute__((packed)); +#define USB_DT_USB_WIRELESS_CAP_SIZE	11 +  /* USB 2.0 Extension descriptor */  #define	USB_CAP_TYPE_EXT		2 @@ -1072,6 +1074,7 @@ struct usb_ptm_cap_descriptor {  	__u8  bDevCapabilityType;  } __attribute__((packed)); +#define USB_DT_USB_PTM_ID_SIZE		3  /*   * The size of the descriptor for the Sublink Speed Attribute Count   * (SSAC) specified in bmAttributes[4:0]. diff --git a/include/uapi/linux/vm_sockets_diag.h b/include/uapi/linux/vm_sockets_diag.h index 14cd7dc5a187..0b4dd54f3d1e 100644 --- a/include/uapi/linux/vm_sockets_diag.h +++ b/include/uapi/linux/vm_sockets_diag.h @@ -1,3 +1,4 @@ +/* SPDX-License-Identifier: GPL-2.0 WITH Linux-syscall-note */  /* AF_VSOCK sock_diag(7) interface for querying open sockets */  #ifndef _UAPI__VM_SOCKETS_DIAG_H__ diff --git a/include/uapi/sound/asound.h b/include/uapi/sound/asound.h index c227ccba60ae..07d61583fd02 100644 --- a/include/uapi/sound/asound.h +++ b/include/uapi/sound/asound.h @@ -214,6 +214,11 @@ typedef int __bitwise snd_pcm_format_t;  #define	SNDRV_PCM_FORMAT_IMA_ADPCM	((__force snd_pcm_format_t) 22)  #define	SNDRV_PCM_FORMAT_MPEG		((__force snd_pcm_format_t) 23)  #define	SNDRV_PCM_FORMAT_GSM		((__force snd_pcm_format_t) 24) +#define	SNDRV_PCM_FORMAT_S20_LE	((__force snd_pcm_format_t) 25) /* in four bytes, LSB justified */ +#define	SNDRV_PCM_FORMAT_S20_BE	((__force snd_pcm_format_t) 26) /* in four bytes, LSB justified */ +#define	SNDRV_PCM_FORMAT_U20_LE	((__force snd_pcm_format_t) 27) /* in four bytes, LSB justified */ +#define	SNDRV_PCM_FORMAT_U20_BE	((__force snd_pcm_format_t) 28) /* in four bytes, LSB justified */ +/* gap in the numbering for a future standard linear format */  #define	SNDRV_PCM_FORMAT_SPECIAL	((__force snd_pcm_format_t) 31)  #define	SNDRV_PCM_FORMAT_S24_3LE	((__force snd_pcm_format_t) 32)	/* in three bytes */  #define	SNDRV_PCM_FORMAT_S24_3BE	((__force snd_pcm_format_t) 33)	/* in three bytes */ @@ -248,6 +253,8 @@ typedef int __bitwise snd_pcm_format_t;  #define	SNDRV_PCM_FORMAT_FLOAT		SNDRV_PCM_FORMAT_FLOAT_LE  #define	SNDRV_PCM_FORMAT_FLOAT64	SNDRV_PCM_FORMAT_FLOAT64_LE  #define	SNDRV_PCM_FORMAT_IEC958_SUBFRAME SNDRV_PCM_FORMAT_IEC958_SUBFRAME_LE +#define	SNDRV_PCM_FORMAT_S20		SNDRV_PCM_FORMAT_S20_LE +#define	SNDRV_PCM_FORMAT_U20		SNDRV_PCM_FORMAT_U20_LE  #endif  #ifdef SNDRV_BIG_ENDIAN  #define	SNDRV_PCM_FORMAT_S16		SNDRV_PCM_FORMAT_S16_BE @@ -259,6 +266,8 @@ typedef int __bitwise snd_pcm_format_t;  #define	SNDRV_PCM_FORMAT_FLOAT		SNDRV_PCM_FORMAT_FLOAT_BE  #define	SNDRV_PCM_FORMAT_FLOAT64	SNDRV_PCM_FORMAT_FLOAT64_BE  #define	SNDRV_PCM_FORMAT_IEC958_SUBFRAME SNDRV_PCM_FORMAT_IEC958_SUBFRAME_BE +#define	SNDRV_PCM_FORMAT_S20		SNDRV_PCM_FORMAT_S20_BE +#define	SNDRV_PCM_FORMAT_U20		SNDRV_PCM_FORMAT_U20_BE  #endif  typedef int __bitwise snd_pcm_subformat_t; diff --git a/include/uapi/sound/snd_sst_tokens.h b/include/uapi/sound/snd_sst_tokens.h index 326054a72bc7..8ba0112e5336 100644 --- a/include/uapi/sound/snd_sst_tokens.h +++ b/include/uapi/sound/snd_sst_tokens.h @@ -222,6 +222,17 @@   * %SKL_TKN_MM_U32_NUM_IN_FMT:  Number of input formats   * %SKL_TKN_MM_U32_NUM_OUT_FMT: Number of output formats   * + * %SKL_TKN_U32_ASTATE_IDX:     Table Index for the A-State entry to be filled + *                              with kcps and clock source + * + * %SKL_TKN_U32_ASTATE_COUNT:   Number of valid entries in A-State table + * + * %SKL_TKN_U32_ASTATE_KCPS:    Specifies the core load threshold (in kilo + *                              cycles per second) below which DSP is clocked + *                              from source specified by clock source. + * + * %SKL_TKN_U32_ASTATE_CLK_SRC: Clock source for A-State entry + *   * module_id and loadable flags dont have tokens as these values will be   * read from the DSP FW manifest   * @@ -309,7 +320,11 @@ enum SKL_TKNS {  	SKL_TKN_MM_U32_NUM_IN_FMT,  	SKL_TKN_MM_U32_NUM_OUT_FMT, -	SKL_TKN_MAX = SKL_TKN_MM_U32_NUM_OUT_FMT, +	SKL_TKN_U32_ASTATE_IDX, +	SKL_TKN_U32_ASTATE_COUNT, +	SKL_TKN_U32_ASTATE_KCPS, +	SKL_TKN_U32_ASTATE_CLK_SRC, +	SKL_TKN_MAX = SKL_TKN_U32_ASTATE_CLK_SRC,  };  #endif diff --git a/include/xen/balloon.h b/include/xen/balloon.h index 4914b93a23f2..61f410fd74e4 100644 --- a/include/xen/balloon.h +++ b/include/xen/balloon.h @@ -44,3 +44,8 @@ static inline void xen_balloon_init(void)  {  }  #endif + +#ifdef CONFIG_XEN_BALLOON_MEMORY_HOTPLUG +struct resource; +void arch_xen_balloon_init(struct resource *hostmem_resource); +#endif |