#ifndef __SOUND_AK4113_H #define __SOUND_AK4113_H /* * Routines for Asahi Kasei AK4113 * Copyright (c) by Jaroslav Kysela , * Copyright (c) by Pavel Hofman , * * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA * */ /* AK4113 registers */ /* power down */ #define AK4113_REG_PWRDN 0x00 /* format control */ #define AK4113_REG_FORMAT 0x01 /* input/output control */ #define AK4113_REG_IO0 0x02 /* input/output control */ #define AK4113_REG_IO1 0x03 /* interrupt0 mask */ #define AK4113_REG_INT0_MASK 0x04 /* interrupt1 mask */ #define AK4113_REG_INT1_MASK 0x05 /* DAT mask & DTS select */ #define AK4113_REG_DATDTS 0x06 /* receiver status 0 */ #define AK4113_REG_RCS0 0x07 /* receiver status 1 */ #define AK4113_REG_RCS1 0x08 /* receiver status 2 */ #define AK4113_REG_RCS2 0x09 /* RX channel status byte 0 */ #define AK4113_REG_RXCSB0 0x0a /* RX channel status byte 1 */ #define AK4113_REG_RXCSB1 0x0b /* RX channel status byte 2 */ #define AK4113_REG_RXCSB2 0x0c /* RX channel status byte 3 */ #define AK4113_REG_RXCSB3 0x0d /* RX channel status byte 4 */ #define AK4113_REG_RXCSB4 0x0e /* burst preamble Pc byte 0 */ #define AK4113_REG_Pc0 0x0f /* burst preamble Pc byte 1 */ #define AK4113_REG_Pc1 0x10 /* burst preamble Pd byte 0 */ #define AK4113_REG_Pd0 0x11 /* burst preamble Pd byte 1 */ #define AK4113_REG_Pd1 0x12 /* Q-subcode address + control */ #define AK4113_REG_QSUB_ADDR 0x13 /* Q-subcode track */ #define AK4113_REG_QSUB_TRACK 0x14 /* Q-subcode index */ #define AK4113_REG_QSUB_INDEX 0x15 /* Q-subcode minute */ #define AK4113_REG_QSUB_MINUTE 0x16 /* Q-subcode second */ #define AK4113_REG_QSUB_SECOND 0x17 /* Q-subcode frame */ #define AK4113_REG_QSUB_FRAME 0x18 /* Q-subcode zero */ #define AK4113_REG_QSUB_ZERO 0x19 /* Q-subcode absolute minute */ #define AK4113_REG_QSUB_ABSMIN 0x1a /* Q-subcode absolute second */ #define AK4113_REG_QSUB_ABSSEC 0x1b /* Q-subcode absolute frame */ #define AK4113_REG_QSUB_ABSFRM 0x1c /* sizes */ #define AK4113_REG_RXCSB_SIZE ((AK4113_REG_RXCSB4-AK4113_REG_RXCSB0)+1) #define AK4113_REG_QSUB_SIZE ((AK4113_REG_QSUB_ABSFRM-AK4113_REG_QSUB_ADDR)\ +1) #define AK4113_WRITABLE_REGS (AK4113_REG_DATDTS + 1) /* AK4113_REG_PWRDN bits */ /* Channel Status Select */ #define AK4113_CS12 (1<<7) /* Block Start & C/U Output Mode */ #define AK4113_BCU (1<<6) /* Master Clock Operation Select */ #define AK4113_CM1 (1<<5) /* Master Clock Operation Select */ #define AK4113_CM0 (1<<4) /* Master Clock Frequency Select */ #define AK4113_OCKS1 (1<<3) /* Master Clock Frequency Select */ #define AK4113_OCKS0 (1<<2) /* 0 = power down, 1 = normal operation */ #define AK4113_PWN (1<<1) /* 0 = reset & initialize (except thisregister), 1 = normal operation */ #define AK4113_RST (1<<0) /* AK4113_REQ_FORMAT bits */ /* V/TX Output select: 0 = Validity Flag Output, 1 = TX */ #define AK4113_VTX (1<<7) /* Audio Data Control */ #define AK4113_DIF2 (1<<6) /* Audio Data Control */ #define AK4113_DIF1 (1<<5) /* Audio Data Control */ #define AK4113_DIF0 (1<<4) /* Deemphasis Autodetect Enable (1 = enable) */ #define AK4113_DEAU (1<<3) /* 32kHz-48kHz Deemphasis Control */ #define AK4113_DEM1 (1<<2) /* 32kHz-48kHz Deemphasis Control */ #define AK4113_DEM0 (1<<1) #define AK4113_DEM_OFF (AK4113_DEM0) #define AK4113_DEM_44KHZ (0) #define AK4113_DEM_48KHZ (AK4113_DEM1) #define AK4113_DEM_32KHZ (AK4113_DEM0|AK4113_DEM1) /* STDO: 16-bit, right justified */ #define AK4113_DIF_16R (0) /* STDO: 18-bit, right justified */ #define AK4113_DIF_18R (AK4113_DIF0) /* STDO: 20-bit, right justified */ #define AK4113_DIF_20R (AK4113_DIF1) /* STDO: 24-bit, right justified */ #define AK4113_DIF_24R (AK4113_DIF1|AK4113_DIF0) /* STDO: 24-bit, left justified */ #define AK4113_DIF_24L (AK4113_DIF2) /* STDO: I2S */ #define AK4113_DIF_24I2S (AK4113_DIF2|AK4113_DIF0) /* STDO: 24-bit, left justified; LRCLK, BICK = Input */ #define AK4113_DIF_I24L (AK4113_DIF2|AK4113_DIF1) /* STDO: I2S; LRCLK, BICK = Input */ #define AK4113_DIF_I24I2S (AK4113_DIF2|AK4113_DIF1|AK4113_DIF0) /* AK4113_REG_IO0 */ /* XTL1=0,XTL0=0 -> 11.2896Mhz; XTL1=0,XTL0=1 -> 12.288Mhz */ #define AK4113_XTL1 (1<<6) /* XTL1=1,XTL0=0 -> 24.576Mhz; XTL1=1,XTL0=1 -> use channel status */ #define AK4113_XTL0 (1<<5) /* Block Start Signal Output: 0 = U-bit, 1 = C-bit (req. BCU = 1) */ #define AK4113_UCE (1<<4) /* TX Output Enable (1 = enable) */ #define AK4113_TXE (1<<3) /* Output Through Data Selector for TX pin */ #define AK4113_OPS2 (1<<2) /* Output Through Data Selector for TX pin */ #define AK4113_OPS1 (1<<1) /* Output Through Data Selector for TX pin */ #define AK4113_OPS0 (1<<0) /* 11.2896 MHz ref. Xtal freq. */ #define AK4113_XTL_11_2896M (0) /* 12.288 MHz ref. Xtal freq. */ #define AK4113_XTL_12_288M (AK4113_XTL0) /* 24.576 MHz ref. Xtal freq. */ #define AK4113_XTL_24_576M (AK4113_XTL1) /* AK4113_REG_IO1 */ /* Interrupt 0 pin Hold */ #define AK4113_EFH1 (1<<7) /* Interrupt 0 pin Hold */ #define AK4113_EFH0 (1<<6) #define AK4113_EFH_512LRCLK (0) #define AK4113_EFH_1024LRCLK (AK4113_EFH0) #define AK4113_EFH_2048LRCLK (AK4113_EFH1) #define AK4113_EFH_4096LRCLK (AK4113_EFH1|AK4113_EFH0) /* PLL Lock Time: 0 = 384/fs, 1 = 1/fs */ #define AK4113_FAST (1<<5) /* MCKO2 Output Select: 0 = CMx/OCKSx, 1 = Xtal */ #define AK4113_XMCK (1<<4) /* MCKO2 Output Freq. Select: 0 = x1, 1 = x0.5 (req. XMCK = 1) */ #define AK4113_DIV (1<<3) /* Input Recovery Data Select */ #define AK4113_IPS2 (1<<2) /* Input Recovery Data Select */ #define AK4113_IPS1 (1<<1) /* Input Recovery Data Select */ #define AK4113_IPS0 (1<<0) #define AK4113_IPS(x) ((x)&7) /* AK4113_REG_INT0_MASK && AK4113_REG_INT1_MASK*/ /* mask enable for QINT bit */ #define AK4113_MQI (1<<7) /* mask enable for AUTO bit */ #define AK4113_MAUT (1<<6) /* mask enable for CINT bit */ #define AK4113_MCIT (1<<5) /* mask enable for UNLOCK bit */ #define AK4113_MULK (1<<4) /* mask enable for V bit */ #define AK4113_V (1<<3) /* mask enable for STC bit */ #define AK4113_STC (1<<2) /* mask enable for AUDN bit */ #define AK4113_MAN (1<<1) /* mask enable for PAR bit */ #define AK4113_MPR (1<<0) /* AK4113_REG_DATDTS */ /* DAT Start ID Counter */ #define AK4113_DCNT (1<<4) /* DTS-CD 16-bit Sync Word Detect */ #define AK4113_DTS16 (1<<3) /* DTS-CD 14-bit Sync Word Detect */ #define AK4113_DTS14 (1<<2) /* mask enable for DAT bit (if 1, no INT1 effect */ #define AK4113_MDAT1 (1<<1) /* mask enable for DAT bit (if 1, no INT0 effect */ #define AK4113_MDAT0 (1<<0) /* AK4113_REG_RCS0 */ /* Q-subcode buffer interrupt, 0 = no change, 1 = changed */ #define AK4113_QINT (1<<7) /* Non-PCM or DTS stream auto detection, 0 = no detect, 1 = detect */ #define AK4113_AUTO (1<<6) /* channel status buffer interrupt, 0 = no change, 1 = change */ #define AK4113_CINT (1<<5) /* PLL lock status, 0 = lock, 1 = unlock */ #define AK4113_UNLCK (1<<4) /* Validity bit, 0 = valid, 1 = invalid */ #define AK4113_V (1<<3) /* sampling frequency or Pre-emphasis change, 0 = no detect, 1 = detect */ #define AK4113_STC (1<<2) /* audio bit output, 0 = audio, 1 = non-audio */ #define AK4113_AUDION (1<<1) /* parity error or biphase error status, 0 = no error, 1 = error */ #define AK4113_PAR (1<<0) /* AK4113_REG_RCS1 */ /* sampling frequency detection */ #define AK4113_FS3 (1<<7) #define AK4113_FS2 (1<<6) #define AK4113_FS1 (1<<5) #define AK4113_FS0 (1<<4) /* Pre-emphasis detect, 0 = OFF, 1 = ON */ #define AK4113_PEM (1<<3) /* DAT Start ID Detect, 0 = no detect, 1 = detect */ #define AK4113_DAT (1<<2) /* DTS-CD bit audio stream detect, 0 = no detect, 1 = detect */ #define AK4113_DTSCD (1<<1) /* Non-PCM bit stream detection, 0 = no detect, 1 = detect */ #define AK4113_NPCM (1<<0) #define AK4113_FS_8000HZ (AK4113_FS3|AK4113_FS0) #define AK4113_FS_11025HZ (AK4113_FS2|AK4113_FS0) #define AK4113_FS_16000HZ (AK4113_FS2|AK4113_FS1|AK4113_FS0) #define AK4113_FS_22050HZ (AK4113_FS2) #define AK4113_FS_24000HZ (AK4113_FS2|AK4113_FS1) #define AK4113_FS_32000HZ (AK4113_FS1|AK4113_FS0) #define AK4113_FS_44100HZ (0) #define AK4113_FS_48000HZ (AK4113_FS1) #define AK4113_FS_64000HZ (AK4113_FS3|AK4113_FS1|AK4113_FS0) #define AK4113_FS_88200HZ (AK4113_FS3) #define AK4113_FS_96000HZ (AK4113_FS3|AK4113_FS1) #define AK4113_FS_176400HZ (AK4113_FS3|AK4113_FS2) #define AK4113_FS_192000HZ (AK4113_FS3|AK4113_FS2|AK4113_FS1) /* AK4113_REG_RCS2 */ /* CRC for Q-subcode, 0 = no error, 1 = error */ #define AK4113_QCRC (1<<1) /* CRC for channel status, 0 = no error, 1 = error */ #define AK4113_CCRC (1<<0) /* flags for snd_ak4113_check_rate_and_errors() */ #define AK4113_CHECK_NO_STAT (1<<0) /* no statistics */ #define AK4113_CHECK_NO_RATE (1<<1) /* no rate check */ #define AK4113_CONTROLS 13 typedef void (ak4113_write_t)(void *private_data, unsigned char addr, unsigned char data); typedef unsigned char (ak4113_read_t)(void *private_data, unsigned char addr); struct ak4113 { struct snd_card *card; ak4113_write_t *write; ak4113_read_t *read; void *private_data; atomic_t wq_processing; struct mutex reinit_mutex; spinlock_t lock; unsigned char regmap[AK4113_WRITABLE_REGS]; struct snd_kcontrol *kctls[AK4113_CONTROLS]; struct snd_pcm_substream *substream; unsigned long parity_errors; unsigned long v_bit_errors; unsigned long qcrc_errors; unsigned long ccrc_errors; unsigned char rcs0; unsigned char rcs1; unsigned char rcs2; struct delayed_work work; unsigned int check_flags; void *change_callback_private; void (*change_callback)(struct ak4113 *ak4113, unsigned char c0, unsigned char c1); }; int snd_ak4113_create(struct snd_card *card, ak4113_read_t *read, ak4113_write_t *write, const unsigned char *pgm, void *private_data, struct ak4113 **r_ak4113); void snd_ak4113_reg_write(struct ak4113 *ak4113, unsigned char reg, unsigned char mask, unsigned char val); void snd_ak4113_reinit(struct ak4113 *ak4113); int snd_ak4113_build(struct ak4113 *ak4113, struct snd_pcm_substream *capture_substream); int snd_ak4113_external_rate(struct ak4113 *ak4113); int snd_ak4113_check_rate_and_errors(struct ak4113 *ak4113, unsigned int flags); #ifdef CONFIG_PM void snd_ak4113_suspend(struct ak4113 *chip); void snd_ak4113_resume(struct ak4113 *chip); #else static inline void snd_ak4113_suspend(struct ak4113 *chip) {} static inline void snd_ak4113_resume(struct ak4113 *chip) {} #endif #endif /* __SOUND_AK4113_H */ span>/+4 syzkaller found another out of bound access in ip_options_compile(), or more exactly in cipso_v4_validate() Fixes: 20e2a8648596 ("cipso: handle CIPSO options correctly when NetLabel is disabled") Fixes: 446fda4f2682 ("[NetLabel]: CIPSOv4 engine") Signed-off-by: Eric Dumazet <edumazet@google.com> Reported-by: Dmitry Vyukov <dvyukov@google.com> Cc: Paul Moore <paul@paul-moore.com> Acked-by: Paul Moore <paul@paul-moore.com> Signed-off-by: David S. Miller <davem@davemloft.net> 2017-02-04Merge branch 'irq-urgent-for-linus' of ↵Linus Torvalds1-0/+17 git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip Pull irq fixes from Thomas Gleixner: - Prevent double activation of interrupt lines, which causes problems on certain interrupt controllers - Handle the fallout of the above because x86 (ab)uses the activation function to reconfigure interrupts under the hood. * 'irq-urgent-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip: x86/irq: Make irq activate operations symmetric irqdomain: Avoid activating interrupts more than once 2017-02-04Merge tag 'char-misc-4.10-rc7' of ↵Linus Torvalds1-2/+30 git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/char-misc Pull char/misc driver fixes from Greg KH: "Here are two bugfixes that resolve some reported issues. One in the firmware loader, that should fix the much-reported problem of crashes with it. The other is a hyperv fix for a reported regression. Both have been in linux-next for a week or so with no reported issues" * tag 'char-misc-4.10-rc7' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/char-misc: Drivers: hv: vmbus: finally fix hv_need_to_signal_on_read() firmware: fix NULL pointer dereference in __fw_load_abort() 2017-02-03base/memory, hotplug: fix a kernel oops in show_valid_zones()Toshi Kani1-1/+2 Reading a sysfs "memoryN/valid_zones" file leads to the following oops when the first page of a range is not backed by struct page. show_valid_zones() assumes that 'start_pfn' is always valid for page_zone(). BUG: unable to handle kernel paging request at ffffea017a000000 IP: show_valid_zones+0x6f/0x160 This issue may happen on x86-64 systems with 64GiB or more memory since their memory block size is bumped up to 2GiB. [1] An example of such systems is desribed below. 0x3240000000 is only aligned by 1GiB and this memory block starts from 0x3200000000, which is not backed by struct page. BIOS-e820: [mem 0x0000003240000000-0x000000603fffffff] usable Since test_pages_in_a_zone() already checks holes, fix this issue by extending this function to return 'valid_start' and 'valid_end' for a given range. show_valid_zones() then proceeds with the valid range. [1] 'Commit bdee237c0343 ("x86: mm: Use 2GB memory block size on large-memory x86-64 systems")' Link: http://lkml.kernel.org/r/20170127222149.30893-3-toshi.kani@hpe.com Signed-off-by: Toshi Kani <toshi.kani@hpe.com> Cc: Greg Kroah-Hartman <gregkh@linuxfoundation.org> Cc: Zhang Zhen <zhenzhang.zhang@huawei.com> Cc: Reza Arbab <arbab@linux.vnet.ibm.com> Cc: David Rientjes <rientjes@google.com> Cc: Dan Williams <dan.j.williams@intel.com> Cc: <stable@vger.kernel.org> [4.4+] Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org> 2017-02-03Merge tag 'drm-fixes-for-v4.10-rc7' of ↵Linus Torvalds2-1/+16 git://people.freedesktop.org/~airlied/linux Pull drm fixes from Dave Airlie: "Another fixes pull for v4.10, it's a bit big due to the backport of the VMA fixes for i915 that should fix the oops on shutdown problems that you've worked around. There are also two drm core connector registration fixes, a bunch of nouveau regression fixes and two AMD fixes" * tag 'drm-fixes-for-v4.10-rc7' of git://people.freedesktop.org/~airlied/linux: drm/radeon: Fix vram_size/visible values in DRM_RADEON_GEM_INFO ioctl drm/amdgpu/si: fix crash on headless asics drm/i915: Track pinned vma in intel_plane_state drm/atomic: Unconditionally call prepare_fb. drm/atomic: Fix double free in drm_atomic_state_default_clear drm/nouveau/kms/nv50: request vblank events for commits that send completion events drm/nouveau/nv1a,nv1f/disp: fix memory clock rate retrieval drm/nouveau/disp/gt215: Fix HDA ELD handling (thus, HDMI audio) on gt215 drm/nouveau/nouveau/led: prevent compiling the led-code if nouveau=y and leds=m drm/nouveau/disp/mcp7x: disable dptmds workaround drm/nouveau: prevent userspace from deleting client object drm/nouveau/fence/g84-: protect against concurrent access to semaphore buffers drm: Don't race connector registration drm: prevent double-(un)registration for connectors 2017-02-03Merge branch 'modversions' (modversions fixes for powerpc from Ard)Linus Torvalds3-17/+25 Merge kcrctab entry fixes from Ard Biesheuvel: "This is a followup to [0] 'modversions: redefine kcrctab entries as relative CRC pointers', but since relative CRC pointers do not work in modules, and are actually only needed by powerpc with CONFIG_RELOCATABLE=y, I have made it a Kconfig selectable feature instead. First it introduces the MODULE_REL_CRCS Kconfig symbol, and adds the kbuild handling of it, i.e., modpost, genksyms and kallsyms. Then it switches all architectures to 32-bit CRC entries in kcrctab, where all architectures except powerpc with CONFIG_RELOCATABLE=y use absolute ELF symbol references as before" [0] http://marc.info/?l=linux-arch&m=148493613415294&w=2 * emailed patches from Ard Biesheuvel: module: unify absolute krctab definitions for 32-bit and 64-bit modversions: treat symbol CRCs as 32 bit quantities kbuild: modversions: add infrastructure for emitting relative CRCs 2017-02-03log2: make order_base_2() behave correctly on const input value zeroArd Biesheuvel1-1/+12 The function order_base_2() is defined (according to the comment block) as returning zero on input zero, but subsequently passes the input into roundup_pow_of_two(), which is explicitly undefined for input zero. This has gone unnoticed until now, but optimization passes in GCC 7 may produce constant folded function instances where a constant value of zero is passed into order_base_2(), resulting in link errors against the deliberately undefined '____ilog2_NaN'. So update order_base_2() to adhere to its own documented interface. [ See http://marc.info/?l=linux-kernel&m=147672952517795&w=2 and follow-up discussion for more background. The gcc "optimization pass" is really just broken, but now the GCC trunk problem seems to have escaped out of just specially built daily images, so we need to work around it in mainline. - Linus ] Signed-off-by: Ard Biesheuvel <ard.biesheuvel@linaro.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org> 2017-02-03module: unify absolute krctab definitions for 32-bit and 64-bitArd Biesheuvel1-7/+0 The previous patch introduced a separate inline asm version of the krcrctab declaration template for use with 64-bit architectures, which cannot refer to ELF symbols using 32-bit quantities. This declaration should be equivalent to the C one for 32-bit architectures, but just in case - unify them in a separate patch, which can simply be dropped if it turns out to break anything. Signed-off-by: Ard Biesheuvel <ard.biesheuvel@linaro.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org> 2017-02-03modversions: treat symbol CRCs as 32 bit quantitiesArd Biesheuvel3-12/+27 The modversion symbol CRCs are emitted as ELF symbols, which allows us to easily populate the kcrctab sections by relying on the linker to associate each kcrctab slot with the correct value. This has a couple of downsides: - Given that the CRCs are treated as memory addresses, we waste 4 bytes for each CRC on 64 bit architectures, - On architectures that support runtime relocation, a R_<arch>_RELATIVE relocation entry is emitted for each CRC value, which identifies it as a quantity that requires fixing up based on the actual runtime load offset of the kernel. This results in corrupted CRCs unless we explicitly undo the fixup (and this is currently being handled in the core module code) - Such runtime relocation entries take up 24 bytes of __init space each, resulting in a x8 overhead in [uncompressed] kernel size for CRCs. Switching to explicit 32 bit values on 64 bit architectures fixes most of these issues, given that 32 bit values are not treated as quantities that require fixing up based on the actual runtime load offset. Note that on some ELF64 architectures [such as PPC64], these 32-bit values are still emitted as [absolute] runtime relocatable quantities, even if the value resolves to a build time constant. Since relative relocations are always resolved at build time, this patch enables MODULE_REL_CRCS on powerpc when CONFIG_RELOCATABLE=y, which turns the absolute CRC references into relative references into .rodata where the actual CRC value is stored. So redefine all CRC fields and variables as u32, and redefine the __CRC_SYMBOL() macro for 64 bit builds to emit the CRC reference using inline assembler (which is necessary since 64-bit C code cannot use 32-bit types to hold memory addresses, even if they are ultimately resolved using values that do not exceed 0xffffffff). To avoid potential problems with legacy 32-bit architectures using legacy toolchains, the equivalent C definition of the kcrctab entry is retained for 32-bit architectures. Note that this mostly reverts commit d4703aefdbc8 ("module: handle ppc64 relocating kcrctabs when CONFIG_RELOCATABLE=y") Acked-by: Rusty Russell <rusty@rustcorp.com.au> Signed-off-by: Ard Biesheuvel <ard.biesheuvel@linaro.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org> 2017-02-03ipv6: sr: remove cleanup flag and fix HMAC computationDavid Lebrun1-6/+3 In the latest version of the IPv6 Segment Routing IETF draft [1] the cleanup flag is removed and the flags field length is shrunk from 16 bits to 8 bits. As a consequence, the input of the HMAC computation is modified in a non-backward compatible way by covering the whole octet of flags instead of only the cleanup bit. As such, if an implementation compatible with the latest draft computes the HMAC of an SRH who has other flags set to 1, then the HMAC result would differ from the current implementation. This patch carries those modifications to prevent conflict with other implementations of IPv6 SR. [1] https://tools.ietf.org/html/draft-ietf-6man-segment-routing-header-05 Signed-off-by: David Lebrun <david.lebrun@uclouvain.be> Signed-off-by: David S. Miller <davem@davemloft.net> 2017-02-02Merge branch 'perf-urgent-for-linus' of ↵Linus Torvalds1-3/+0 git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip Pull perf fixes from Ingo Molnar: "Five kernel fixes: - an mmap tracing ABI fix for certain mappings - a use-after-free fix, found via KASAN - three CPU hotplug related x86 PMU driver fixes" * 'perf-urgent-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip: perf/x86/intel/uncore: Make package handling more robust perf/x86/intel/uncore: Clean up hotplug conversion fallout perf/x86/intel/rapl: Make package handling more robust perf/core: Fix PERF_RECORD_MMAP2 prot/flags for anonymous memory perf/core: Fix use-after-free bug 2017-02-01Merge git://git.kernel.org/pub/scm/linux/kernel/git/davem/netLinus Torvalds4-19/+26 Pull networking fixes from David Miller: 1) Fix handling of interrupt status in stmmac driver. Just because we have masked the event from generating interrupts, doesn't mean the bit won't still be set in the interrupt status register. From Alexey Brodkin. 2) Fix DMA API debugging splats in gianfar driver, from Arseny Solokha. 3) Fix off-by-one error in __ip6_append_data(), from Vlad Yasevich. 4) cls_flow does not match on icmpv6 codes properly, from Simon Horman. 5) Initial MAC address can be set incorrectly in some scenerios, from Ivan Vecera. 6) Packet header pointer arithmetic fix in ip6_tnl_parse_tlv_end_lim(), from Dan Carpenter. 7) Fix divide by zero in __tcp_select_window(), from Eric Dumazet. 8) Fix crash in iwlwifi when unregistering thermal zone, from Jens Axboe. 9) Check for DMA mapping errors in starfire driver, from Alexey Khoroshilov. * git://git.kernel.org/pub/scm/linux/kernel/git/davem/net: (31 commits) tcp: fix 0 divide in __tcp_select_window() ipv6: pointer math error in ip6_tnl_parse_tlv_enc_lim() net: fix ndo_features_check/ndo_fix_features comment ordering net/sched: matchall: Fix configuration race be2net: fix initial MAC setting ipv6: fix flow labels when the traffic class is non-0 net: thunderx: avoid dereferencing xcv when NULL net/sched: cls_flower: Correct matching on ICMPv6 code ipv6: Paritially checksum full MTU frames net/mlx4_core: Avoid command timeouts during VF driver device shutdown gianfar: synchronize DMA API usage by free_skb_rx_queue w/ gfar_new_page net: ethtool: add support for 2500BaseT and 5000BaseT link modes can: bcm: fix hrtimer/tasklet termination in bcm op removal net: adaptec: starfire: add checks for dma mapping errors net: phy: micrel: KSZ8795 do not set SUPPORTED_[Asym_]Pause can: Fix kernel panic at security_sock_rcv_skb net: macb: Fix 64 bit addressing support for GEM stmmac: Discard masked flags in interrupt status register net/mlx5e: Check ets capability before ets query FW command net/mlx5e: Fix update of hash function/key via ethtool ... 2017-02-01Merge branch 'for-linus' of ↵Linus Torvalds1-0/+1 git://git.kernel.org/pub/scm/linux/kernel/git/viro/vfs Pull fscache fixes from Al Viro. * 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/viro/vfs: fscache: Fix dead object requeue fscache: Clear outstanding writes when disabling a cookie FS-Cache: Initialise stores_lock in netfs cookie 2017-02-01net: fix ndo_features_check/ndo_fix_features comment orderingDimitris Michailidis1-14/+15 Commit cdba756f5803a2 ("net: move ndo_features_check() close to ndo_start_xmit()") inadvertently moved the doc comment for .ndo_fix_features instead of .ndo_features_check. Fix the comment ordering. Fixes: cdba756f5803a2 ("net: move ndo_features_check() close to ndo_start_xmit()") Signed-off-by: Dimitris Michailidis <dmichail@google.com> Acked-by: Eric Dumazet <edumazet@google.com> Signed-off-by: David S. Miller <davem@davemloft.net> 2017-02-01perf/x86/intel/uncore: Make package handling more robustThomas Gleixner1-2/+0 The package management code in uncore relies on package mapping being available before a CPU is started. This changed with: 9d85eb9119f4 ("x86/smpboot: Make logical package management more robust") because the ACPI/BIOS information turned out to be unreliable, but that left uncore in broken state. This was not noticed because on a regular boot all CPUs are online before uncore is initialized. Move the allocation to the CPU online callback and simplify the hotplug handling. At this point the package mapping is established and correct. Signed-off-by: Thomas Gleixner <tglx@linutronix.de> Cc: Alexander Shishkin <alexander.shishkin@linux.intel.com> Cc: Arnaldo Carvalho de Melo <acme@redhat.com> Cc: Jiri Olsa <jolsa@redhat.com> Cc: Linus Torvalds <torvalds@linux-foundation.org> Cc: Peter Zijlstra <peterz@infradead.org> Cc: Sebastian Siewior <bigeasy@linutronix.de> Cc: Stephane Eranian <eranian@google.com> Cc: Vince Weaver <vincent.weaver@maine.edu> Cc: Yasuaki Ishimatsu <yasu.isimatu@gmail.com> Fixes: 9d85eb9119f4 ("x86/smpboot: Make logical package management more robust") Link: http://lkml.kernel.org/r/20170131230141.377156255@linutronix.de Signed-off-by: Ingo Molnar <mingo@kernel.org>