/* * VMware vSockets Driver * * Copyright (C) 2009-2013 VMware, Inc. All rights reserved. * * 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 version 2 and no later version. * * This program is distributed in the hope that it will be useful, but WITHOUT * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for * more details. */ #ifndef __VMCI_TRANSPORT_NOTIFY_H__ #define __VMCI_TRANSPORT_NOTIFY_H__ #include #include #include #include #include "vmci_transport.h" /* Comment this out to compare with old protocol. */ #define VSOCK_OPTIMIZATION_WAITING_NOTIFY 1 #if defined(VSOCK_OPTIMIZATION_WAITING_NOTIFY) /* Comment this out to remove flow control for "new" protocol */ #define VSOCK_OPTIMIZATION_FLOW_CONTROL 1 #endif #define VMCI_TRANSPORT_MAX_DGRAM_RESENDS 10 struct vmci_transport_recv_notify_data { u64 consume_head; u64 produce_tail; bool notify_on_block; }; struct vmci_transport_send_notify_data { u64 consume_head; u64 produce_tail; }; /* Socket notification callbacks. */ struct vmci_transport_notify_ops { void (*socket_init) (struct sock *sk); void (*socket_destruct) (struct vsock_sock *vsk); int (*poll_in) (struct sock *sk, size_t target, bool *data_ready_now); int (*poll_out) (struct sock *sk, size_t target, bool *space_avail_now); void (*handle_notify_pkt) (struct sock *sk, struct vmci_transport_packet *pkt, bool bottom_half, struct sockaddr_vm *dst, struct sockaddr_vm *src, bool *pkt_processed); int (*recv_init) (struct sock *sk, size_t target, struct vmci_transport_recv_notify_data *data); int (*recv_pre_block) (struct sock *sk, size_t target, struct vmci_transport_recv_notify_data *data); int (*recv_pre_dequeue) (struct sock *sk, size_t target, struct vmci_transport_recv_notify_data *data); int (*recv_post_dequeue) (struct sock *sk, size_t target, ssize_t copied, bool data_read, struct vmci_transport_recv_notify_data *data); int (*send_init) (struct sock *sk, struct vmci_transport_send_notify_data *data); int (*send_pre_block) (struct sock *sk, struct vmci_transport_send_notify_data *data); int (*send_pre_enqueue) (struct sock *sk, struct vmci_transport_send_notify_data *data); int (*send_post_enqueue) (struct sock *sk, ssize_t written, struct vmci_transport_send_notify_data *data); void (*process_request) (struct sock *sk); void (*process_negotiate) (struct sock *sk); }; extern const struct vmci_transport_notify_ops vmci_transport_notify_pkt_ops; extern const struct vmci_transport_notify_ops vmci_transport_notify_pkt_q_state_ops; #endif /* __VMCI_TRANSPORT_NOTIFY_H__ */ .cgi/linux/net-next.git/commit/net?h=nds-private-remove&id=23fbe2cdc1de80120cf9ccd478ac57c3a3a0764b'>net/ceph/auth.c
diff options
context:
space:
mode:
authorLinus Torvalds <torvalds@linux-foundation.org>2017-02-08 09:56:15 -0800
committerLinus Torvalds <torvalds@linux-foundation.org>2017-02-08 09:56:15 -0800
commit23fbe2cdc1de80120cf9ccd478ac57c3a3a0764b (patch)
tree4aff32d5f2f6fe2f54028bfd4d1b66fdd2f8d281 /net/ceph/auth.c
parent926af6273fc683cd98cd0ce7bf0d04a02eed6742 (diff)
parenteeeefd41843218c55a8782a6920f044d9bf6207a (diff)
Merge branch 'for-linus' of git://git.kernel.dk/linux-block
Pull block fix from Jens Axboe: "A single fix that should go into 4.10, fixing a regression on some devices with the WRITE_SAME command" * 'for-linus' of git://git.kernel.dk/linux-block: block: don't try Write Same from __blkdev_issue_zeroout
Diffstat (limited to 'net/ceph/auth.c')