* aosp/android-4.14-stable:
Linux 4.14.216
net: drop bogus skb with CHECKSUM_PARTIAL and offset beyond end of trimmed packet
block: fix use-after-free in disk_part_iter_next
KVM: arm64: Don't access PMCR_EL0 when no PMU is available
wan: ds26522: select CONFIG_BITREVERSE
net/mlx5e: Fix two double free cases
net/mlx5e: Fix memleak in mlx5e_create_l2_table_groups
iommu/intel: Fix memleak in intel_irq_remapping_alloc
block: rsxx: select CONFIG_CRC32
wil6210: select CONFIG_CRC32
dmaengine: xilinx_dma: fix mixed_enum_type coverity warning
dmaengine: xilinx_dma: check dma_async_device_register return value
spi: stm32: FIFO threshold level - fix align packet size
cpufreq: powernow-k8: pass policy rather than use cpufreq_cpu_get()
i2c: sprd: use a specific timeout to avoid system hang up issue
ARM: OMAP2+: omap_device: fix idling of devices during probe
iio: imu: st_lsm6dsx: fix edge-trigger interrupts
iio: imu: st_lsm6dsx: flip irq return logic
spi: pxa2xx: Fix use-after-free on unbind
ubifs: wbuf: Don't leak kernel memory to flash
drm/i915: Fix mismatch between misplaced vma check and vma insert
vmlinux.lds.h: Add PGO and AutoFDO input sections
x86/resctrl: Don't move a task to the same resource group
x86/resctrl: Use an IPI instead of task_work_add() to update PQR_ASSOC MSR
net: fix pmtu check in nopmtudisc mode
net: ip: always refragment ip defragmented packets
net: vlan: avoid leaks on register_vlan_dev() failures
net: cdc_ncm: correct overhead in delayed_ndp_size
powerpc: Fix incorrect stw{, ux, u, x} instructions in __set_pte_at
Linux 4.14.215
scsi: target: Fix XCOPY NAA identifier lookup
KVM: x86: fix shift out of bounds reported by UBSAN
x86/mtrr: Correct the range check before performing MTRR type lookups
netfilter: xt_RATEEST: reject non-null terminated string from userspace
netfilter: ipset: fix shift-out-of-bounds in htable_bits()
Revert "device property: Keep secondary firmware node secondary by type"
ALSA: hda/realtek - Fix speaker volume control on Lenovo C940
ALSA: hda/conexant: add a new hda codec CX11970
x86/mm: Fix leak of pmd ptlock
USB: serial: keyspan_pda: remove unused variable
usb: gadget: configfs: Fix use-after-free issue with udc_name
usb: gadget: configfs: Preserve function ordering after bind failure
usb: gadget: Fix spinlock lockup on usb_function_deactivate
USB: gadget: legacy: fix return error code in acm_ms_bind()
usb: gadget: function: printer: Fix a memory leak for interface descriptor
usb: gadget: f_uac2: reset wMaxPacketSize
usb: gadget: select CONFIG_CRC32
ALSA: usb-audio: Fix UBSAN warnings for MIDI jacks
USB: usblp: fix DMA to stack
USB: yurex: fix control-URB timeout handling
USB: serial: option: add Quectel EM160R-GL
USB: serial: option: add LongSung M5710 module support
USB: serial: iuu_phoenix: fix DMA from stack
usb: uas: Add PNY USB Portable SSD to unusual_uas
usb: usbip: vhci_hcd: protect shift size
USB: xhci: fix U1/U2 handling for hardware with XHCI_INTEL_HOST quirk set
usb: chipidea: ci_hdrc_imx: add missing put_device() call in usbmisc_get_init_data()
usb: dwc3: ulpi: Use VStsDone to detect PHY regs access completion
USB: cdc-acm: blacklist another IR Droid device
usb: gadget: enable super speed plus
crypto: ecdh - avoid buffer overflow in ecdh_set_secret()
video: hyperv_fb: Fix the mmap() regression for v5.4.y and older
net: systemport: set dev->max_mtu to UMAC_MAX_MTU_SIZE
net: mvpp2: Fix GoP port 3 Networking Complex Control configurations
net-sysfs: take the rtnl lock when accessing xps_cpus_map and num_tc
net: sched: prevent invalid Scell_log shift count
vhost_net: fix ubuf refcount incorrectly when sendmsg fails
net: usb: qmi_wwan: add Quectel EM160R-GL
CDC-NCM: remove "connected" log message
net: hdlc_ppp: Fix issues when mod_timer is called while timer is running
net: hns: fix return value check in __lb_other_process()
ipv4: Ignore ECN bits for fib lookups in fib_compute_spec_dst()
net: ethernet: ti: cpts: fix ethtool output when no ptp_clock registered
net-sysfs: take the rtnl lock when storing xps_cpus
net: ethernet: Fix memleak in ethoc_probe
net/ncsi: Use real net-device for response handler
virtio_net: Fix recursive call to cpus_read_lock()
qede: fix offload for IPIP tunnel packets
atm: idt77252: call pci_disable_device() on error path
ethernet: ucc_geth: set dev->max_mtu to 1518
ethernet: ucc_geth: fix use-after-free in ucc_geth_remove()
depmod: handle the case of /sbin/depmod without /sbin in PATH
lib/genalloc: fix the overflow when size is too big
scsi: ide: Do not set the RQF_PREEMPT flag for sense requests
scsi: ufs-pci: Ensure UFS device is in PowerDown mode for suspend-to-disk ->poweroff()
workqueue: Kick a worker based on the actual activation of delayed works
kbuild: don't hardcode depmod path
Linux 4.14.214
mwifiex: Fix possible buffer overflows in mwifiex_cmd_802_11_ad_hoc_start
iio:magnetometer:mag3110: Fix alignment and data leak issues.
iio:imu:bmi160: Fix alignment and data leak issues
kdev_t: always inline major/minor helper functions
dm verity: skip verity work if I/O error when system is shutting down
ALSA: pcm: Clear the full allocated memory at hw_params
module: delay kobject uevent until after module init call
powerpc: sysdev: add missing iounmap() on error in mpic_msgr_probe()
quota: Don't overflow quota file offsets
module: set MODULE_STATE_GOING state when a module fails to load
rtc: sun6i: Fix memleak in sun6i_rtc_clk_init
ALSA: seq: Use bool for snd_seq_queue internal flags
media: gp8psk: initialize stats at power control logic
misc: vmw_vmci: fix kernel info-leak by initializing dbells in vmci_ctx_get_chkpt_doorbells()
reiserfs: add check for an invalid ih_entry_count
of: fix linker-section match-table corruption
uapi: move constants from <linux/kernel.h> to <linux/const.h>
powerpc/bitops: Fix possible undefined behaviour with fls() and fls64()
USB: serial: digi_acceleport: fix write-wakeup deadlocks
s390/dasd: fix hanging device offline processing
vfio/pci: Move dummy_resources_list init in vfio_pci_probe()
mm: memcontrol: fix excessive complexity in memory.stat reporting
mm: memcontrol: implement lruvec stat functions on top of each other
mm: memcontrol: eliminate raw access to stat and event counters
ALSA: usb-audio: fix sync-ep altsetting sanity check
ALSA: usb-audio: simplify set_sync_ep_implicit_fb_quirk
ALSA: hda/ca0132 - Fix work handling in delayed HP detection
md/raid10: initialize r10_bio->read_slot before use.
x86/entry/64: Add instruction suffix
ANDROID: usb: f_accessory: Don't drop NULL reference in acc_disconnect()
ANDROID: usb: f_accessory: Avoid bitfields for shared variables
ANDROID: usb: f_accessory: Cancel any pending work before teardown
ANDROID: usb: f_accessory: Don't corrupt global state on double registration
ANDROID: usb: f_accessory: Fix teardown ordering in acc_release()
ANDROID: usb: f_accessory: Add refcounting to global 'acc_dev'
ANDROID: usb: f_accessory: Wrap '_acc_dev' in get()/put() accessors
ANDROID: usb: f_accessory: Remove useless assignment
ANDROID: usb: f_accessory: Remove useless non-debug prints
ANDROID: usb: f_accessory: Remove stale comments
ANDROID: USB: f_accessory: Check dev pointer before decoding ctrl request
ANDROID: usb: gadget: f_accessory: fix CTS test stuck
Linux 4.14.213
PCI: Fix pci_slot_release() NULL pointer dereference
libnvdimm/namespace: Fix reaping of invalidated block-window-namespace labels
xenbus/xenbus_backend: Disallow pending watch messages
xen/xenbus: Count pending messages for each watch
xen/xenbus/xen_bus_type: Support will_handle watch callback
xen/xenbus: Add 'will_handle' callback support in xenbus_watch_path()
xen/xenbus: Allow watches discard events before queueing
xen-blkback: set ring->xenblkd to NULL after kthread_stop()
clk: mvebu: a3700: fix the XTAL MODE pin to MPP1_9
md/cluster: fix deadlock when node is doing resync job
iio:imu:bmi160: Fix too large a buffer.
iio:pressure:mpl3115: Force alignment of buffer
iio:light:rpr0521: Fix timestamp alignment and prevent data leak.
iio: adc: rockchip_saradc: fix missing clk_disable_unprepare() on error in rockchip_saradc_resume
iio: buffer: Fix demux update
mtd: parser: cmdline: Fix parsing of part-names with colons
soc: qcom: smp2p: Safely acquire spinlock without IRQs
spi: st-ssc4: Fix unbalanced pm_runtime_disable() in probe error path
spi: sc18is602: Don't leak SPI master in probe error path
spi: rb4xx: Don't leak SPI master in probe error path
spi: pic32: Don't leak DMA channels in probe error path
spi: davinci: Fix use-after-free on unbind
spi: spi-sh: Fix use-after-free on unbind
drm/dp_aux_dev: check aux_dev before use in drm_dp_aux_dev_get_by_minor()
jfs: Fix array index bounds check in dbAdjTree
jffs2: Fix GC exit abnormally
ceph: fix race in concurrent __ceph_remove_cap invocations
ima: Don't modify file descriptor mode on the fly
powerpc/powernv/memtrace: Don't leak kernel memory to user space
powerpc/xmon: Change printk() to pr_cont()
powerpc/rtas: Fix typo of ibm,open-errinjct in RTAS filter
ARM: dts: at91: sama5d2: fix CAN message ram offset and size
KVM: arm64: Introduce handling of AArch32 TTBCR2 traps
ext4: fix deadlock with fs freezing and EA inodes
ext4: fix a memory leak of ext4_free_data
btrfs: fix return value mixup in btrfs_get_extent
Btrfs: fix selftests failure due to uninitialized i_mode in test inodes
USB: serial: keyspan_pda: fix write unthrottling
USB: serial: keyspan_pda: fix tx-unthrottle use-after-free
USB: serial: keyspan_pda: fix write-wakeup use-after-free
USB: serial: keyspan_pda: fix stalled writes
USB: serial: keyspan_pda: fix write deadlock
USB: serial: keyspan_pda: fix dropped unthrottle interrupts
USB: serial: mos7720: fix parallel-port state restore
EDAC/amd64: Fix PCI component registration
crypto: ecdh - avoid unaligned accesses in ecdh_set_secret()
powerpc/perf: Exclude kernel samples while counting events in user space.
staging: comedi: mf6x4: Fix AI end-of-conversion detection
s390/dasd: fix list corruption of lcu list
s390/dasd: fix list corruption of pavgroup group list
s390/dasd: prevent inconsistent LCU device data
s390/smp: perform initial CPU reset also for SMT siblings
ALSA: usb-audio: Disable sample read check if firmware doesn't give back
ALSA: pcm: oss: Fix a few more UBSAN fixes
ALSA: hda/realtek - Enable headset mic of ASUS Q524UQK with ALC255
ACPI: PNP: compare the string length in the matching_id()
Revert "ACPI / resources: Use AE_CTRL_TERMINATE to terminate resources walks"
PM: ACPI: PCI: Drop acpi_pm_set_bridge_wakeup()
Input: cyapa_gen6 - fix out-of-bounds stack access
media: netup_unidvb: Don't leak SPI master in probe error path
media: sunxi-cir: ensure IR is handled when it is continuous
media: gspca: Fix memory leak in probe
Input: goodix - add upside-down quirk for Teclast X98 Pro tablet
Input: cros_ec_keyb - send 'scancodes' in addition to key events
fix namespaced fscaps when !CONFIG_SECURITY
cfg80211: initialize rekey_data
clk: sunxi-ng: Make sure divider tables have sentinel
clk: s2mps11: Fix a resource leak in error handling paths in the probe function
qlcnic: Fix error code in probe
perf record: Fix memory leak when using '--user-regs=?' to list registers
pwm: lp3943: Dynamically allocate PWM chip base
pwm: zx: Add missing cleanup in error path
clk: ti: Fix memleak in ti_fapll_synth_setup
watchdog: coh901327: add COMMON_CLK dependency
watchdog: qcom: Avoid context switch in restart handler
net: korina: fix return value
net: allwinner: Fix some resources leak in the error handling path of the probe and in the remove function
net: bcmgenet: Fix a resource leak in an error handling path in the probe functin
checkpatch: fix unescaped left brace
powerpc/ps3: use dma_mapping_error()
nfc: s3fwrn5: Release the nfc firmware
um: chan_xterm: Fix fd leak
watchdog: sirfsoc: Add missing dependency on HAS_IOMEM
irqchip/alpine-msi: Fix freeing of interrupts on allocation error path
ASoC: wm_adsp: remove "ctl" from list on error in wm_adsp_create_control()
extcon: max77693: Fix modalias string
clk: tegra: Fix duplicated SE clock entry
x86/kprobes: Restore BTF if the single-stepping is cancelled
nfs_common: need lock during iterate through the list
nfsd: Fix message level for normal termination
speakup: fix uninitialized flush_lock
usb: oxu210hp-hcd: Fix memory leak in oxu_create
usb: ehci-omap: Fix PM disable depth umbalance in ehci_hcd_omap_probe
powerpc/pseries/hibernation: remove redundant cacheinfo update
powerpc/pseries/hibernation: drop pseries_suspend_begin() from suspend ops
scsi: fnic: Fix error return code in fnic_probe()
seq_buf: Avoid type mismatch for seq_buf_init
scsi: pm80xx: Fix error return in pm8001_pci_probe()
scsi: qedi: Fix missing destroy_workqueue() on error in __qedi_probe
cpufreq: scpi: Add missing MODULE_ALIAS
cpufreq: loongson1: Add missing MODULE_ALIAS
cpufreq: st: Add missing MODULE_DEVICE_TABLE
cpufreq: mediatek: Add missing MODULE_DEVICE_TABLE
cpufreq: highbank: Add missing MODULE_DEVICE_TABLE
clocksource/drivers/arm_arch_timer: Correct fault programming of CNTKCTL_EL1.EVNTI
dm ioctl: fix error return code in target_message
ASoC: jz4740-i2s: add missed checks for clk_get()
net/mlx5: Properly convey driver version to firmware
memstick: r592: Fix error return in r592_probe()
arm64: dts: rockchip: Fix UART pull-ups on rk3328
pinctrl: falcon: add missing put_device() call in pinctrl_falcon_probe()
ARM: dts: at91: sama5d2: map securam as device
clocksource/drivers/cadence_ttc: Fix memory leak in ttc_setup_clockevent()
media: saa7146: fix array overflow in vidioc_s_audio()
vfio-pci: Use io_remap_pfn_range() for PCI IO memory
NFS: switch nfsiod to be an UNBOUND workqueue.
lockd: don't use interval-based rebinding over TCP
SUNRPC: xprt_load_transport() needs to support the netid "rdma6"
NFSv4.2: condition READDIR's mask for security label based on LSM state
ath10k: Release some resources in an error handling path
ath10k: Fix an error handling path
ARM: dts: at91: at91sam9rl: fix ADC triggers
PCI: iproc: Fix out-of-bound array accesses
genirq/irqdomain: Don't try to free an interrupt that has no mapping
power: supply: bq24190_charger: fix reference leak
ARM: dts: Remove non-existent i2c1 from 98dx3236
HSI: omap_ssi: Don't jump to free ID in ssi_add_controller()
media: max2175: fix max2175_set_csm_mode() error code
mips: cdmm: fix use-after-free in mips_cdmm_bus_discover
samples: bpf: Fix lwt_len_hist reusing previous BPF map
media: siano: fix memory leak of debugfs members in smsdvb_hotplug
cw1200: fix missing destroy_workqueue() on error in cw1200_init_common
orinoco: Move context allocation after processing the skb
ARM: dts: at91: sama5d3_xplained: add pincontrol for USB Host
ARM: dts: at91: sama5d4_xplained: add pincontrol for USB Host
memstick: fix a double-free bug in memstick_check
RDMA/cxgb4: Validate the number of CQEs
Input: omap4-keypad - fix runtime PM error handling
drivers: soc: ti: knav_qmss_queue: Fix error return code in knav_queue_probe
soc: ti: Fix reference imbalance in knav_dma_probe
soc: ti: knav_qmss: fix reference leak in knav_queue_probe
crypto: omap-aes - Fix PM disable depth imbalance in omap_aes_probe
powerpc/feature: Fix CPU_FTRS_ALWAYS by removing CPU_FTRS_GENERIC_32
Input: ads7846 - fix unaligned access on 7845
Input: ads7846 - fix integer overflow on Rt calculation
Input: ads7846 - fix race that causes missing releases
drm/omap: dmm_tiler: fix return error code in omap_dmm_probe()
media: solo6x10: fix missing snd_card_free in error handling case
scsi: core: Fix VPD LUN ID designator priorities
media: mtk-vcodec: add missing put_device() call in mtk_vcodec_release_dec_pm()
staging: greybus: codecs: Fix reference counter leak in error handling
MIPS: BCM47XX: fix kconfig dependency bug for BCM47XX_BCMA
RDMa/mthca: Work around -Wenum-conversion warning
ASoC: arizona: Fix a wrong free in wm8997_probe
ASoC: wm8998: Fix PM disable depth imbalance on error
mwifiex: fix mwifiex_shutdown_sw() causing sw reset failure
spi: tegra114: fix reference leak in tegra spi ops
spi: tegra20-sflash: fix reference leak in tegra_sflash_resume
spi: tegra20-slink: fix reference leak in slink ops of tegra20
spi: spi-ti-qspi: fix reference leak in ti_qspi_setup
Bluetooth: Fix null pointer dereference in hci_event_packet()
arm64: dts: exynos: Correct psci compatible used on Exynos7
selinux: fix inode_doinit_with_dentry() LABEL_INVALID error handling
ASoC: pcm: DRAIN support reactivation
spi: img-spfi: fix reference leak in img_spfi_resume
crypto: talitos - Fix return type of current_desc_hdr()
sched: Reenable interrupts in do_sched_yield()
sched/deadline: Fix sched_dl_global_validate()
ARM: p2v: fix handling of LPAE translation in BE mode
x86/mm/ident_map: Check for errors from ident_pud_init()
RDMA/rxe: Compute PSN windows correctly
selinux: fix error initialization in inode_doinit_with_dentry()
RDMA/bnxt_re: Set queue pair state when being queried
soc: mediatek: Check if power domains can be powered on at boot time
soc: renesas: rmobile-sysc: Fix some leaks in rmobile_init_pm_domains()
drm/gma500: fix double free of gma_connector
Bluetooth: Fix slab-out-of-bounds read in hci_le_direct_adv_report_evt()
md: fix a warning caused by a race between concurrent md_ioctl()s
crypto: af_alg - avoid undefined behavior accessing salg_name
media: msi2500: assign SPI bus number dynamically
quota: Sanity-check quota file headers on load
serial_core: Check for port state when tty is in error state
HID: i2c-hid: add Vero K147 to descriptor override
ARM: dts: exynos: fix USB 3.0 pins supply being turned off on Odroid XU
ARM: dts: exynos: fix USB 3.0 VBUS control and over-current pins on Exynos5410
ARM: dts: exynos: fix roles of USB 3.0 ports on Odroid XU
usb: chipidea: ci_hdrc_imx: Pass DISABLE_DEVICE_STREAMING flag to imx6ul
USB: gadget: f_rndis: fix bitrate for SuperSpeed and above
usb: gadget: f_fs: Re-use SS descriptors for SuperSpeedPlus
USB: gadget: f_midi: setup SuperSpeed Plus descriptors
USB: gadget: f_acm: add support for SuperSpeed Plus
USB: serial: option: add interface-number sanity check to flag handling
soc/tegra: fuse: Fix index bug in get_process_id
dm table: Remove BUG_ON(in_interrupt())
scsi: mpt3sas: Increase IOCInit request timeout to 30s
vxlan: Copy needed_tailroom from lowerdev
vxlan: Add needed_headroom for lower device
drm/tegra: sor: Disable clocks on error in tegra_sor_init()
kernel/cpu: add arch override for clear_tasks_mm_cpumask() mm handling
RDMA/cm: Fix an attempt to use non-valid pointer when cleaning timewait
can: softing: softing_netdev_open(): fix error handling
scsi: bnx2i: Requires MMU
gpio: mvebu: fix potential user-after-free on probe
ARM: dts: sun8i: v3s: fix GIC node memory range
pinctrl: baytrail: Avoid clearing debounce value when turning it off
pinctrl: merrifield: Set default bias in case no particular value given
drm: fix drm_dp_mst_port refcount leaks in drm_dp_mst_allocate_vcpi
serial: 8250_omap: Avoid FIFO corruption caused by MDR1 access
ALSA: pcm: oss: Fix potential out-of-bounds shift
USB: sisusbvga: Make console support depend on BROKEN
USB: UAS: introduce a quirk to set no_write_same
xhci: Give USB2 ports time to enter U3 in bus suspend
ALSA: usb-audio: Fix control 'access overflow' errors from chmap
ALSA: usb-audio: Fix potential out-of-bounds shift
USB: add RESET_RESUME quirk for Snapscan 1212
USB: dummy-hcd: Fix uninitialized array use in init()
mac80211: mesh: fix mesh_pathtbl_init() error path
net: bridge: vlan: fix error return code in __vlan_add()
net: stmmac: dwmac-meson8b: fix mask definition of the m250_sel mux
net: stmmac: delete the eee_ctrl_timer after napi disabled
net/mlx4_en: Handle TX error CQE
net/mlx4_en: Avoid scheduling restart task if it is already running
tcp: fix cwnd-limited bug for TSO deferral where we send nothing
net: stmmac: free tx skb buffer in stmmac_resume()
PCI: qcom: Add missing reset for ipq806x
x86/mm/mem_encrypt: Fix definition of PMD_FLAGS_DEC_WP
scsi: be2iscsi: Revert "Fix a theoretical leak in beiscsi_create_eqs()"
kbuild: avoid static_assert for genksyms
pinctrl: amd: remove debounce filter setting in IRQ type setting
Input: i8042 - add Acer laptops to the i8042 reset list
Input: cm109 - do not stomp on control URB
platform/x86: acer-wmi: add automatic keyboard background light toggle key as KEY_LIGHTS_TOGGLE
soc: fsl: dpio: Get the cpumask through cpumask_of(cpu)
scsi: ufs: Make sure clk scaling happens only when HBA is runtime ACTIVE
ARC: stack unwinding: don't assume non-current task is sleeping
iwlwifi: mvm: fix kernel panic in case of assert during CSA
arm64: dts: rockchip: Assign a fixed index to mmc devices on rk3399 boards.
iwlwifi: pcie: limit memory read spin time
spi: bcm2835aux: Restore err assignment in bcm2835aux_spi_probe
spi: bcm2835aux: Fix use-after-free on unbind
Linux 4.14.212
x86/uprobes: Do not use prefixes.nbytes when looping over prefixes.bytes
Input: i8042 - fix error return code in i8042_setup_aux()
i2c: qup: Fix error return code in qup_i2c_bam_schedule_desc()
gfs2: check for empty rgrp tree in gfs2_ri_update
tracing: Fix userstacktrace option for instances
spi: bcm2835: Release the DMA channel if probe fails after dma_init
spi: bcm2835: Fix use-after-free on unbind
spi: bcm-qspi: Fix use-after-free on unbind
spi: Introduce device-managed SPI controller allocation
iommu/amd: Set DTE[IntTabLen] to represent 512 IRTEs
speakup: Reject setting the speakup line discipline outside of speakup
i2c: imx: Check for I2SR_IAL after every byte
i2c: imx: Fix reset of I2SR_IAL flag
mm/swapfile: do not sleep with a spin lock held
cifs: fix potential use-after-free in cifs_echo_request()
ftrace: Fix updating FTRACE_FL_TRAMP
ALSA: hda/generic: Add option to enforce preferred_dacs pairs
ALSA: hda/realtek - Add new codec supported for ALC897
tty: Fix ->session locking
tty: Fix ->pgrp locking in tiocspgrp()
USB: serial: option: fix Quectel BG96 matching
USB: serial: option: add support for Thales Cinterion EXS82
USB: serial: option: add Fibocom NL668 variants
USB: serial: ch341: sort device-id entries
USB: serial: ch341: add new Product ID for CH341A
USB: serial: kl5kusb105: fix memleak on open
usb: gadget: f_fs: Use local copy of descriptors for userspace copy
vlan: consolidate VLAN parsing code and limit max parsing depth
pinctrl: baytrail: Fix pin being driven low for a while on gpiod_get(..., GPIOD_OUT_HIGH)
pinctrl: baytrail: Replace WARN with dev_info_once when setting direct-irq pin to output
ANDROID: Incremental fs: Set credentials before reading/writing
ANDROID: Incremental fs: Fix incfs_test use of atol, open
ANDROID: Incremental fs: Change per UID timeouts to microseconds
ANDROID: Incremental fs: Add v2 feature flag
ANDROID: Incremental fs: Add zstd feature flag
Linux 4.14.211
RDMA/i40iw: Address an mmap handler exploit in i40iw
Input: i8042 - add ByteSpeed touchpad to noloop table
Input: xpad - support Ardwiino Controllers
ALSA: usb-audio: US16x08: fix value count for level meters
dt-bindings: net: correct interrupt flags in examples
net/mlx5: Fix wrong address reclaim when command interface is down
net: pasemi: fix error return code in pasemi_mac_open()
cxgb3: fix error return code in t3_sge_alloc_qset()
net/x25: prevent a couple of overflows
ibmvnic: Fix TX completion error handling
ibmvnic: Ensure that SCRQ entry reads are correctly ordered
ipv4: Fix tos mask in inet_rtm_getroute()
netfilter: bridge: reset skb->pkt_type after NF_INET_POST_ROUTING traversal
bonding: wait for sysfs kobject destruction before freeing struct slave
usbnet: ipheth: fix connectivity with iOS 14
tun: honor IOCB_NOWAIT flag
tcp: Set INET_ECN_xmit configuration in tcp_reinit_congestion_control
sock: set sk_err to ee_errno on dequeue from errq
rose: Fix Null pointer dereference in rose_send_frame()
net/af_iucv: set correct sk_protocol for child sockets
ANDROID: Incremental fs: Fix 32-bit build
UPSTREAM: arm64: sysreg: Clean up instructions for modifying PSTATE fields
[CP] CHROMIUM: drm/virtio: rebase zero-copy patches to virgl/drm-misc-next
Linux 4.14.210
USB: core: Fix regression in Hercules audio card
USB: core: add endpoint-blacklist quirk
x86/resctrl: Add necessary kernfs_put() calls to prevent refcount leak
x86/resctrl: Remove superfluous kernfs_get() calls to prevent refcount leak
x86/speculation: Fix prctl() when spectre_v2_user={seccomp,prctl},ibpb
usb: gadget: Fix memleak in gadgetfs_fill_super
usb: gadget: f_midi: Fix memleak in f_midi_alloc
USB: core: Change %pK for __user pointers to %px
perf probe: Fix to die_entrypc() returns error correctly
can: m_can: fix nominal bitiming tseg2 min for version >= 3.1
platform/x86: toshiba_acpi: Fix the wrong variable assignment
can: gs_usb: fix endianess problem with candleLight firmware
efivarfs: revert "fix memory leak in efivarfs_create()"
ibmvnic: fix NULL pointer dereference in ibmvic_reset_crq
ibmvnic: fix NULL pointer dereference in reset_sub_crq_queues
net: ena: set initial DMA width to avoid intel iommu issue
nfc: s3fwrn5: use signed integer for parsing GPIO numbers
IB/mthca: fix return value of error branch in mthca_init_cq()
bnxt_en: Release PCI regions when DMA mask setup fails during probe.
video: hyperv_fb: Fix the cache type when mapping the VRAM
bnxt_en: fix error return code in bnxt_init_board()
bnxt_en: fix error return code in bnxt_init_one()
scsi: ufs: Fix race between shutdown and runtime resume flow
batman-adv: set .owner to THIS_MODULE
phy: tegra: xusb: Fix dangling pointer on probe failure
perf/x86: fix sysfs type mismatches
scsi: target: iscsi: Fix cmd abort fabric stop race
scsi: libiscsi: Fix NOP race condition
dmaengine: pl330: _prep_dma_memcpy: Fix wrong burst size
nvme: free sq/cq dbbuf pointers when dbbuf set fails
proc: don't allow async path resolution of /proc/self components
HID: Add Logitech Dinovo Edge battery quirk
x86/xen: don't unbind uninitialized lock_kicker_irq
dmaengine: xilinx_dma: use readl_poll_timeout_atomic variant
HID: hid-sensor-hub: Fix issue with devices with no report ID
Input: i8042 - allow insmod to succeed on devices without an i8042 controller
HID: cypress: Support Varmilo Keyboards' media hotkeys
ALSA: hda/hdmi: fix incorrect locking in hdmi_pcm_close
ALSA: hda/hdmi: Use single mutex unlock in error paths
arm64: pgtable: Ensure dirty bit is preserved across pte_wrprotect()
arm64: pgtable: Fix pte_accessible()
btrfs: inode: Verify inode mode to avoid NULL pointer dereference
btrfs: adjust return values of btrfs_inode_by_name
btrfs: tree-checker: Enhance chunk checker to validate chunk profile
PCI: Add device even if driver attach failed
wireless: Use linux/stddef.h instead of stddef.h
btrfs: fix lockdep splat when reading qgroup config on mount
mm/userfaultfd: do not access vma->vm_mm after calling handle_userfault()
perf event: Check ref_reloc_sym before using it
Linux 4.14.209
x86/microcode/intel: Check patch signature before saving microcode for early loading
s390/dasd: fix null pointer dereference for ERP requests
s390/cpum_sf.c: fix file permission for cpum_sfb_size
mac80211: free sta in sta_info_insert_finish() on errors
mac80211: minstrel: fix tx status processing corner case
mac80211: minstrel: remove deferred sampling code
xtensa: disable preemption around cache alias management calls
regulator: workaround self-referent regulators
regulator: avoid resolve_supply() infinite recursion
regulator: fix memory leak with repeated set_machine_constraints()
iio: accel: kxcjk1013: Add support for KIOX010A ACPI DSM for setting tablet-mode
iio: accel: kxcjk1013: Replace is_smo8500_device with an acpi_type enum
ext4: fix bogus warning in ext4_update_dx_flag()
staging: rtl8723bs: Add 024c:0627 to the list of SDIO device-ids
efivarfs: fix memory leak in efivarfs_create()
tty: serial: imx: keep console clocks always on
ALSA: mixart: Fix mutex deadlock
ALSA: ctl: fix error path at adding user-defined element set
speakup: Do not let the line discipline be used several times
powerpc/uaccess-flush: fix missing includes in kup-radix.h
libfs: fix error cast of negative value in simple_attr_write()
xfs: revert "xfs: fix rmap key and record comparison functions"
regulator: ti-abb: Fix array out of bound read access on the first transition
MIPS: Alchemy: Fix memleak in alchemy_clk_setup_cpu
ASoC: qcom: lpass-platform: Fix memory leak
can: m_can: m_can_handle_state_change(): fix state change
can: peak_usb: fix potential integer overflow on shift of a int
can: mcba_usb: mcba_usb_start_xmit(): first fill skb, then pass to can_put_echo_skb()
can: ti_hecc: Fix memleak in ti_hecc_probe
can: dev: can_restart(): post buffer from the right context
can: af_can: prevent potential access of uninitialized member in canfd_rcv()
can: af_can: prevent potential access of uninitialized member in can_rcv()
perf lock: Don't free "lock_seq_stat" if read_count isn't zero
ARM: dts: imx50-evk: Fix the chip select 1 IOMUX
arm: dts: imx6qdl-udoo: fix rgmii phy-mode for ksz9031 phy
MIPS: export has_transparent_hugepage() for modules
Input: adxl34x - clean up a data type in adxl34x_probe()
vfs: remove lockdep bogosity in __sb_start_write
arm64: psci: Avoid printing in cpu_psci_cpu_die()
pinctrl: rockchip: enable gpio pclk for rockchip_gpio_to_irq
net: ftgmac100: Fix crash when removing driver
tcp: only postpone PROBE_RTT if RTT is < current min_rtt estimate
net: usb: qmi_wwan: Set DTR quirk for MR400
net/mlx5: Disable QoS when min_rates on all VFs are zero
sctp: change to hold/put transport for proto_unreach_timer
qlcnic: fix error return code in qlcnic_83xx_restart_hw()
net: x25: Increase refcnt of "struct x25_neigh" in x25_rx_call_request
net/mlx4_core: Fix init_hca fields offset
netlabel: fix an uninitialized warning in netlbl_unlabel_staticlist()
netlabel: fix our progress tracking in netlbl_unlabel_staticlist()
net: Have netpoll bring-up DSA management interface
net: dsa: mv88e6xxx: Avoid VTU corruption on 6097
net: bridge: add missing counters to ndo_get_stats64 callback
net: b44: fix error return code in b44_init_one()
mlxsw: core: Use variable timeout for EMAD retries
inet_diag: Fix error path to cancel the meseage in inet_req_diag_fill()
devlink: Add missing genlmsg_cancel() in devlink_nl_sb_port_pool_fill()
bnxt_en: read EEPROM A2h address using page 0
atm: nicstar: Unmap DMA on send error
ah6: fix error return code in ah6_input()
ANDROID: Fix cuttlefish defconfigs now incfs uses zstd
ANDROID: Incremental fs: Add zstd compression support
ANDROID: Incremental fs: Small improvements
ANDROID: Incremental fs: Initialize mount options correctly
ANDROID: Incremental fs: Fix read_log_test which failed sporadically
ANDROID: Incremental fs: Fix misuse of cpu_to_leXX and poll return
ANDROID: Incremental fs: Add per UID read timeouts
ANDROID: Incremental fs: Add .incomplete folder
ANDROID: Incremental fs: Fix dangling else
ANDROID: Incremental fs: Fix uninitialized variable
ANDROID: Incremental fs: Fix filled block count from get filled blocks
ANDROID: Incremental fs: Add hash block counts to IOC_IOCTL_GET_BLOCK_COUNT
ANDROID: Incremental fs: Add INCFS_IOC_GET_BLOCK_COUNT
ANDROID: Incremental fs: Make compatible with existing files
ANDROID: Incremental fs: Remove block HASH flag
ANDROID: Incremental fs: Remove back links and crcs
ANDROID: Incremental fs: Remove attributes from file
ANDROID: Incremental fs: Add .blocks_written file
ANDROID: Incremental fs: Separate pseudo-file code
ANDROID: Incremental fs: Add UID to pending_read
ANDROID: Incremental fs: Create mapped file
ANDROID: Incremental fs: Don't allow renaming .index directory.
ANDROID: Incremental fs: Fix incfs to work on virtio-9p
ANDROID: Incremental fs: Allow running a single test
ANDROID: Incremental fs: Adding perf test
ANDROID: Incremental fs: Stress tool
ANDROID: Incremental fs: Use R/W locks to read/write segment blockmap.
ANDROID: Incremental fs: Remove unnecessary dependencies
ANDROID: Incremental fs: Remove annoying pr_debugs
ANDROID: Incremental fs: dentry_revalidate should not return -EBADF.
ANDROID: Incremental fs: Fix minor bugs
ANDROID: Incremental fs: RCU locks instead of mutex for pending_reads.
ANDROID: Incremental fs: fix up attempt to copy structures with READ/WRITE_ONCE
Linux 4.14.208
ACPI: GED: fix -Wformat
KVM: x86: clflushopt should be treated as a no-op by emulation
can: proc: can_remove_proc(): silence remove_proc_entry warning
mac80211: always wind down STA state
Input: sunkbd - avoid use-after-free in teardown paths
powerpc/8xx: Always fault when _PAGE_ACCESSED is not set
gpio: mockup: fix resource leak in error path
i2c: imx: Fix external abort on interrupt in exit paths
i2c: imx: use clk notifier for rate changes
powerpc/64s: flush L1D after user accesses
powerpc/uaccess: Evaluate macro arguments once, before user access is allowed
powerpc: Fix __clear_user() with KUAP enabled
powerpc: Implement user_access_begin and friends
powerpc: Add a framework for user access tracking
powerpc/64s: flush L1D on kernel entry
powerpc/64s: move some exception handlers out of line
powerpc/64s: Define MASKABLE_RELON_EXCEPTION_PSERIES_OOL
Linux 4.14.207
mm: fix exec activate_mm vs TLB shootdown and lazy tlb switching race
Convert trailing spaces and periods in path components
reboot: fix overflow parsing reboot cpu number
Revert "kernel/reboot.c: convert simple_strtoul to kstrtoint"
perf/core: Fix race in the perf_mmap_close() function
xen/events: block rogue events for some time
xen/events: defer eoi in case of excessive number of events
xen/events: use a common cpu hotplug hook for event channels
xen/events: switch user event channels to lateeoi model
xen/pciback: use lateeoi irq binding
xen/pvcallsback: use lateeoi irq binding
xen/scsiback: use lateeoi irq binding
xen/netback: use lateeoi irq binding
xen/blkback: use lateeoi irq binding
xen/events: add a new "late EOI" evtchn framework
xen/events: fix race in evtchn_fifo_unmask()
xen/events: add a proper barrier to 2-level uevent unmasking
xen/events: avoid removing an event channel while handling it
perf/core: Fix a memory leak in perf_event_parse_addr_filter()
perf/core: Fix crash when using HW tracing kernel filters
perf/core: Fix bad use of igrab()
x86/speculation: Allow IBPB to be conditionally enabled on CPUs with always-on STIBP
random32: make prandom_u32() output unpredictable
net: Update window_clamp if SOCK_RCVBUF is set
r8169: fix potential skb double free in an error path
vrf: Fix fast path output packet handling with async Netfilter rules
net/x25: Fix null-ptr-deref in x25_connect
net/af_iucv: fix null pointer dereference on shutdown
IPv6: Set SIT tunnel hard_header_len to zero
swiotlb: fix "x86: Don't panic if can not alloc buffer for swiotlb"
pinctrl: amd: fix incorrect way to disable debounce filter
pinctrl: amd: use higher precision for 512 RtcClk
drm/gma500: Fix out-of-bounds access to struct drm_device.vblank[]
don't dump the threads that had been already exiting when zapped.
selinux: Fix error return code in sel_ib_pkey_sid_slow()
ocfs2: initialize ip_next_orphan
futex: Don't enable IRQs unconditionally in put_pi_state()
mei: protect mei_cl_mtu from null dereference
usb: cdc-acm: Add DISABLE_ECHO for Renesas USB Download mode
uio: Fix use-after-free in uio_unregister_device()
thunderbolt: Add the missed ida_simple_remove() in ring_request_msix()
ext4: unlock xattr_sem properly in ext4_inline_data_truncate()
ext4: correctly report "not supported" for {usr,grp}jquota when !CONFIG_QUOTA
perf: Fix get_recursion_context()
cosa: Add missing kfree in error path of cosa_write
of/address: Fix of_node memory leak in of_dma_is_coherent
xfs: fix a missing unlock on error in xfs_fs_map_blocks
xfs: fix rmap key and record comparison functions
xfs: fix flags argument to rmap lookup when converting shared file rmaps
nbd: fix a block_device refcount leak in nbd_release
pinctrl: aspeed: Fix GPI only function problem.
ARM: 9019/1: kprobes: Avoid fortify_panic() when copying optprobe template
pinctrl: intel: Set default bias in case no particular value given
iommu/amd: Increase interrupt remapping table limit to 512 entries
scsi: scsi_dh_alua: Avoid crash during alua_bus_detach()
cfg80211: regulatory: Fix inconsistent format argument
mac80211: fix use of skb payload instead of header
drm/amdgpu: perform srbm soft reset always on SDMA resume
scsi: hpsa: Fix memory leak in hpsa_init_one()
gfs2: check for live vs. read-only file system in gfs2_fitrim
gfs2: Add missing truncate_inode_pages_final for sd_aspace
gfs2: Free rd_bits later in gfs2_clear_rgrpd to fix use-after-free
usb: gadget: goku_udc: fix potential crashes in probe
ath9k_htc: Use appropriate rs_datalen type
Btrfs: fix missing error return if writeback for extent buffer never started
xfs: flush new eof page on truncate to avoid post-eof corruption
can: peak_canfd: pucan_handle_can_rx(): fix echo management when loopback is on
can: peak_usb: peak_usb_get_ts_time(): fix timestamp wrapping
can: peak_usb: add range checking in decode operations
can: can_create_echo_skb(): fix echo skb generation: always use skb_clone()
can: dev: __can_get_echo_skb(): fix real payload length return value for RTR frames
can: dev: can_get_echo_skb(): prevent call to kfree_skb() in hard IRQ context
can: rx-offload: don't call kfree_skb() from IRQ context
ALSA: hda: prevent undefined shift in snd_hdac_ext_bus_get_link()
perf tools: Add missing swap for ino_generation
net: xfrm: fix a race condition during allocing spi
hv_balloon: disable warning when floor reached
genirq: Let GENERIC_IRQ_IPI select IRQ_DOMAIN_HIERARCHY
btrfs: reschedule when cloning lots of extents
btrfs: sysfs: init devices outside of the chunk_mutex
nbd: don't update block size after device is started
time: Prevent undefined behaviour in timespec64_to_ns()
mm: mempolicy: fix potential pte_unmap_unlock pte error
ring-buffer: Fix recursion protection transitions between interrupt context
regulator: defer probe when trying to get voltage from unresolved supply
UPSTREAM: sched: idle: Avoid retaining the tick when it has been stopped
UPSTREAM: cpuidle: menu: Handle stopped tick more aggressively
UPSTREAM: staging: android: vsoc: fix copy_from_user overrun
UPSTREAM: ipv6: ndisc: RFC-ietf-6man-ra-pref64-09 is now published as RFC8781
BACKPORT: drm/virtio: fix missing dma_fence_put() in virtio_gpu_execbuffer_ioctl()
Conflicts:
drivers/scsi/ufs/ufshcd.c
drivers/soc/qcom/smp2p.c
drivers/usb/gadget/function/f_accessory.c
drivers/usb/gadget/function/f_fs.c
drivers/usb/gadget/function/f_uac2.c
Change-Id: I7ec83fef94dcc943abd858eb81e4a78983faae8c
806 lines
28 KiB
C
806 lines
28 KiB
C
/* SPDX-License-Identifier: GPL-2.0 */
|
|
#ifndef _LINUX_TTY_H
|
|
#define _LINUX_TTY_H
|
|
|
|
#include <linux/fs.h>
|
|
#include <linux/major.h>
|
|
#include <linux/termios.h>
|
|
#include <linux/workqueue.h>
|
|
#include <linux/tty_driver.h>
|
|
#include <linux/tty_ldisc.h>
|
|
#include <linux/mutex.h>
|
|
#include <linux/tty_flags.h>
|
|
#include <uapi/linux/tty.h>
|
|
#include <linux/rwsem.h>
|
|
#include <linux/llist.h>
|
|
|
|
|
|
/*
|
|
* Lock subclasses for tty locks
|
|
*
|
|
* TTY_LOCK_NORMAL is for normal ttys and master ptys.
|
|
* TTY_LOCK_SLAVE is for slave ptys only.
|
|
*
|
|
* Lock subclasses are necessary for handling nested locking with pty pairs.
|
|
* tty locks which use nested locking:
|
|
*
|
|
* legacy_mutex - Nested tty locks are necessary for releasing pty pairs.
|
|
* The stable lock order is master pty first, then slave pty.
|
|
* termios_rwsem - The stable lock order is tty_buffer lock->termios_rwsem.
|
|
* Subclassing this lock enables the slave pty to hold its
|
|
* termios_rwsem when claiming the master tty_buffer lock.
|
|
* tty_buffer lock - slave ptys can claim nested buffer lock when handling
|
|
* signal chars. The stable lock order is slave pty, then
|
|
* master.
|
|
*/
|
|
|
|
enum {
|
|
TTY_LOCK_NORMAL = 0,
|
|
TTY_LOCK_SLAVE,
|
|
};
|
|
|
|
/*
|
|
* (Note: the *_driver.minor_start values 1, 64, 128, 192 are
|
|
* hardcoded at present.)
|
|
*/
|
|
#define NR_UNIX98_PTY_DEFAULT 4096 /* Default maximum for Unix98 ptys */
|
|
#define NR_UNIX98_PTY_RESERVE 1024 /* Default reserve for main devpts */
|
|
#define NR_UNIX98_PTY_MAX (1 << MINORBITS) /* Absolute limit */
|
|
|
|
/*
|
|
* This character is the same as _POSIX_VDISABLE: it cannot be used as
|
|
* a c_cc[] character, but indicates that a particular special character
|
|
* isn't in use (eg VINTR has no character etc)
|
|
*/
|
|
#define __DISABLED_CHAR '\0'
|
|
|
|
struct tty_buffer {
|
|
union {
|
|
struct tty_buffer *next;
|
|
struct llist_node free;
|
|
};
|
|
int used;
|
|
int size;
|
|
int commit;
|
|
int read;
|
|
int flags;
|
|
/* Data points here */
|
|
unsigned long data[];
|
|
};
|
|
|
|
/* Values for .flags field of tty_buffer */
|
|
#define TTYB_NORMAL 1 /* buffer has no flags buffer */
|
|
|
|
static inline unsigned char *char_buf_ptr(struct tty_buffer *b, int ofs)
|
|
{
|
|
return ((unsigned char *)b->data) + ofs;
|
|
}
|
|
|
|
static inline char *flag_buf_ptr(struct tty_buffer *b, int ofs)
|
|
{
|
|
return (char *)char_buf_ptr(b, ofs) + b->size;
|
|
}
|
|
|
|
struct tty_bufhead {
|
|
struct tty_buffer *head; /* Queue head */
|
|
struct work_struct work;
|
|
struct mutex lock;
|
|
atomic_t priority;
|
|
struct tty_buffer sentinel;
|
|
struct llist_head free; /* Free queue head */
|
|
atomic_t mem_used; /* In-use buffers excluding free list */
|
|
int mem_limit;
|
|
struct tty_buffer *tail; /* Active buffer */
|
|
};
|
|
/*
|
|
* When a break, frame error, or parity error happens, these codes are
|
|
* stuffed into the flags buffer.
|
|
*/
|
|
#define TTY_NORMAL 0
|
|
#define TTY_BREAK 1
|
|
#define TTY_FRAME 2
|
|
#define TTY_PARITY 3
|
|
#define TTY_OVERRUN 4
|
|
|
|
#define INTR_CHAR(tty) ((tty)->termios.c_cc[VINTR])
|
|
#define QUIT_CHAR(tty) ((tty)->termios.c_cc[VQUIT])
|
|
#define ERASE_CHAR(tty) ((tty)->termios.c_cc[VERASE])
|
|
#define KILL_CHAR(tty) ((tty)->termios.c_cc[VKILL])
|
|
#define EOF_CHAR(tty) ((tty)->termios.c_cc[VEOF])
|
|
#define TIME_CHAR(tty) ((tty)->termios.c_cc[VTIME])
|
|
#define MIN_CHAR(tty) ((tty)->termios.c_cc[VMIN])
|
|
#define SWTC_CHAR(tty) ((tty)->termios.c_cc[VSWTC])
|
|
#define START_CHAR(tty) ((tty)->termios.c_cc[VSTART])
|
|
#define STOP_CHAR(tty) ((tty)->termios.c_cc[VSTOP])
|
|
#define SUSP_CHAR(tty) ((tty)->termios.c_cc[VSUSP])
|
|
#define EOL_CHAR(tty) ((tty)->termios.c_cc[VEOL])
|
|
#define REPRINT_CHAR(tty) ((tty)->termios.c_cc[VREPRINT])
|
|
#define DISCARD_CHAR(tty) ((tty)->termios.c_cc[VDISCARD])
|
|
#define WERASE_CHAR(tty) ((tty)->termios.c_cc[VWERASE])
|
|
#define LNEXT_CHAR(tty) ((tty)->termios.c_cc[VLNEXT])
|
|
#define EOL2_CHAR(tty) ((tty)->termios.c_cc[VEOL2])
|
|
|
|
#define _I_FLAG(tty, f) ((tty)->termios.c_iflag & (f))
|
|
#define _O_FLAG(tty, f) ((tty)->termios.c_oflag & (f))
|
|
#define _C_FLAG(tty, f) ((tty)->termios.c_cflag & (f))
|
|
#define _L_FLAG(tty, f) ((tty)->termios.c_lflag & (f))
|
|
|
|
#define I_IGNBRK(tty) _I_FLAG((tty), IGNBRK)
|
|
#define I_BRKINT(tty) _I_FLAG((tty), BRKINT)
|
|
#define I_IGNPAR(tty) _I_FLAG((tty), IGNPAR)
|
|
#define I_PARMRK(tty) _I_FLAG((tty), PARMRK)
|
|
#define I_INPCK(tty) _I_FLAG((tty), INPCK)
|
|
#define I_ISTRIP(tty) _I_FLAG((tty), ISTRIP)
|
|
#define I_INLCR(tty) _I_FLAG((tty), INLCR)
|
|
#define I_IGNCR(tty) _I_FLAG((tty), IGNCR)
|
|
#define I_ICRNL(tty) _I_FLAG((tty), ICRNL)
|
|
#define I_IUCLC(tty) _I_FLAG((tty), IUCLC)
|
|
#define I_IXON(tty) _I_FLAG((tty), IXON)
|
|
#define I_IXANY(tty) _I_FLAG((tty), IXANY)
|
|
#define I_IXOFF(tty) _I_FLAG((tty), IXOFF)
|
|
#define I_IMAXBEL(tty) _I_FLAG((tty), IMAXBEL)
|
|
#define I_IUTF8(tty) _I_FLAG((tty), IUTF8)
|
|
|
|
#define O_OPOST(tty) _O_FLAG((tty), OPOST)
|
|
#define O_OLCUC(tty) _O_FLAG((tty), OLCUC)
|
|
#define O_ONLCR(tty) _O_FLAG((tty), ONLCR)
|
|
#define O_OCRNL(tty) _O_FLAG((tty), OCRNL)
|
|
#define O_ONOCR(tty) _O_FLAG((tty), ONOCR)
|
|
#define O_ONLRET(tty) _O_FLAG((tty), ONLRET)
|
|
#define O_OFILL(tty) _O_FLAG((tty), OFILL)
|
|
#define O_OFDEL(tty) _O_FLAG((tty), OFDEL)
|
|
#define O_NLDLY(tty) _O_FLAG((tty), NLDLY)
|
|
#define O_CRDLY(tty) _O_FLAG((tty), CRDLY)
|
|
#define O_TABDLY(tty) _O_FLAG((tty), TABDLY)
|
|
#define O_BSDLY(tty) _O_FLAG((tty), BSDLY)
|
|
#define O_VTDLY(tty) _O_FLAG((tty), VTDLY)
|
|
#define O_FFDLY(tty) _O_FLAG((tty), FFDLY)
|
|
|
|
#define C_BAUD(tty) _C_FLAG((tty), CBAUD)
|
|
#define C_CSIZE(tty) _C_FLAG((tty), CSIZE)
|
|
#define C_CSTOPB(tty) _C_FLAG((tty), CSTOPB)
|
|
#define C_CREAD(tty) _C_FLAG((tty), CREAD)
|
|
#define C_PARENB(tty) _C_FLAG((tty), PARENB)
|
|
#define C_PARODD(tty) _C_FLAG((tty), PARODD)
|
|
#define C_HUPCL(tty) _C_FLAG((tty), HUPCL)
|
|
#define C_CLOCAL(tty) _C_FLAG((tty), CLOCAL)
|
|
#define C_CIBAUD(tty) _C_FLAG((tty), CIBAUD)
|
|
#define C_CRTSCTS(tty) _C_FLAG((tty), CRTSCTS)
|
|
#define C_CMSPAR(tty) _C_FLAG((tty), CMSPAR)
|
|
|
|
#define L_ISIG(tty) _L_FLAG((tty), ISIG)
|
|
#define L_ICANON(tty) _L_FLAG((tty), ICANON)
|
|
#define L_XCASE(tty) _L_FLAG((tty), XCASE)
|
|
#define L_ECHO(tty) _L_FLAG((tty), ECHO)
|
|
#define L_ECHOE(tty) _L_FLAG((tty), ECHOE)
|
|
#define L_ECHOK(tty) _L_FLAG((tty), ECHOK)
|
|
#define L_ECHONL(tty) _L_FLAG((tty), ECHONL)
|
|
#define L_NOFLSH(tty) _L_FLAG((tty), NOFLSH)
|
|
#define L_TOSTOP(tty) _L_FLAG((tty), TOSTOP)
|
|
#define L_ECHOCTL(tty) _L_FLAG((tty), ECHOCTL)
|
|
#define L_ECHOPRT(tty) _L_FLAG((tty), ECHOPRT)
|
|
#define L_ECHOKE(tty) _L_FLAG((tty), ECHOKE)
|
|
#define L_FLUSHO(tty) _L_FLAG((tty), FLUSHO)
|
|
#define L_PENDIN(tty) _L_FLAG((tty), PENDIN)
|
|
#define L_IEXTEN(tty) _L_FLAG((tty), IEXTEN)
|
|
#define L_EXTPROC(tty) _L_FLAG((tty), EXTPROC)
|
|
|
|
struct device;
|
|
struct signal_struct;
|
|
|
|
/*
|
|
* Port level information. Each device keeps its own port level information
|
|
* so provide a common structure for those ports wanting to use common support
|
|
* routines.
|
|
*
|
|
* The tty port has a different lifetime to the tty so must be kept apart.
|
|
* In addition be careful as tty -> port mappings are valid for the life
|
|
* of the tty object but in many cases port -> tty mappings are valid only
|
|
* until a hangup so don't use the wrong path.
|
|
*/
|
|
|
|
struct tty_port;
|
|
|
|
struct tty_port_operations {
|
|
/* Return 1 if the carrier is raised */
|
|
int (*carrier_raised)(struct tty_port *port);
|
|
/* Control the DTR line */
|
|
void (*dtr_rts)(struct tty_port *port, int raise);
|
|
/* Called when the last close completes or a hangup finishes
|
|
IFF the port was initialized. Do not use to free resources. Called
|
|
under the port mutex to serialize against activate/shutdowns */
|
|
void (*shutdown)(struct tty_port *port);
|
|
/* Called under the port mutex from tty_port_open, serialized using
|
|
the port mutex */
|
|
/* FIXME: long term getting the tty argument *out* of this would be
|
|
good for consoles */
|
|
int (*activate)(struct tty_port *port, struct tty_struct *tty);
|
|
/* Called on the final put of a port */
|
|
void (*destruct)(struct tty_port *port);
|
|
};
|
|
|
|
struct tty_port_client_operations {
|
|
int (*receive_buf)(struct tty_port *port, const unsigned char *, const unsigned char *, size_t);
|
|
void (*write_wakeup)(struct tty_port *port);
|
|
};
|
|
|
|
extern const struct tty_port_client_operations tty_port_default_client_ops;
|
|
|
|
struct tty_port {
|
|
struct tty_bufhead buf; /* Locked internally */
|
|
struct tty_struct *tty; /* Back pointer */
|
|
struct tty_struct *itty; /* internal back ptr */
|
|
const struct tty_port_operations *ops; /* Port operations */
|
|
const struct tty_port_client_operations *client_ops; /* Port client operations */
|
|
spinlock_t lock; /* Lock protecting tty field */
|
|
int blocked_open; /* Waiting to open */
|
|
int count; /* Usage count */
|
|
wait_queue_head_t open_wait; /* Open waiters */
|
|
wait_queue_head_t delta_msr_wait; /* Modem status change */
|
|
unsigned long flags; /* User TTY flags ASYNC_ */
|
|
unsigned long iflags; /* Internal flags TTY_PORT_ */
|
|
unsigned char console:1, /* port is a console */
|
|
low_latency:1; /* optional: tune for latency */
|
|
struct mutex mutex; /* Locking */
|
|
struct mutex buf_mutex; /* Buffer alloc lock */
|
|
unsigned char *xmit_buf; /* Optional buffer */
|
|
unsigned int close_delay; /* Close port delay */
|
|
unsigned int closing_wait; /* Delay for output */
|
|
int drain_delay; /* Set to zero if no pure time
|
|
based drain is needed else
|
|
set to size of fifo */
|
|
struct kref kref; /* Ref counter */
|
|
void *client_data;
|
|
};
|
|
|
|
/* tty_port::iflags bits -- use atomic bit ops */
|
|
#define TTY_PORT_INITIALIZED 0 /* device is initialized */
|
|
#define TTY_PORT_SUSPENDED 1 /* device is suspended */
|
|
#define TTY_PORT_ACTIVE 2 /* device is open */
|
|
|
|
/*
|
|
* uart drivers: use the uart_port::status field and the UPSTAT_* defines
|
|
* for s/w-based flow control steering and carrier detection status
|
|
*/
|
|
#define TTY_PORT_CTS_FLOW 3 /* h/w flow control enabled */
|
|
#define TTY_PORT_CHECK_CD 4 /* carrier detect enabled */
|
|
#define TTY_PORT_KOPENED 5 /* device exclusively opened by
|
|
kernel */
|
|
|
|
/*
|
|
* Where all of the state associated with a tty is kept while the tty
|
|
* is open. Since the termios state should be kept even if the tty
|
|
* has been closed --- for things like the baud rate, etc --- it is
|
|
* not stored here, but rather a pointer to the real state is stored
|
|
* here. Possible the winsize structure should have the same
|
|
* treatment, but (1) the default 80x24 is usually right and (2) it's
|
|
* most often used by a windowing system, which will set the correct
|
|
* size each time the window is created or resized anyway.
|
|
* - TYT, 9/14/92
|
|
*/
|
|
|
|
struct tty_operations;
|
|
|
|
struct tty_struct {
|
|
int magic;
|
|
struct kref kref;
|
|
struct device *dev;
|
|
struct tty_driver *driver;
|
|
const struct tty_operations *ops;
|
|
int index;
|
|
|
|
/* Protects ldisc changes: Lock tty not pty */
|
|
struct ld_semaphore ldisc_sem;
|
|
struct tty_ldisc *ldisc;
|
|
|
|
struct mutex atomic_write_lock;
|
|
struct mutex legacy_mutex;
|
|
struct mutex throttle_mutex;
|
|
struct rw_semaphore termios_rwsem;
|
|
struct mutex winsize_mutex;
|
|
spinlock_t ctrl_lock;
|
|
spinlock_t flow_lock;
|
|
/* Termios values are protected by the termios rwsem */
|
|
struct ktermios termios, termios_locked;
|
|
struct termiox *termiox; /* May be NULL for unsupported */
|
|
char name[64];
|
|
struct pid *pgrp; /* Protected by ctrl lock */
|
|
/*
|
|
* Writes protected by both ctrl lock and legacy mutex, readers must use
|
|
* at least one of them.
|
|
*/
|
|
struct pid *session;
|
|
unsigned long flags;
|
|
int count;
|
|
struct winsize winsize; /* winsize_mutex */
|
|
unsigned long stopped:1, /* flow_lock */
|
|
flow_stopped:1,
|
|
unused:BITS_PER_LONG - 2;
|
|
int hw_stopped;
|
|
unsigned long ctrl_status:8, /* ctrl_lock */
|
|
packet:1,
|
|
unused_ctrl:BITS_PER_LONG - 9;
|
|
unsigned int receive_room; /* Bytes free for queue */
|
|
int flow_change;
|
|
|
|
struct tty_struct *link;
|
|
struct fasync_struct *fasync;
|
|
wait_queue_head_t write_wait;
|
|
wait_queue_head_t read_wait;
|
|
struct work_struct hangup_work;
|
|
#if defined(CONFIG_TTY_FLUSH_LOCAL_ECHO)
|
|
int delayed_work;
|
|
struct delayed_work echo_delayed_work;
|
|
#endif
|
|
void *disc_data;
|
|
void *driver_data;
|
|
spinlock_t files_lock; /* protects tty_files list */
|
|
struct list_head tty_files;
|
|
|
|
#define N_TTY_BUF_SIZE 4096
|
|
|
|
int closing;
|
|
unsigned char *write_buf;
|
|
int write_cnt;
|
|
/* If the tty has a pending do_SAK, queue it here - akpm */
|
|
struct work_struct SAK_work;
|
|
struct tty_port *port;
|
|
} __randomize_layout;
|
|
|
|
/* Each of a tty's open files has private_data pointing to tty_file_private */
|
|
struct tty_file_private {
|
|
struct tty_struct *tty;
|
|
struct file *file;
|
|
struct list_head list;
|
|
};
|
|
|
|
/* tty magic number */
|
|
#define TTY_MAGIC 0x5401
|
|
|
|
/*
|
|
* These bits are used in the flags field of the tty structure.
|
|
*
|
|
* So that interrupts won't be able to mess up the queues,
|
|
* copy_to_cooked must be atomic with respect to itself, as must
|
|
* tty->write. Thus, you must use the inline functions set_bit() and
|
|
* clear_bit() to make things atomic.
|
|
*/
|
|
#define TTY_THROTTLED 0 /* Call unthrottle() at threshold min */
|
|
#define TTY_IO_ERROR 1 /* Cause an I/O error (may be no ldisc too) */
|
|
#define TTY_OTHER_CLOSED 2 /* Other side (if any) has closed */
|
|
#define TTY_EXCLUSIVE 3 /* Exclusive open mode */
|
|
#define TTY_DO_WRITE_WAKEUP 5 /* Call write_wakeup after queuing new */
|
|
#define TTY_LDISC_OPEN 11 /* Line discipline is open */
|
|
#define TTY_PTY_LOCK 16 /* pty private */
|
|
#define TTY_NO_WRITE_SPLIT 17 /* Preserve write boundaries to driver */
|
|
#define TTY_HUPPED 18 /* Post driver->hangup() */
|
|
#define TTY_HUPPING 19 /* Hangup in progress */
|
|
#define TTY_LDISC_CHANGING 20 /* Change pending - non-block IO */
|
|
#define TTY_LDISC_HALTED 22 /* Line discipline is halted */
|
|
|
|
/* Values for tty->flow_change */
|
|
#define TTY_THROTTLE_SAFE 1
|
|
#define TTY_UNTHROTTLE_SAFE 2
|
|
|
|
static inline void __tty_set_flow_change(struct tty_struct *tty, int val)
|
|
{
|
|
tty->flow_change = val;
|
|
}
|
|
|
|
static inline void tty_set_flow_change(struct tty_struct *tty, int val)
|
|
{
|
|
tty->flow_change = val;
|
|
smp_mb();
|
|
}
|
|
|
|
static inline bool tty_io_nonblock(struct tty_struct *tty, struct file *file)
|
|
{
|
|
return file->f_flags & O_NONBLOCK ||
|
|
test_bit(TTY_LDISC_CHANGING, &tty->flags);
|
|
}
|
|
|
|
static inline bool tty_io_error(struct tty_struct *tty)
|
|
{
|
|
return test_bit(TTY_IO_ERROR, &tty->flags);
|
|
}
|
|
|
|
static inline bool tty_throttled(struct tty_struct *tty)
|
|
{
|
|
return test_bit(TTY_THROTTLED, &tty->flags);
|
|
}
|
|
|
|
#ifdef CONFIG_TTY
|
|
extern void tty_kref_put(struct tty_struct *tty);
|
|
extern struct pid *tty_get_pgrp(struct tty_struct *tty);
|
|
extern void tty_vhangup_self(void);
|
|
extern void disassociate_ctty(int priv);
|
|
extern dev_t tty_devnum(struct tty_struct *tty);
|
|
extern void proc_clear_tty(struct task_struct *p);
|
|
extern struct tty_struct *get_current_tty(void);
|
|
/* tty_io.c */
|
|
extern int __init tty_init(void);
|
|
extern const char *tty_name(const struct tty_struct *tty);
|
|
extern struct tty_struct *tty_kopen(dev_t device);
|
|
extern void tty_kclose(struct tty_struct *tty);
|
|
extern int tty_dev_name_to_number(const char *name, dev_t *number);
|
|
extern int tty_ldisc_lock(struct tty_struct *tty, unsigned long timeout);
|
|
extern void tty_ldisc_unlock(struct tty_struct *tty);
|
|
#else
|
|
static inline void tty_kref_put(struct tty_struct *tty)
|
|
{ }
|
|
static inline struct pid *tty_get_pgrp(struct tty_struct *tty)
|
|
{ return NULL; }
|
|
static inline void tty_vhangup_self(void)
|
|
{ }
|
|
static inline void disassociate_ctty(int priv)
|
|
{ }
|
|
static inline dev_t tty_devnum(struct tty_struct *tty)
|
|
{ return 0; }
|
|
static inline void proc_clear_tty(struct task_struct *p)
|
|
{ }
|
|
static inline struct tty_struct *get_current_tty(void)
|
|
{ return NULL; }
|
|
/* tty_io.c */
|
|
static inline int __init tty_init(void)
|
|
{ return 0; }
|
|
static inline const char *tty_name(const struct tty_struct *tty)
|
|
{ return "(none)"; }
|
|
static inline struct tty_struct *tty_kopen(dev_t device)
|
|
{ return ERR_PTR(-ENODEV); }
|
|
static inline void tty_kclose(struct tty_struct *tty)
|
|
{ }
|
|
static inline int tty_dev_name_to_number(const char *name, dev_t *number)
|
|
{ return -ENOTSUPP; }
|
|
#endif
|
|
|
|
extern struct ktermios tty_std_termios;
|
|
|
|
extern int vcs_init(void);
|
|
|
|
extern struct class *tty_class;
|
|
|
|
/**
|
|
* tty_kref_get - get a tty reference
|
|
* @tty: tty device
|
|
*
|
|
* Return a new reference to a tty object. The caller must hold
|
|
* sufficient locks/counts to ensure that their existing reference cannot
|
|
* go away
|
|
*/
|
|
|
|
static inline struct tty_struct *tty_kref_get(struct tty_struct *tty)
|
|
{
|
|
if (tty)
|
|
kref_get(&tty->kref);
|
|
return tty;
|
|
}
|
|
|
|
extern const char *tty_driver_name(const struct tty_struct *tty);
|
|
extern void tty_wait_until_sent(struct tty_struct *tty, long timeout);
|
|
extern int __tty_check_change(struct tty_struct *tty, int sig);
|
|
extern int tty_check_change(struct tty_struct *tty);
|
|
extern void __stop_tty(struct tty_struct *tty);
|
|
extern void stop_tty(struct tty_struct *tty);
|
|
extern void __start_tty(struct tty_struct *tty);
|
|
extern void start_tty(struct tty_struct *tty);
|
|
extern int tty_register_driver(struct tty_driver *driver);
|
|
extern int tty_unregister_driver(struct tty_driver *driver);
|
|
extern struct device *tty_register_device(struct tty_driver *driver,
|
|
unsigned index, struct device *dev);
|
|
extern struct device *tty_register_device_attr(struct tty_driver *driver,
|
|
unsigned index, struct device *device,
|
|
void *drvdata,
|
|
const struct attribute_group **attr_grp);
|
|
extern void tty_unregister_device(struct tty_driver *driver, unsigned index);
|
|
extern void tty_write_message(struct tty_struct *tty, char *msg);
|
|
extern int tty_send_xchar(struct tty_struct *tty, char ch);
|
|
extern int tty_put_char(struct tty_struct *tty, unsigned char c);
|
|
extern int tty_chars_in_buffer(struct tty_struct *tty);
|
|
extern int tty_write_room(struct tty_struct *tty);
|
|
extern void tty_driver_flush_buffer(struct tty_struct *tty);
|
|
extern void tty_throttle(struct tty_struct *tty);
|
|
extern void tty_unthrottle(struct tty_struct *tty);
|
|
extern int tty_throttle_safe(struct tty_struct *tty);
|
|
extern int tty_unthrottle_safe(struct tty_struct *tty);
|
|
extern int tty_do_resize(struct tty_struct *tty, struct winsize *ws);
|
|
extern int is_current_pgrp_orphaned(void);
|
|
extern void tty_hangup(struct tty_struct *tty);
|
|
extern void tty_vhangup(struct tty_struct *tty);
|
|
extern void tty_vhangup_session(struct tty_struct *tty);
|
|
extern int tty_hung_up_p(struct file *filp);
|
|
extern void do_SAK(struct tty_struct *tty);
|
|
extern void __do_SAK(struct tty_struct *tty);
|
|
extern void tty_open_proc_set_tty(struct file *filp, struct tty_struct *tty);
|
|
extern int tty_signal_session_leader(struct tty_struct *tty, int exit_session);
|
|
extern void session_clear_tty(struct pid *session);
|
|
extern void no_tty(void);
|
|
extern void tty_buffer_free_all(struct tty_port *port);
|
|
extern void tty_buffer_flush(struct tty_struct *tty, struct tty_ldisc *ld);
|
|
extern void tty_buffer_init(struct tty_port *port);
|
|
extern void tty_buffer_set_lock_subclass(struct tty_port *port);
|
|
extern bool tty_buffer_restart_work(struct tty_port *port);
|
|
extern bool tty_buffer_cancel_work(struct tty_port *port);
|
|
extern void tty_buffer_flush_work(struct tty_port *port);
|
|
extern speed_t tty_termios_baud_rate(struct ktermios *termios);
|
|
extern speed_t tty_termios_input_baud_rate(struct ktermios *termios);
|
|
extern void tty_termios_encode_baud_rate(struct ktermios *termios,
|
|
speed_t ibaud, speed_t obaud);
|
|
extern void tty_encode_baud_rate(struct tty_struct *tty,
|
|
speed_t ibaud, speed_t obaud);
|
|
|
|
/**
|
|
* tty_get_baud_rate - get tty bit rates
|
|
* @tty: tty to query
|
|
*
|
|
* Returns the baud rate as an integer for this terminal. The
|
|
* termios lock must be held by the caller and the terminal bit
|
|
* flags may be updated.
|
|
*
|
|
* Locking: none
|
|
*/
|
|
static inline speed_t tty_get_baud_rate(struct tty_struct *tty)
|
|
{
|
|
return tty_termios_baud_rate(&tty->termios);
|
|
}
|
|
|
|
extern void tty_termios_copy_hw(struct ktermios *new, struct ktermios *old);
|
|
extern int tty_termios_hw_change(struct ktermios *a, struct ktermios *b);
|
|
extern int tty_set_termios(struct tty_struct *tty, struct ktermios *kt);
|
|
|
|
extern struct tty_ldisc *tty_ldisc_ref(struct tty_struct *);
|
|
extern void tty_ldisc_deref(struct tty_ldisc *);
|
|
extern struct tty_ldisc *tty_ldisc_ref_wait(struct tty_struct *);
|
|
extern void tty_ldisc_hangup(struct tty_struct *tty, bool reset);
|
|
extern int tty_ldisc_reinit(struct tty_struct *tty, int disc);
|
|
extern const struct file_operations tty_ldiscs_proc_fops;
|
|
|
|
extern void tty_wakeup(struct tty_struct *tty);
|
|
extern void tty_ldisc_flush(struct tty_struct *tty);
|
|
|
|
extern long tty_ioctl(struct file *file, unsigned int cmd, unsigned long arg);
|
|
extern int tty_mode_ioctl(struct tty_struct *tty, struct file *file,
|
|
unsigned int cmd, unsigned long arg);
|
|
extern long tty_jobctrl_ioctl(struct tty_struct *tty, struct tty_struct *real_tty,
|
|
struct file *file, unsigned int cmd, unsigned long arg);
|
|
extern int tty_perform_flush(struct tty_struct *tty, unsigned long arg);
|
|
extern void tty_default_fops(struct file_operations *fops);
|
|
extern struct tty_struct *alloc_tty_struct(struct tty_driver *driver, int idx);
|
|
extern int tty_alloc_file(struct file *file);
|
|
extern void tty_add_file(struct tty_struct *tty, struct file *file);
|
|
extern void tty_free_file(struct file *file);
|
|
extern struct tty_struct *tty_init_dev(struct tty_driver *driver, int idx);
|
|
extern void tty_release_struct(struct tty_struct *tty, int idx);
|
|
extern int tty_release(struct inode *inode, struct file *filp);
|
|
extern void tty_init_termios(struct tty_struct *tty);
|
|
extern int tty_standard_install(struct tty_driver *driver,
|
|
struct tty_struct *tty);
|
|
|
|
extern struct mutex tty_mutex;
|
|
|
|
#define tty_is_writelocked(tty) (mutex_is_locked(&tty->atomic_write_lock))
|
|
|
|
extern void tty_port_init(struct tty_port *port);
|
|
extern void tty_port_link_device(struct tty_port *port,
|
|
struct tty_driver *driver, unsigned index);
|
|
extern struct device *tty_port_register_device(struct tty_port *port,
|
|
struct tty_driver *driver, unsigned index,
|
|
struct device *device);
|
|
extern struct device *tty_port_register_device_attr(struct tty_port *port,
|
|
struct tty_driver *driver, unsigned index,
|
|
struct device *device, void *drvdata,
|
|
const struct attribute_group **attr_grp);
|
|
extern struct device *tty_port_register_device_serdev(struct tty_port *port,
|
|
struct tty_driver *driver, unsigned index,
|
|
struct device *device);
|
|
extern struct device *tty_port_register_device_attr_serdev(struct tty_port *port,
|
|
struct tty_driver *driver, unsigned index,
|
|
struct device *device, void *drvdata,
|
|
const struct attribute_group **attr_grp);
|
|
extern void tty_port_unregister_device(struct tty_port *port,
|
|
struct tty_driver *driver, unsigned index);
|
|
extern int tty_port_alloc_xmit_buf(struct tty_port *port);
|
|
extern void tty_port_free_xmit_buf(struct tty_port *port);
|
|
extern void tty_port_destroy(struct tty_port *port);
|
|
extern void tty_port_put(struct tty_port *port);
|
|
|
|
static inline struct tty_port *tty_port_get(struct tty_port *port)
|
|
{
|
|
if (port && kref_get_unless_zero(&port->kref))
|
|
return port;
|
|
return NULL;
|
|
}
|
|
|
|
/* If the cts flow control is enabled, return true. */
|
|
static inline bool tty_port_cts_enabled(struct tty_port *port)
|
|
{
|
|
return test_bit(TTY_PORT_CTS_FLOW, &port->iflags);
|
|
}
|
|
|
|
static inline void tty_port_set_cts_flow(struct tty_port *port, bool val)
|
|
{
|
|
if (val)
|
|
set_bit(TTY_PORT_CTS_FLOW, &port->iflags);
|
|
else
|
|
clear_bit(TTY_PORT_CTS_FLOW, &port->iflags);
|
|
}
|
|
|
|
static inline bool tty_port_active(struct tty_port *port)
|
|
{
|
|
return test_bit(TTY_PORT_ACTIVE, &port->iflags);
|
|
}
|
|
|
|
static inline void tty_port_set_active(struct tty_port *port, bool val)
|
|
{
|
|
if (val)
|
|
set_bit(TTY_PORT_ACTIVE, &port->iflags);
|
|
else
|
|
clear_bit(TTY_PORT_ACTIVE, &port->iflags);
|
|
}
|
|
|
|
static inline bool tty_port_check_carrier(struct tty_port *port)
|
|
{
|
|
return test_bit(TTY_PORT_CHECK_CD, &port->iflags);
|
|
}
|
|
|
|
static inline void tty_port_set_check_carrier(struct tty_port *port, bool val)
|
|
{
|
|
if (val)
|
|
set_bit(TTY_PORT_CHECK_CD, &port->iflags);
|
|
else
|
|
clear_bit(TTY_PORT_CHECK_CD, &port->iflags);
|
|
}
|
|
|
|
static inline bool tty_port_suspended(struct tty_port *port)
|
|
{
|
|
return test_bit(TTY_PORT_SUSPENDED, &port->iflags);
|
|
}
|
|
|
|
static inline void tty_port_set_suspended(struct tty_port *port, bool val)
|
|
{
|
|
if (val)
|
|
set_bit(TTY_PORT_SUSPENDED, &port->iflags);
|
|
else
|
|
clear_bit(TTY_PORT_SUSPENDED, &port->iflags);
|
|
}
|
|
|
|
static inline bool tty_port_initialized(struct tty_port *port)
|
|
{
|
|
return test_bit(TTY_PORT_INITIALIZED, &port->iflags);
|
|
}
|
|
|
|
static inline void tty_port_set_initialized(struct tty_port *port, bool val)
|
|
{
|
|
if (val)
|
|
set_bit(TTY_PORT_INITIALIZED, &port->iflags);
|
|
else
|
|
clear_bit(TTY_PORT_INITIALIZED, &port->iflags);
|
|
}
|
|
|
|
static inline bool tty_port_kopened(struct tty_port *port)
|
|
{
|
|
return test_bit(TTY_PORT_KOPENED, &port->iflags);
|
|
}
|
|
|
|
static inline void tty_port_set_kopened(struct tty_port *port, bool val)
|
|
{
|
|
if (val)
|
|
set_bit(TTY_PORT_KOPENED, &port->iflags);
|
|
else
|
|
clear_bit(TTY_PORT_KOPENED, &port->iflags);
|
|
}
|
|
|
|
extern struct tty_struct *tty_port_tty_get(struct tty_port *port);
|
|
extern void tty_port_tty_set(struct tty_port *port, struct tty_struct *tty);
|
|
extern int tty_port_carrier_raised(struct tty_port *port);
|
|
extern void tty_port_raise_dtr_rts(struct tty_port *port);
|
|
extern void tty_port_lower_dtr_rts(struct tty_port *port);
|
|
extern void tty_port_hangup(struct tty_port *port);
|
|
extern void tty_port_tty_hangup(struct tty_port *port, bool check_clocal);
|
|
extern void tty_port_tty_wakeup(struct tty_port *port);
|
|
extern int tty_port_block_til_ready(struct tty_port *port,
|
|
struct tty_struct *tty, struct file *filp);
|
|
extern int tty_port_close_start(struct tty_port *port,
|
|
struct tty_struct *tty, struct file *filp);
|
|
extern void tty_port_close_end(struct tty_port *port, struct tty_struct *tty);
|
|
extern void tty_port_close(struct tty_port *port,
|
|
struct tty_struct *tty, struct file *filp);
|
|
extern int tty_port_install(struct tty_port *port, struct tty_driver *driver,
|
|
struct tty_struct *tty);
|
|
extern int tty_port_open(struct tty_port *port,
|
|
struct tty_struct *tty, struct file *filp);
|
|
static inline int tty_port_users(struct tty_port *port)
|
|
{
|
|
return port->count + port->blocked_open;
|
|
}
|
|
|
|
extern int tty_register_ldisc(int disc, struct tty_ldisc_ops *new_ldisc);
|
|
extern int tty_unregister_ldisc(int disc);
|
|
extern int tty_set_ldisc(struct tty_struct *tty, int disc);
|
|
extern int tty_ldisc_setup(struct tty_struct *tty, struct tty_struct *o_tty);
|
|
extern void tty_ldisc_release(struct tty_struct *tty);
|
|
extern int __must_check tty_ldisc_init(struct tty_struct *tty);
|
|
extern void tty_ldisc_deinit(struct tty_struct *tty);
|
|
extern int tty_ldisc_receive_buf(struct tty_ldisc *ld, const unsigned char *p,
|
|
char *f, int count);
|
|
|
|
/* n_tty.c */
|
|
extern void n_tty_inherit_ops(struct tty_ldisc_ops *ops);
|
|
#ifdef CONFIG_TTY
|
|
extern void __init n_tty_init(void);
|
|
#else
|
|
static inline void n_tty_init(void) { }
|
|
#endif
|
|
|
|
/* tty_audit.c */
|
|
#ifdef CONFIG_AUDIT
|
|
extern void tty_audit_add_data(struct tty_struct *tty, const void *data,
|
|
size_t size);
|
|
extern void tty_audit_exit(void);
|
|
extern void tty_audit_fork(struct signal_struct *sig);
|
|
extern void tty_audit_tiocsti(struct tty_struct *tty, char ch);
|
|
extern int tty_audit_push(void);
|
|
#else
|
|
static inline void tty_audit_add_data(struct tty_struct *tty, const void *data,
|
|
size_t size)
|
|
{
|
|
}
|
|
static inline void tty_audit_tiocsti(struct tty_struct *tty, char ch)
|
|
{
|
|
}
|
|
static inline void tty_audit_exit(void)
|
|
{
|
|
}
|
|
static inline void tty_audit_fork(struct signal_struct *sig)
|
|
{
|
|
}
|
|
static inline int tty_audit_push(void)
|
|
{
|
|
return 0;
|
|
}
|
|
#endif
|
|
|
|
/* tty_ioctl.c */
|
|
extern int n_tty_ioctl_helper(struct tty_struct *tty, struct file *file,
|
|
unsigned int cmd, unsigned long arg);
|
|
extern long n_tty_compat_ioctl_helper(struct tty_struct *tty, struct file *file,
|
|
unsigned int cmd, unsigned long arg);
|
|
|
|
/* vt.c */
|
|
|
|
extern int vt_ioctl(struct tty_struct *tty,
|
|
unsigned int cmd, unsigned long arg);
|
|
|
|
extern long vt_compat_ioctl(struct tty_struct *tty,
|
|
unsigned int cmd, unsigned long arg);
|
|
|
|
/* tty_mutex.c */
|
|
/* functions for preparation of BKL removal */
|
|
extern void tty_lock(struct tty_struct *tty);
|
|
extern int tty_lock_interruptible(struct tty_struct *tty);
|
|
extern void tty_unlock(struct tty_struct *tty);
|
|
extern void tty_lock_slave(struct tty_struct *tty);
|
|
extern void tty_unlock_slave(struct tty_struct *tty);
|
|
extern void tty_set_lock_subclass(struct tty_struct *tty);
|
|
|
|
#ifdef CONFIG_PROC_FS
|
|
extern void proc_tty_register_driver(struct tty_driver *);
|
|
extern void proc_tty_unregister_driver(struct tty_driver *);
|
|
#else
|
|
static inline void proc_tty_register_driver(struct tty_driver *d) {}
|
|
static inline void proc_tty_unregister_driver(struct tty_driver *d) {}
|
|
#endif
|
|
|
|
#define tty_msg(fn, tty, f, ...) \
|
|
fn("%s %s: " f, tty_driver_name(tty), tty_name(tty), ##__VA_ARGS__)
|
|
|
|
#define tty_debug(tty, f, ...) tty_msg(pr_debug, tty, f, ##__VA_ARGS__)
|
|
#define tty_info(tty, f, ...) tty_msg(pr_info, tty, f, ##__VA_ARGS__)
|
|
#define tty_notice(tty, f, ...) tty_msg(pr_notice, tty, f, ##__VA_ARGS__)
|
|
#define tty_warn(tty, f, ...) tty_msg(pr_warn, tty, f, ##__VA_ARGS__)
|
|
#define tty_err(tty, f, ...) tty_msg(pr_err, tty, f, ##__VA_ARGS__)
|
|
|
|
#define tty_info_ratelimited(tty, f, ...) \
|
|
tty_msg(pr_info_ratelimited, tty, f, ##__VA_ARGS__)
|
|
|
|
#endif
|