io_uring-6.3-2023-03-24
-----BEGIN PGP SIGNATURE----- iQJEBAABCAAuFiEEwPw5LcreJtl1+l5K99NY+ylx4KYFAmQdzZsQHGF4Ym9lQGtl cm5lbC5kawAKCRD301j7KXHgpiZmEACCjaHA9cneID3RpfDBlJETog9aaMz5Kh4T QAlX3iA1Q8oJ5yhI9SETAxqrd09vvruz/eGHJUe61ZTpdZzKZmra9Jp6f1K3fjvz 5TVuSDlD29ei2Wj79X3LXNiPV8ksTrZcBvF255XiwOBW227Xlm6YD2I07+jXhqh5 1c0oAC1Dr7T01AUPfkVEN/2jyQnypqU+ptOmHJs+imAZC/b9+J0roj8ni2n6+9H5 Jej5Os0laa8je3q4QCTPxn8cEY7lmyb4b90JYVD779jZuP1Nt78D/EYcktNVajrp 5f47S5SiZ1eiSgp3Bvg966w1ESaEA9fxsHNUCjV9tKfWp/EYCgFzfjtb4sFM7Ntu 0JissFmgLuLIIqBUeQI/sUPPVqg9lnw8aktK/WL9DBAVr6JGNWQ7xAGs8VWlfSVm 8g9VknBAzrCOd/UCaez9zmcz5Mr689f973HMEUGKdu/CtTEevX89O4sV8V7jMxAN /2xw3jBZGjq7ZXJQSs2qFoghWlB2AtTJGtXiIVgSHpukJp392QuGexLAlPp/fGr4 dmMttYDmmJZEaASzzjRnlFqPRQ5jpncsYaqvpFdM6eb3eLzsjv9Jv+aE87xysMiw 4jOMeAI98vixmaU1vBOxwjsXpA7XXbHJESwobVEpFgnG4BlQhH0FT6rzqseKp0dN 8TYqpi5XyA== =VjlK -----END PGP SIGNATURE----- Merge tag 'io_uring-6.3-2023-03-24' of git://git.kernel.dk/linux Pull io_uring fixes from Jens Axboe: - Fix an issue with repeated -ECONNREFUSED on a socket (me) - Fix a NULL pointer deference due to a stale lookup cache for allocating direct descriptors (Savino) * tag 'io_uring-6.3-2023-03-24' of git://git.kernel.dk/linux: io_uring/rsrc: fix null-ptr-deref in io_file_bitmap_get() io_uring/net: avoid sending -ECONNABORTED on repeated connection requests
This commit is contained in:
Коммит
e344eb7be2
|
@ -19,6 +19,9 @@ static int io_file_bitmap_get(struct io_ring_ctx *ctx)
|
||||||
unsigned long nr = ctx->file_alloc_end;
|
unsigned long nr = ctx->file_alloc_end;
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
|
if (!table->bitmap)
|
||||||
|
return -ENFILE;
|
||||||
|
|
||||||
do {
|
do {
|
||||||
ret = find_next_zero_bit(table->bitmap, nr, table->alloc_hint);
|
ret = find_next_zero_bit(table->bitmap, nr, table->alloc_hint);
|
||||||
if (ret != nr)
|
if (ret != nr)
|
||||||
|
|
|
@ -47,6 +47,7 @@ struct io_connect {
|
||||||
struct sockaddr __user *addr;
|
struct sockaddr __user *addr;
|
||||||
int addr_len;
|
int addr_len;
|
||||||
bool in_progress;
|
bool in_progress;
|
||||||
|
bool seen_econnaborted;
|
||||||
};
|
};
|
||||||
|
|
||||||
struct io_sr_msg {
|
struct io_sr_msg {
|
||||||
|
@ -1424,7 +1425,7 @@ int io_connect_prep(struct io_kiocb *req, const struct io_uring_sqe *sqe)
|
||||||
|
|
||||||
conn->addr = u64_to_user_ptr(READ_ONCE(sqe->addr));
|
conn->addr = u64_to_user_ptr(READ_ONCE(sqe->addr));
|
||||||
conn->addr_len = READ_ONCE(sqe->addr2);
|
conn->addr_len = READ_ONCE(sqe->addr2);
|
||||||
conn->in_progress = false;
|
conn->in_progress = conn->seen_econnaborted = false;
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1461,18 +1462,24 @@ int io_connect(struct io_kiocb *req, unsigned int issue_flags)
|
||||||
|
|
||||||
ret = __sys_connect_file(req->file, &io->address,
|
ret = __sys_connect_file(req->file, &io->address,
|
||||||
connect->addr_len, file_flags);
|
connect->addr_len, file_flags);
|
||||||
if ((ret == -EAGAIN || ret == -EINPROGRESS) && force_nonblock) {
|
if ((ret == -EAGAIN || ret == -EINPROGRESS || ret == -ECONNABORTED)
|
||||||
|
&& force_nonblock) {
|
||||||
if (ret == -EINPROGRESS) {
|
if (ret == -EINPROGRESS) {
|
||||||
connect->in_progress = true;
|
connect->in_progress = true;
|
||||||
} else {
|
return -EAGAIN;
|
||||||
if (req_has_async_data(req))
|
|
||||||
return -EAGAIN;
|
|
||||||
if (io_alloc_async_data(req)) {
|
|
||||||
ret = -ENOMEM;
|
|
||||||
goto out;
|
|
||||||
}
|
|
||||||
memcpy(req->async_data, &__io, sizeof(__io));
|
|
||||||
}
|
}
|
||||||
|
if (ret == -ECONNABORTED) {
|
||||||
|
if (connect->seen_econnaborted)
|
||||||
|
goto out;
|
||||||
|
connect->seen_econnaborted = true;
|
||||||
|
}
|
||||||
|
if (req_has_async_data(req))
|
||||||
|
return -EAGAIN;
|
||||||
|
if (io_alloc_async_data(req)) {
|
||||||
|
ret = -ENOMEM;
|
||||||
|
goto out;
|
||||||
|
}
|
||||||
|
memcpy(req->async_data, &__io, sizeof(__io));
|
||||||
return -EAGAIN;
|
return -EAGAIN;
|
||||||
}
|
}
|
||||||
if (ret == -ERESTARTSYS)
|
if (ret == -ERESTARTSYS)
|
||||||
|
|
|
@ -794,6 +794,7 @@ void __io_sqe_files_unregister(struct io_ring_ctx *ctx)
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
io_free_file_tables(&ctx->file_table);
|
io_free_file_tables(&ctx->file_table);
|
||||||
|
io_file_table_set_alloc_range(ctx, 0, 0);
|
||||||
io_rsrc_data_free(ctx->file_data);
|
io_rsrc_data_free(ctx->file_data);
|
||||||
ctx->file_data = NULL;
|
ctx->file_data = NULL;
|
||||||
ctx->nr_user_files = 0;
|
ctx->nr_user_files = 0;
|
||||||
|
|
Загрузка…
Ссылка в новой задаче