Import of kernel-5.14.0-570.28.1.el9_6
This commit is contained in:
parent
bbc13f3f35
commit
d63051341b
@ -12,7 +12,7 @@ RHEL_MINOR = 6
|
||||
#
|
||||
# Use this spot to avoid future merge conflicts.
|
||||
# Do not trim this comment.
|
||||
RHEL_RELEASE = 570.26.1
|
||||
RHEL_RELEASE = 570.28.1
|
||||
|
||||
#
|
||||
# ZSTREAM
|
||||
|
@ -1397,6 +1397,11 @@ static int tegra_i2c_xfer(struct i2c_adapter *adap, struct i2c_msg msgs[],
|
||||
ret = tegra_i2c_xfer_msg(i2c_dev, &msgs[i], MSG_END_CONTINUE);
|
||||
if (ret)
|
||||
break;
|
||||
|
||||
/* Validate message length before proceeding */
|
||||
if (msgs[i].buf[0] == 0 || msgs[i].buf[0] > I2C_SMBUS_BLOCK_MAX)
|
||||
break;
|
||||
|
||||
/* Set the msg length from first byte */
|
||||
msgs[i].len += msgs[i].buf[0];
|
||||
dev_dbg(i2c_dev->dev, "reading %d bytes\n", msgs[i].len);
|
||||
|
@ -1579,6 +1579,40 @@ static void uvc_ctrl_send_slave_event(struct uvc_video_chain *chain,
|
||||
uvc_ctrl_send_event(chain, handle, ctrl, mapping, val, changes);
|
||||
}
|
||||
|
||||
static void uvc_ctrl_set_handle(struct uvc_fh *handle, struct uvc_control *ctrl,
|
||||
struct uvc_fh *new_handle)
|
||||
{
|
||||
lockdep_assert_held(&handle->chain->ctrl_mutex);
|
||||
|
||||
if (new_handle) {
|
||||
if (ctrl->handle)
|
||||
dev_warn_ratelimited(&handle->stream->dev->udev->dev,
|
||||
"UVC non compliance: Setting an async control with a pending operation.");
|
||||
|
||||
if (new_handle == ctrl->handle)
|
||||
return;
|
||||
|
||||
if (ctrl->handle) {
|
||||
WARN_ON(!ctrl->handle->pending_async_ctrls);
|
||||
if (ctrl->handle->pending_async_ctrls)
|
||||
ctrl->handle->pending_async_ctrls--;
|
||||
}
|
||||
|
||||
ctrl->handle = new_handle;
|
||||
handle->pending_async_ctrls++;
|
||||
return;
|
||||
}
|
||||
|
||||
/* Cannot clear the handle for a control not owned by us.*/
|
||||
if (WARN_ON(ctrl->handle != handle))
|
||||
return;
|
||||
|
||||
ctrl->handle = NULL;
|
||||
if (WARN_ON(!handle->pending_async_ctrls))
|
||||
return;
|
||||
handle->pending_async_ctrls--;
|
||||
}
|
||||
|
||||
void uvc_ctrl_status_event(struct uvc_video_chain *chain,
|
||||
struct uvc_control *ctrl, const u8 *data)
|
||||
{
|
||||
@ -1588,8 +1622,12 @@ void uvc_ctrl_status_event(struct uvc_video_chain *chain,
|
||||
|
||||
mutex_lock(&chain->ctrl_mutex);
|
||||
|
||||
/* Flush the control cache, the data might have changed. */
|
||||
ctrl->loaded = 0;
|
||||
|
||||
handle = ctrl->handle;
|
||||
ctrl->handle = NULL;
|
||||
if (handle)
|
||||
uvc_ctrl_set_handle(handle, ctrl, NULL);
|
||||
|
||||
list_for_each_entry(mapping, &ctrl->info.mappings, list) {
|
||||
s32 value = __uvc_ctrl_get_value(mapping, data);
|
||||
@ -1640,10 +1678,8 @@ bool uvc_ctrl_status_event_async(struct urb *urb, struct uvc_video_chain *chain,
|
||||
struct uvc_device *dev = chain->dev;
|
||||
struct uvc_ctrl_work *w = &dev->async_ctrl;
|
||||
|
||||
if (list_empty(&ctrl->info.mappings)) {
|
||||
ctrl->handle = NULL;
|
||||
if (list_empty(&ctrl->info.mappings))
|
||||
return false;
|
||||
}
|
||||
|
||||
w->data = data;
|
||||
w->urb = urb;
|
||||
@ -1811,7 +1847,10 @@ int uvc_ctrl_begin(struct uvc_video_chain *chain)
|
||||
}
|
||||
|
||||
static int uvc_ctrl_commit_entity(struct uvc_device *dev,
|
||||
struct uvc_entity *entity, int rollback, struct uvc_control **err_ctrl)
|
||||
struct uvc_fh *handle,
|
||||
struct uvc_entity *entity,
|
||||
int rollback,
|
||||
struct uvc_control **err_ctrl)
|
||||
{
|
||||
struct uvc_control *ctrl;
|
||||
unsigned int i;
|
||||
@ -1859,6 +1898,10 @@ static int uvc_ctrl_commit_entity(struct uvc_device *dev,
|
||||
*err_ctrl = ctrl;
|
||||
return ret;
|
||||
}
|
||||
|
||||
if (!rollback && handle &&
|
||||
ctrl->info.flags & UVC_CTRL_FLAG_ASYNCHRONOUS)
|
||||
uvc_ctrl_set_handle(handle, ctrl, handle);
|
||||
}
|
||||
|
||||
return 0;
|
||||
@ -1895,8 +1938,8 @@ int __uvc_ctrl_commit(struct uvc_fh *handle, int rollback,
|
||||
|
||||
/* Find the control. */
|
||||
list_for_each_entry(entity, &chain->entities, chain) {
|
||||
ret = uvc_ctrl_commit_entity(chain->dev, entity, rollback,
|
||||
&err_ctrl);
|
||||
ret = uvc_ctrl_commit_entity(chain->dev, handle, entity,
|
||||
rollback, &err_ctrl);
|
||||
if (ret < 0) {
|
||||
if (ctrls)
|
||||
ctrls->error_idx =
|
||||
@ -1941,6 +1984,8 @@ int uvc_ctrl_set(struct uvc_fh *handle,
|
||||
s32 max;
|
||||
int ret;
|
||||
|
||||
lockdep_assert_held(&chain->ctrl_mutex);
|
||||
|
||||
if (__uvc_query_v4l2_class(chain, xctrl->id, 0) >= 0)
|
||||
return -EACCES;
|
||||
|
||||
@ -2046,9 +2091,6 @@ int uvc_ctrl_set(struct uvc_fh *handle,
|
||||
mapping->set(mapping, value,
|
||||
uvc_ctrl_data(ctrl, UVC_CTRL_DATA_CURRENT));
|
||||
|
||||
if (ctrl->info.flags & UVC_CTRL_FLAG_ASYNCHRONOUS)
|
||||
ctrl->handle = handle;
|
||||
|
||||
ctrl->dirty = 1;
|
||||
ctrl->modified = 1;
|
||||
return 0;
|
||||
@ -2377,7 +2419,7 @@ int uvc_ctrl_restore_values(struct uvc_device *dev)
|
||||
ctrl->dirty = 1;
|
||||
}
|
||||
|
||||
ret = uvc_ctrl_commit_entity(dev, entity, 0, NULL);
|
||||
ret = uvc_ctrl_commit_entity(dev, NULL, entity, 0, NULL);
|
||||
if (ret < 0)
|
||||
return ret;
|
||||
}
|
||||
@ -2770,6 +2812,26 @@ int uvc_ctrl_init_device(struct uvc_device *dev)
|
||||
return 0;
|
||||
}
|
||||
|
||||
void uvc_ctrl_cleanup_fh(struct uvc_fh *handle)
|
||||
{
|
||||
struct uvc_entity *entity;
|
||||
|
||||
guard(mutex)(&handle->chain->ctrl_mutex);
|
||||
|
||||
if (!handle->pending_async_ctrls)
|
||||
return;
|
||||
|
||||
list_for_each_entry(entity, &handle->chain->dev->entities, list) {
|
||||
for (unsigned int i = 0; i < entity->ncontrols; ++i) {
|
||||
if (entity->controls[i].handle != handle)
|
||||
continue;
|
||||
uvc_ctrl_set_handle(handle, &entity->controls[i], NULL);
|
||||
}
|
||||
}
|
||||
|
||||
WARN_ON(handle->pending_async_ctrls);
|
||||
}
|
||||
|
||||
/*
|
||||
* Cleanup device controls.
|
||||
*/
|
||||
|
@ -32,7 +32,7 @@
|
||||
|
||||
unsigned int uvc_clock_param = CLOCK_MONOTONIC;
|
||||
unsigned int uvc_hw_timestamps_param;
|
||||
unsigned int uvc_no_drop_param;
|
||||
unsigned int uvc_no_drop_param = 1;
|
||||
static unsigned int uvc_quirks_param = -1;
|
||||
unsigned int uvc_dbg_param;
|
||||
unsigned int uvc_timeout_param = UVC_CTRL_STREAMING_TIMEOUT;
|
||||
@ -1949,7 +1949,7 @@ int uvc_register_video_device(struct uvc_device *dev,
|
||||
int ret;
|
||||
|
||||
/* Initialize the video buffers queue. */
|
||||
ret = uvc_queue_init(queue, type, !uvc_no_drop_param);
|
||||
ret = uvc_queue_init(queue, type);
|
||||
if (ret)
|
||||
return ret;
|
||||
|
||||
@ -2387,8 +2387,25 @@ module_param_call(clock, uvc_clock_param_set, uvc_clock_param_get,
|
||||
MODULE_PARM_DESC(clock, "Video buffers timestamp clock");
|
||||
module_param_named(hwtimestamps, uvc_hw_timestamps_param, uint, 0644);
|
||||
MODULE_PARM_DESC(hwtimestamps, "Use hardware timestamps");
|
||||
module_param_named(nodrop, uvc_no_drop_param, uint, 0644);
|
||||
|
||||
static int param_set_nodrop(const char *val, const struct kernel_param *kp)
|
||||
{
|
||||
pr_warn_once("uvcvideo: "
|
||||
DEPRECATED
|
||||
"nodrop parameter will be eventually removed.\n");
|
||||
return param_set_bool(val, kp);
|
||||
}
|
||||
|
||||
static const struct kernel_param_ops param_ops_nodrop = {
|
||||
.set = param_set_nodrop,
|
||||
.get = param_get_uint,
|
||||
};
|
||||
|
||||
param_check_uint(nodrop, &uvc_no_drop_param);
|
||||
module_param_cb(nodrop, ¶m_ops_nodrop, &uvc_no_drop_param, 0644);
|
||||
__MODULE_PARM_TYPE(nodrop, "uint");
|
||||
MODULE_PARM_DESC(nodrop, "Don't drop incomplete frames");
|
||||
|
||||
module_param_named(quirks, uvc_quirks_param, uint, 0644);
|
||||
MODULE_PARM_DESC(quirks, "Forced device quirks");
|
||||
module_param_named(trace, uvc_dbg_param, uint, 0644);
|
||||
|
@ -212,8 +212,7 @@ static const struct vb2_ops uvc_meta_queue_qops = {
|
||||
.stop_streaming = uvc_stop_streaming,
|
||||
};
|
||||
|
||||
int uvc_queue_init(struct uvc_video_queue *queue, enum v4l2_buf_type type,
|
||||
int drop_corrupted)
|
||||
int uvc_queue_init(struct uvc_video_queue *queue, enum v4l2_buf_type type)
|
||||
{
|
||||
int ret;
|
||||
|
||||
@ -243,7 +242,6 @@ int uvc_queue_init(struct uvc_video_queue *queue, enum v4l2_buf_type type,
|
||||
mutex_init(&queue->mutex);
|
||||
spin_lock_init(&queue->irqlock);
|
||||
INIT_LIST_HEAD(&queue->irqqueue);
|
||||
queue->flags = drop_corrupted ? UVC_QUEUE_DROP_CORRUPTED : 0;
|
||||
|
||||
return 0;
|
||||
}
|
||||
@ -476,14 +474,15 @@ static void uvc_queue_buffer_complete(struct kref *ref)
|
||||
struct vb2_buffer *vb = &buf->buf.vb2_buf;
|
||||
struct uvc_video_queue *queue = vb2_get_drv_priv(vb->vb2_queue);
|
||||
|
||||
if ((queue->flags & UVC_QUEUE_DROP_CORRUPTED) && buf->error) {
|
||||
if (buf->error && !uvc_no_drop_param) {
|
||||
uvc_queue_buffer_requeue(queue, buf);
|
||||
return;
|
||||
}
|
||||
|
||||
buf->state = buf->error ? UVC_BUF_STATE_ERROR : UVC_BUF_STATE_DONE;
|
||||
vb2_set_plane_payload(&buf->buf.vb2_buf, 0, buf->bytesused);
|
||||
vb2_buffer_done(&buf->buf.vb2_buf, VB2_BUF_STATE_DONE);
|
||||
vb2_buffer_done(&buf->buf.vb2_buf, buf->error ? VB2_BUF_STATE_ERROR :
|
||||
VB2_BUF_STATE_DONE);
|
||||
}
|
||||
|
||||
/*
|
||||
|
@ -659,6 +659,8 @@ static int uvc_v4l2_release(struct file *file)
|
||||
|
||||
uvc_dbg(stream->dev, CALLS, "%s\n", __func__);
|
||||
|
||||
uvc_ctrl_cleanup_fh(handle);
|
||||
|
||||
/* Only free resources if this is a privileged handle. */
|
||||
if (uvc_has_privileges(handle))
|
||||
uvc_queue_release(&stream->queue);
|
||||
|
@ -316,7 +316,6 @@ struct uvc_buffer {
|
||||
};
|
||||
|
||||
#define UVC_QUEUE_DISCONNECTED (1 << 0)
|
||||
#define UVC_QUEUE_DROP_CORRUPTED (1 << 1)
|
||||
|
||||
struct uvc_video_queue {
|
||||
struct vb2_queue queue;
|
||||
@ -337,7 +336,11 @@ struct uvc_video_chain {
|
||||
struct uvc_entity *processing; /* Processing unit */
|
||||
struct uvc_entity *selector; /* Selector unit */
|
||||
|
||||
struct mutex ctrl_mutex; /* Protects ctrl.info */
|
||||
struct mutex ctrl_mutex; /*
|
||||
* Protects ctrl.info,
|
||||
* ctrl.handle and
|
||||
* uvc_fh.pending_async_ctrls
|
||||
*/
|
||||
|
||||
struct v4l2_prio_state prio; /* V4L2 priority state */
|
||||
u32 caps; /* V4L2 chain-wide caps */
|
||||
@ -612,6 +615,7 @@ struct uvc_fh {
|
||||
struct uvc_video_chain *chain;
|
||||
struct uvc_streaming *stream;
|
||||
enum uvc_handle_state state;
|
||||
unsigned int pending_async_ctrls;
|
||||
};
|
||||
|
||||
struct uvc_driver {
|
||||
@ -674,8 +678,7 @@ extern struct uvc_driver uvc_driver;
|
||||
struct uvc_entity *uvc_entity_by_id(struct uvc_device *dev, int id);
|
||||
|
||||
/* Video buffers queue management. */
|
||||
int uvc_queue_init(struct uvc_video_queue *queue, enum v4l2_buf_type type,
|
||||
int drop_corrupted);
|
||||
int uvc_queue_init(struct uvc_video_queue *queue, enum v4l2_buf_type type);
|
||||
void uvc_queue_release(struct uvc_video_queue *queue);
|
||||
int uvc_request_buffers(struct uvc_video_queue *queue,
|
||||
struct v4l2_requestbuffers *rb);
|
||||
@ -795,6 +798,8 @@ int uvc_ctrl_is_accessible(struct uvc_video_chain *chain, u32 v4l2_id,
|
||||
int uvc_xu_ctrl_query(struct uvc_video_chain *chain,
|
||||
struct uvc_xu_control_query *xqry);
|
||||
|
||||
void uvc_ctrl_cleanup_fh(struct uvc_fh *handle);
|
||||
|
||||
/* Utility functions */
|
||||
struct usb_host_endpoint *uvc_find_endpoint(struct usb_host_interface *alts,
|
||||
u8 epaddr);
|
||||
|
@ -326,7 +326,7 @@ static int mlx5e_ptp_alloc_txqsq(struct mlx5e_ptp *c, int txq_ix,
|
||||
int node;
|
||||
|
||||
sq->pdev = c->pdev;
|
||||
sq->clock = &mdev->clock;
|
||||
sq->clock = mdev->clock;
|
||||
sq->mkey_be = c->mkey_be;
|
||||
sq->netdev = c->netdev;
|
||||
sq->priv = c->priv;
|
||||
@ -696,7 +696,7 @@ static int mlx5e_init_ptp_rq(struct mlx5e_ptp *c, struct mlx5e_params *params,
|
||||
rq->pdev = c->pdev;
|
||||
rq->netdev = priv->netdev;
|
||||
rq->priv = priv;
|
||||
rq->clock = &mdev->clock;
|
||||
rq->clock = mdev->clock;
|
||||
rq->tstamp = &priv->tstamp;
|
||||
rq->mdev = mdev;
|
||||
rq->hw_mtu = MLX5E_SW2HW_MTU(params, params->sw_mtu);
|
||||
|
@ -46,7 +46,7 @@ static void mlx5e_init_trap_rq(struct mlx5e_trap *t, struct mlx5e_params *params
|
||||
rq->pdev = t->pdev;
|
||||
rq->netdev = priv->netdev;
|
||||
rq->priv = priv;
|
||||
rq->clock = &mdev->clock;
|
||||
rq->clock = mdev->clock;
|
||||
rq->tstamp = &priv->tstamp;
|
||||
rq->mdev = mdev;
|
||||
rq->hw_mtu = MLX5E_SW2HW_MTU(params, params->sw_mtu);
|
||||
|
@ -231,9 +231,9 @@ static u64 mlx5e_xsk_fill_timestamp(void *_priv)
|
||||
ts = get_cqe_ts(priv->cqe);
|
||||
|
||||
if (mlx5_is_real_time_rq(priv->cq->mdev) || mlx5_is_real_time_sq(priv->cq->mdev))
|
||||
return mlx5_real_time_cyc2time(&priv->cq->mdev->clock, ts);
|
||||
return mlx5_real_time_cyc2time(priv->cq->mdev->clock, ts);
|
||||
|
||||
return mlx5_timecounter_cyc2time(&priv->cq->mdev->clock, ts);
|
||||
return mlx5_timecounter_cyc2time(priv->cq->mdev->clock, ts);
|
||||
}
|
||||
|
||||
static void mlx5e_xsk_request_checksum(u16 csum_start, u16 csum_offset, void *priv)
|
||||
|
@ -72,7 +72,7 @@ static int mlx5e_init_xsk_rq(struct mlx5e_channel *c,
|
||||
rq->netdev = c->netdev;
|
||||
rq->priv = c->priv;
|
||||
rq->tstamp = c->tstamp;
|
||||
rq->clock = &mdev->clock;
|
||||
rq->clock = mdev->clock;
|
||||
rq->icosq = &c->icosq;
|
||||
rq->ix = c->ix;
|
||||
rq->channel = c;
|
||||
|
@ -742,7 +742,7 @@ static int mlx5e_init_rxq_rq(struct mlx5e_channel *c, struct mlx5e_params *param
|
||||
rq->netdev = c->netdev;
|
||||
rq->priv = c->priv;
|
||||
rq->tstamp = c->tstamp;
|
||||
rq->clock = &mdev->clock;
|
||||
rq->clock = mdev->clock;
|
||||
rq->icosq = &c->icosq;
|
||||
rq->ix = c->ix;
|
||||
rq->channel = c;
|
||||
@ -1621,7 +1621,7 @@ static int mlx5e_alloc_txqsq(struct mlx5e_channel *c,
|
||||
int err;
|
||||
|
||||
sq->pdev = c->pdev;
|
||||
sq->clock = &mdev->clock;
|
||||
sq->clock = mdev->clock;
|
||||
sq->mkey_be = c->mkey_be;
|
||||
sq->netdev = c->netdev;
|
||||
sq->mdev = c->mdev;
|
||||
|
File diff suppressed because it is too large
Load Diff
@ -33,6 +33,38 @@
|
||||
#ifndef __LIB_CLOCK_H__
|
||||
#define __LIB_CLOCK_H__
|
||||
|
||||
#include <linux/ptp_clock_kernel.h>
|
||||
|
||||
/* KABI checker sees the old definitions in include/linux/mlx5/driver.h */
|
||||
#ifndef __GENKSYMS__
|
||||
#define MAX_PIN_NUM 8
|
||||
struct mlx5_pps {
|
||||
u8 pin_caps[MAX_PIN_NUM];
|
||||
u64 start[MAX_PIN_NUM];
|
||||
u8 enabled;
|
||||
u64 min_npps_period;
|
||||
u64 min_out_pulse_duration_ns;
|
||||
bool pin_armed[MAX_PIN_NUM];
|
||||
};
|
||||
|
||||
struct mlx5_timer {
|
||||
struct cyclecounter cycles;
|
||||
struct timecounter tc;
|
||||
u32 nominal_c_mult;
|
||||
unsigned long overflow_period;
|
||||
};
|
||||
|
||||
struct mlx5_clock {
|
||||
seqlock_t lock;
|
||||
struct hwtstamp_config hwtstamp_config;
|
||||
struct ptp_clock *ptp;
|
||||
struct ptp_clock_info ptp_info;
|
||||
struct mlx5_pps pps_info;
|
||||
struct mlx5_timer timer;
|
||||
bool shared;
|
||||
};
|
||||
#endif
|
||||
|
||||
static inline bool mlx5_is_real_time_rq(struct mlx5_core_dev *mdev)
|
||||
{
|
||||
u8 rq_ts_format_cap = MLX5_CAP_GEN(mdev, rq_ts_format);
|
||||
@ -54,12 +86,14 @@ static inline bool mlx5_is_real_time_sq(struct mlx5_core_dev *mdev)
|
||||
typedef ktime_t (*cqe_ts_to_ns)(struct mlx5_clock *, u64);
|
||||
|
||||
#if IS_ENABLED(CONFIG_PTP_1588_CLOCK)
|
||||
void mlx5_init_clock(struct mlx5_core_dev *mdev);
|
||||
int mlx5_init_clock(struct mlx5_core_dev *mdev);
|
||||
void mlx5_cleanup_clock(struct mlx5_core_dev *mdev);
|
||||
void mlx5_clock_load(struct mlx5_core_dev *mdev);
|
||||
void mlx5_clock_unload(struct mlx5_core_dev *mdev);
|
||||
|
||||
static inline int mlx5_clock_get_ptp_index(struct mlx5_core_dev *mdev)
|
||||
{
|
||||
return mdev->clock.ptp ? ptp_clock_index(mdev->clock.ptp) : -1;
|
||||
return mdev->clock->ptp ? ptp_clock_index(mdev->clock->ptp) : -1;
|
||||
}
|
||||
|
||||
static inline ktime_t mlx5_timecounter_cyc2time(struct mlx5_clock *clock,
|
||||
@ -87,8 +121,10 @@ static inline ktime_t mlx5_real_time_cyc2time(struct mlx5_clock *clock,
|
||||
return ns_to_ktime(time);
|
||||
}
|
||||
#else
|
||||
static inline void mlx5_init_clock(struct mlx5_core_dev *mdev) {}
|
||||
static inline int mlx5_init_clock(struct mlx5_core_dev *mdev) { return 0; }
|
||||
static inline void mlx5_cleanup_clock(struct mlx5_core_dev *mdev) {}
|
||||
static inline void mlx5_clock_load(struct mlx5_core_dev *mdev) {}
|
||||
static inline void mlx5_clock_unload(struct mlx5_core_dev *mdev) {}
|
||||
static inline int mlx5_clock_get_ptp_index(struct mlx5_core_dev *mdev)
|
||||
{
|
||||
return -1;
|
||||
|
@ -11,6 +11,7 @@ enum mlx5_devcom_component {
|
||||
MLX5_DEVCOM_MPV,
|
||||
MLX5_DEVCOM_HCA_PORTS,
|
||||
MLX5_DEVCOM_SD_GROUP,
|
||||
MLX5_DEVCOM_SHARED_CLOCK,
|
||||
MLX5_DEVCOM_NUM_COMPONENTS,
|
||||
};
|
||||
|
||||
|
@ -1032,7 +1032,11 @@ static int mlx5_init_once(struct mlx5_core_dev *dev)
|
||||
|
||||
mlx5_init_reserved_gids(dev);
|
||||
|
||||
mlx5_init_clock(dev);
|
||||
err = mlx5_init_clock(dev);
|
||||
if (err) {
|
||||
mlx5_core_err(dev, "failed to initialize hardware clock\n");
|
||||
goto err_tables_cleanup;
|
||||
}
|
||||
|
||||
dev->vxlan = mlx5_vxlan_create(dev);
|
||||
dev->geneve = mlx5_geneve_create(dev);
|
||||
@ -1040,7 +1044,7 @@ static int mlx5_init_once(struct mlx5_core_dev *dev)
|
||||
err = mlx5_init_rl_table(dev);
|
||||
if (err) {
|
||||
mlx5_core_err(dev, "Failed to init rate limiting\n");
|
||||
goto err_tables_cleanup;
|
||||
goto err_clock_cleanup;
|
||||
}
|
||||
|
||||
err = mlx5_mpfs_init(dev);
|
||||
@ -1117,10 +1121,11 @@ err_mpfs_cleanup:
|
||||
mlx5_mpfs_cleanup(dev);
|
||||
err_rl_cleanup:
|
||||
mlx5_cleanup_rl_table(dev);
|
||||
err_tables_cleanup:
|
||||
err_clock_cleanup:
|
||||
mlx5_geneve_destroy(dev->geneve);
|
||||
mlx5_vxlan_destroy(dev->vxlan);
|
||||
mlx5_cleanup_clock(dev);
|
||||
err_tables_cleanup:
|
||||
mlx5_cleanup_reserved_gids(dev);
|
||||
mlx5_cq_debugfs_cleanup(dev);
|
||||
mlx5_fw_reset_cleanup(dev);
|
||||
@ -1353,6 +1358,8 @@ static int mlx5_load(struct mlx5_core_dev *dev)
|
||||
goto err_eq_table;
|
||||
}
|
||||
|
||||
mlx5_clock_load(dev);
|
||||
|
||||
err = mlx5_fw_tracer_init(dev->tracer);
|
||||
if (err) {
|
||||
mlx5_core_err(dev, "Failed to init FW tracer %d\n", err);
|
||||
@ -1436,6 +1443,7 @@ err_fpga_start:
|
||||
mlx5_hv_vhca_cleanup(dev->hv_vhca);
|
||||
mlx5_fw_reset_events_stop(dev);
|
||||
mlx5_fw_tracer_cleanup(dev->tracer);
|
||||
mlx5_clock_unload(dev);
|
||||
mlx5_eq_table_destroy(dev);
|
||||
err_eq_table:
|
||||
mlx5_irq_table_destroy(dev);
|
||||
@ -1462,6 +1470,7 @@ static void mlx5_unload(struct mlx5_core_dev *dev)
|
||||
mlx5_hv_vhca_cleanup(dev->hv_vhca);
|
||||
mlx5_fw_reset_events_stop(dev);
|
||||
mlx5_fw_tracer_cleanup(dev->tracer);
|
||||
mlx5_clock_unload(dev);
|
||||
mlx5_eq_table_destroy(dev);
|
||||
mlx5_irq_table_destroy(dev);
|
||||
mlx5_pagealloc_stop(dev);
|
||||
|
@ -161,6 +161,7 @@ enum {
|
||||
MLX5_REG_MIRC = 0x9162,
|
||||
MLX5_REG_MTPTM = 0x9180,
|
||||
MLX5_REG_MTCTR = 0x9181,
|
||||
MLX5_REG_MRTCQ = 0x9182,
|
||||
MLX5_REG_SBCAM = 0xB01F,
|
||||
MLX5_REG_RESOURCE_DUMP = 0xC000,
|
||||
MLX5_REG_DTOR = 0xC00E,
|
||||
@ -706,17 +707,38 @@ struct mlx5_rsvd_gids {
|
||||
struct ida ida;
|
||||
};
|
||||
|
||||
#define MAX_PIN_NUM 8
|
||||
struct mlx5_pps {
|
||||
u8 pin_caps[MAX_PIN_NUM];
|
||||
/* RHEL 9.6 GA had an embedded struct mlx5_clock in struct mlx5_core_dev.
|
||||
* For PTP clock support with BF-3 (RHEL-87775), it needs to change to
|
||||
* a pointer. However, changes to struct mlx5_core_dev break KABI symbols:
|
||||
* mlx5_blocking_notifier_register
|
||||
* mlx5_blocking_notifier_unregister
|
||||
* mlx5_core_access_reg
|
||||
* mlx5_core_uplink_netdev_event_replay
|
||||
*
|
||||
* We assume that:
|
||||
* - The functions are exported to serve the in-tree drivers (mlx5_ib,
|
||||
* mlx5_dpll).
|
||||
* - Mixing the in-tree mlx5_core with an external mlx5_* aux binary
|
||||
* driver is unlikely.
|
||||
* - Even if the mixing occurs, the external driver is unlikely to touch
|
||||
* the "clock" member anyway.
|
||||
*
|
||||
* To preserve the maximum of the KABI, we keep a dummy struct mlx5_clock where
|
||||
* it was originally. To any external module accessing it, it will appear as if
|
||||
* mlx5_init_clock() had aborted the HW clock init and left the struct cleared.
|
||||
* To make this work, we keep the original struct layout definitions here.
|
||||
*/
|
||||
#define RHEL96_KABI_MAX_PIN_NUM 8
|
||||
struct RH_KABI_RENAME(mlx5_pps, rhel96_kabi_mlx5_pps) {
|
||||
u8 pin_caps[RHEL96_KABI_MAX_PIN_NUM];
|
||||
struct work_struct out_work;
|
||||
u64 start[MAX_PIN_NUM];
|
||||
u64 start[RHEL96_KABI_MAX_PIN_NUM];
|
||||
u8 enabled;
|
||||
u64 min_npps_period;
|
||||
u64 min_out_pulse_duration_ns;
|
||||
};
|
||||
|
||||
struct mlx5_timer {
|
||||
struct RH_KABI_RENAME(mlx5_timer, rhel96_kabi_mlx5_timer) {
|
||||
struct cyclecounter cycles;
|
||||
struct timecounter tc;
|
||||
u32 nominal_c_mult;
|
||||
@ -724,16 +746,18 @@ struct mlx5_timer {
|
||||
struct delayed_work overflow_work;
|
||||
};
|
||||
|
||||
struct mlx5_clock {
|
||||
struct RH_KABI_RENAME(mlx5_clock, rhel96_kabi_mlx5_clock) {
|
||||
struct mlx5_nb pps_nb;
|
||||
seqlock_t lock;
|
||||
struct hwtstamp_config hwtstamp_config;
|
||||
struct ptp_clock *ptp;
|
||||
struct ptp_clock_info ptp_info;
|
||||
struct mlx5_pps pps_info;
|
||||
struct mlx5_timer timer;
|
||||
struct RH_KABI_RENAME(mlx5_pps, rhel96_kabi_mlx5_pps) pps_info;
|
||||
struct RH_KABI_RENAME(mlx5_timer, rhel96_kabi_mlx5_timer) timer;
|
||||
};
|
||||
|
||||
struct mlx5_clock;
|
||||
struct mlx5_clock_dev_state;
|
||||
struct mlx5_dm;
|
||||
struct mlx5_fw_tracer;
|
||||
struct mlx5_vxlan;
|
||||
@ -818,7 +842,8 @@ struct mlx5_core_dev {
|
||||
#ifdef CONFIG_MLX5_FPGA
|
||||
struct mlx5_fpga_device *fpga;
|
||||
#endif
|
||||
struct mlx5_clock clock;
|
||||
struct RH_KABI_RENAME(mlx5_clock, rhel96_kabi_mlx5_clock)
|
||||
RH_KABI_RENAME(clock, rhel96_kabi_dummy_clock);
|
||||
struct mlx5_ib_clock_info *clock_info;
|
||||
struct mlx5_fw_tracer *tracer;
|
||||
struct mlx5_rsc_dump *rsc_dump;
|
||||
@ -837,6 +862,8 @@ struct mlx5_core_dev {
|
||||
enum mlx5_wc_state wc_state;
|
||||
/* sync write combining state */
|
||||
struct mutex wc_state_lock;
|
||||
RH_KABI_EXTEND(struct mlx5_clock *clock)
|
||||
RH_KABI_EXTEND(struct mlx5_clock_dev_state *clock_state)
|
||||
};
|
||||
|
||||
struct mlx5_db {
|
||||
|
@ -10626,7 +10626,8 @@ struct mlx5_ifc_mcam_access_reg_bits3 {
|
||||
|
||||
u8 regs_63_to_32[0x20];
|
||||
|
||||
u8 regs_31_to_2[0x1e];
|
||||
u8 regs_31_to_3[0x1d];
|
||||
u8 mrtcq[0x1];
|
||||
u8 mtctr[0x1];
|
||||
u8 mtptm[0x1];
|
||||
};
|
||||
@ -13117,4 +13118,12 @@ struct mlx5_ifc_msees_reg_bits {
|
||||
u8 reserved_at_80[0x180];
|
||||
};
|
||||
|
||||
struct mlx5_ifc_mrtcq_reg_bits {
|
||||
u8 reserved_at_0[0x40];
|
||||
|
||||
u8 rt_clock_identity[0x40];
|
||||
|
||||
u8 reserved_at_80[0x180];
|
||||
};
|
||||
|
||||
#endif /* MLX5_IFC_H */
|
||||
|
@ -1370,7 +1370,8 @@ svc_process_common(struct svc_rqst *rqstp)
|
||||
case SVC_OK:
|
||||
break;
|
||||
case SVC_GARBAGE:
|
||||
goto err_garbage_args;
|
||||
rqstp->rq_auth_stat = rpc_autherr_badcred;
|
||||
goto err_bad_auth;
|
||||
case SVC_SYSERR:
|
||||
goto err_system_err;
|
||||
case SVC_DENIED:
|
||||
@ -1511,14 +1512,6 @@ err_bad_proc:
|
||||
*rqstp->rq_accept_statp = rpc_proc_unavail;
|
||||
goto sendit;
|
||||
|
||||
err_garbage_args:
|
||||
svc_printk(rqstp, "failed to decode RPC header\n");
|
||||
|
||||
if (serv->sv_stats)
|
||||
serv->sv_stats->rpcbadfmt++;
|
||||
*rqstp->rq_accept_statp = rpc_garbage_args;
|
||||
goto sendit;
|
||||
|
||||
err_system_err:
|
||||
if (serv->sv_stats)
|
||||
serv->sv_stats->rpcbadfmt++;
|
||||
|
@ -1,3 +1,32 @@
|
||||
* Tue Jul 15 2025 CKI KWF Bot <cki-ci-bot+kwf-gitlab-com@redhat.com> [5.14.0-570.28.1.el9_6]
|
||||
- sunrpc: handle SVC_GARBAGE during svc auth processing as auth error (CKI Backport Bot) [RHEL-101327] {CVE-2025-38089}
|
||||
Resolves: RHEL-101327
|
||||
|
||||
* Sat Jul 12 2025 CKI KWF Bot <cki-ci-bot+kwf-gitlab-com@redhat.com> [5.14.0-570.27.1.el9_6]
|
||||
- i2c: tegra: check msg length in SMBUS block read (Steve Dunnagan) [RHEL-100516]
|
||||
- net/mlx5: Generate PPS IN event on new function for shared clock (Benjamin Poirier) [RHEL-87775]
|
||||
- net/mlx5: Support one PTP device per hardware clock (Benjamin Poirier) [RHEL-87775]
|
||||
- net/mlx5: Move PPS notifier and out_work to clock_state (Benjamin Poirier) [RHEL-87775]
|
||||
- net/mlx5: Add devcom component for the clock shared by functions (Michal Schmidt) [RHEL-87775]
|
||||
- net/mlx5: Change clock in mlx5_core_dev to mlx5_clock pointer (Michal Schmidt) [RHEL-87775]
|
||||
- net/mlx5: Add API to get mlx5_core_dev from mlx5_clock (Benjamin Poirier) [RHEL-87775]
|
||||
- net/mlx5: Add init and destruction functions for a single HW clock (Benjamin Poirier) [RHEL-87775]
|
||||
- net/mlx5: Change parameters for PTP internal functions (Benjamin Poirier) [RHEL-87775]
|
||||
- net/mlx5: Add helper functions for PTP callbacks (Benjamin Poirier) [RHEL-87775]
|
||||
- net/mlx5: Add support for MRTCQ register (Benjamin Poirier) [RHEL-87775]
|
||||
- net/mlx5: use do_aux_work for PHC overflow checks (Michal Schmidt) [RHEL-87775]
|
||||
- mlx5_en: use read sequence for gettimex64 (Benjamin Poirier) [RHEL-87775]
|
||||
- media: uvcvideo: Announce the user our deprecation intentions (Desnes Nunes) [RHEL-98772]
|
||||
- media: uvcvideo: Allow changing noparam on the fly (Desnes Nunes) [RHEL-98772]
|
||||
- media: uvcvideo: Invert default value for nodrop module param (Desnes Nunes) [RHEL-98772]
|
||||
- media: uvcvideo: Propagate buf->error to userspace (Desnes Nunes) [RHEL-98772]
|
||||
- media: uvcvideo: Flush the control cache when we get an event (Desnes Nunes) [RHEL-98772]
|
||||
- media: uvcvideo: Annotate lock requirements for uvc_ctrl_set (Desnes Nunes) [RHEL-98772]
|
||||
- media: uvcvideo: Remove dangling pointers (Desnes Nunes) [RHEL-98772] {CVE-2024-58002}
|
||||
- media: uvcvideo: Remove redundant NULL assignment (Desnes Nunes) [RHEL-98772]
|
||||
- media: uvcvideo: Only save async fh if success (Desnes Nunes) [RHEL-98772]
|
||||
Resolves: RHEL-100516, RHEL-87775, RHEL-98772
|
||||
|
||||
* Sat Jul 05 2025 CKI KWF Bot <cki-ci-bot+kwf-gitlab-com@redhat.com> [5.14.0-570.26.1.el9_6]
|
||||
- x86/microcode/AMD: Fix out-of-bounds on systems with CPU-less NUMA nodes (CKI Backport Bot) [RHEL-98996] {CVE-2025-21991}
|
||||
- cpufreq: intel_pstate: Unchecked MSR aceess in legacy mode (David Arcari) [RHEL-90212]
|
||||
|
Loading…
Reference in New Issue
Block a user