Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

v1.9/fix build #22311

Closed
wants to merge 150 commits into from
Closed
Changes from 1 commit
Commits
Show all changes
150 commits
Select commit Hold shift + click to select a range
3e28ffa
Bump RpcClient node versions (#21612) (#21613)
mergify[bot] Dec 5, 2021
b4c8e09
adds back position field to coding-shred-header (#21600) (#21620)
mergify[bot] Dec 5, 2021
6008530
Fix spelling of 'Borsh' (#21624)
mergify[bot] Dec 6, 2021
58c755e
Rework docs for Pubkey::find_program_address and friends (#21528) (#2…
mergify[bot] Dec 6, 2021
b3fa1e4
Move transaction error code into new module (#21635) (#21638)
mergify[bot] Dec 6, 2021
89d2f34
Reject vote withdraws that create non-rent-exempt accounts (backport …
mergify[bot] Dec 7, 2021
8a7106b
Remove activated feature for filtering invalid stakes from rewards (#…
mergify[bot] Dec 7, 2021
46935c0
Ensure that StakeDelegations and StakeHistory serde (#21640) (#21653)
mergify[bot] Dec 7, 2021
0e96901
Add offline and fee-payer utilities to CLI vote module (#21579) (#21649)
mergify[bot] Dec 7, 2021
87accd1
Fixup flaky tests (#21617) (#21647)
mergify[bot] Dec 7, 2021
2b4347d
Add option to reclaim accounts-cluster-bench accounts/lamports (backp…
mergify[bot] Dec 7, 2021
18e3a63
docs: Fix SOL staked formula (#21615) (#21667)
mergify[bot] Dec 7, 2021
b7b56d5
Docs: Solflare web/app updates (#21540) (#21668)
mergify[bot] Dec 7, 2021
2d2ef59
Ensure we have keys to activate these features (#21669) (#21674)
mergify[bot] Dec 7, 2021
cabd851
Avoid entropy sources when constructing a solana_program::message::Me…
Dec 7, 2021
ef970bb
- Implicitly fixes invoke_context.return_data not being reset between…
mergify[bot] Dec 8, 2021
f2a6b94
SDK: Add stdlib.h include to pull in `abort()` (#21700) (#21705)
mergify[bot] Dec 8, 2021
8ee5fbc
simulateTransaction now returns the correct error code if accounts ar…
mergify[bot] Dec 9, 2021
8cacf82
adds more sanity checks to shreds (#21675) (#21734)
mergify[bot] Dec 9, 2021
dd157fd
Fixed minor issues with the cluster overview docs which had confused …
mergify[bot] Dec 9, 2021
2698a5c
AcctIdx: env var to enable testing of disk buckets (#21494) (#21723)
mergify[bot] Dec 9, 2021
8836069
Add wasm bindings for `Pubkey` and `Keypair`
mvines Oct 13, 2021
effd0b2
Add wasm bindings for `Hash`
mvines Oct 19, 2021
b0754cc
Add initial wasm bindings for `Instruction`, `SystemProgram` and `Tra…
mvines Oct 18, 2021
85f6019
Cargo.lock
mvines Dec 8, 2021
539ad4b
Remove libcurl to prevent wasm-pack segfault in libssl
mvines Dec 8, 2021
a316608
rebase
mvines Dec 10, 2021
abecf29
Expand docs for Pubkey::create_program_address (#21750) (#21759)
mergify[bot] Dec 10, 2021
ef51778
Nits in message-processor (#21755) (#21762)
mergify[bot] Dec 10, 2021
2a6bb2b
Migrate from address maps to address lookup tables (#21634) (#21773)
mergify[bot] Dec 10, 2021
68fc72a
Add more reporting for invalid stake cache members and prune them (#2…
mergify[bot] Dec 10, 2021
da9e682
Move type alias and use it more broadly (#21763) (#21777)
mergify[bot] Dec 10, 2021
ed0040d
Update to Rust 1.57.0 (#21779)
mergify[bot] Dec 10, 2021
e71ea19
adds back ErasureMeta::first_coding_index field (#21623) (#21785)
mergify[bot] Dec 10, 2021
2c4765e
Bump solana_rbpf to version v0.2.18 (#21774) (#21786)
mergify[bot] Dec 11, 2021
7782d34
Add StakesCache struct to abstract away locking (#21738) (#21796)
jstarry Dec 11, 2021
5bf4445
Add address lookup table program (backport #21616) (#21789)
mergify[bot] Dec 11, 2021
4b63d51
Bump version to 1.9.1 (#21802)
tao-stones Dec 11, 2021
01941cf
Rename Packets to PacketBatch (backport #21794) (#21805)
mergify[bot] Dec 11, 2021
9956afb
uses Option<u64> for SlotMeta.last_index (#21775) (#21806)
mergify[bot] Dec 11, 2021
0576d13
Add Accountsdb plugin documentations (#21746) (#21799)
lijunwangs Dec 11, 2021
c1f54c2
Remove the 5 integer msg! form
mvines Dec 10, 2021
0376045
cli: Order displayed feature list by status (#21810) (#21830)
mergify[bot] Dec 13, 2021
6c329e2
Fixup RPC docs (backport #21858) (#21864)
mergify[bot] Dec 14, 2021
5e2b12a
Restore ALL behavior; add enum variant, comments, and help text to ma…
mergify[bot] Dec 14, 2021
cf2a9de
Add solana-cli-config link to rust-api.md (#21840) (#21874)
mergify[bot] Dec 14, 2021
3977bcd
Add missing word "that" (#21878) (#21884)
mergify[bot] Dec 14, 2021
a9d4728
Deserialize accounts before acquiring stakes cache lock (#21733) (#21…
mergify[bot] Dec 14, 2021
fad4bfd
Don't publish poh-bench to crates.io
mvines Dec 14, 2021
135dfdb
Don't publish rbpf-cli to crates.io
mvines Dec 14, 2021
2cd2f3b
Bump rbpf to v0.2.19 (#21880) (#21891)
mergify[bot] Dec 14, 2021
2f1816d
adds ShredId uniquely identifying each shred (backport #21820) (#21897)
mergify[bot] Dec 14, 2021
a056fd8
uses Option<Slot> for SlotMeta.parent_slot (backport #21808) (#21899)
mergify[bot] Dec 14, 2021
5c3fbb3
Futures 0.3.18 has been yanked, back off to .17
mvines Dec 14, 2021
fb955bd
Update Cargo.toml
mvines Dec 14, 2021
41ea597
Fix subtraction overflow (#21871) (#21901)
mergify[bot] Dec 14, 2021
2246135
Document solana_program::instruction (#21817) (#21906)
mergify[bot] Dec 15, 2021
dcd76e4
Update openssl-src package to resolve cargo audit complaint
mvines Dec 15, 2021
9f173d3
Add helper crate to generate syscalls.txt
mvines Dec 14, 2021
de48347
Add json support for feature sets; also print output after feature li…
mergify[bot] Dec 15, 2021
b4c8475
Restore solana_validator::test_validator export
mvines Dec 15, 2021
c907d44
add accountsdb-plugin-config to test-validator (#21918)
mergify[bot] Dec 15, 2021
7dba8bb
Add complete account dump to file
losman0s Dec 11, 2021
a462c58
Add option to load accounts from file
losman0s Dec 11, 2021
569c832
Update argument name
mvines Dec 15, 2021
3967dc8
rebase
mvines Dec 15, 2021
b66e2ae
add caching_enabled option to test-validator
fanatid Dec 15, 2021
bfa6302
Bump version to 1.9.2
mvines Dec 16, 2021
301e380
Fixes the calculation of the "compute_meter_consumption" across proce…
mergify[bot] Dec 16, 2021
c25d16b
adds ErasureSetId identifying erasure coding sets of shreds (backport…
mergify[bot] Dec 16, 2021
0c5a2bc
Update getSignaturesForAddress and getConfirmedSignaturesForAddress2 …
mergify[bot] Dec 16, 2021
f452100
Clean up demote program write lock feature (backport #21949) (#21969)
mergify[bot] Dec 17, 2021
e572678
removes next_shred_index from return value of entries to shreds api (…
mergify[bot] Dec 17, 2021
b20fae5
simplifies ShredIndex api (#21932) (#21959)
mergify[bot] Dec 17, 2021
02be3a6
Check file size of `snapshot_version` when unarchiving snapshot (#219…
mergify[bot] Dec 17, 2021
02cfa85
Update to reed-solomon-erasure 5.0.1, to get simd-accel on M1 macs (#…
mergify[bot] Dec 18, 2021
35ee48b
RPC Block Subscription (backport #21787) (#21992)
mergify[bot] Dec 18, 2021
91657ba
new net-stats require a new table (#21996) (#22000)
mergify[bot] Dec 18, 2021
e3a4b98
removes Select in favor of recv_timeout/try_iter (#21981) (#22001)
mergify[bot] Dec 18, 2021
bf41c53
chore: add blockSubscribe api docs (#22002) (#22008)
mergify[bot] Dec 19, 2021
f58c375
typo: lanaguage -> language (#22009) (#22015)
mergify[bot] Dec 20, 2021
c4b3b28
Update program close docs (#22026) (#22027)
mergify[bot] Dec 20, 2021
4f57c4a
Fix weird formatting of bullets (#22013) (#22030)
mergify[bot] Dec 20, 2021
57e5406
Add deactivation cooldown before address lookup tables can be closed …
mergify[bot] Dec 21, 2021
c296a6c
The sidebar for the plugin doc is showing the item as "Overview", cor…
mergify[bot] Dec 21, 2021
75fe0d3
Fix #21986 (#22035) (#22049)
mergify[bot] Dec 21, 2021
1a2823b
chore: bump lru from 0.7.0 to 0.7.1 (#22018) (#22056)
mergify[bot] Dec 21, 2021
f58b87b
v1.9: bump tarpc from 0.26.2 to 0.27.2 and add BanksClientError (#22055)
CriesofCarrots Dec 22, 2021
78e7913
Bump version to 1.9.3 (#22065)
willhickey Dec 22, 2021
9fbaaa5
Increment execution timings on errors as well (#22053) (#22072)
mergify[bot] Dec 22, 2021
8f26c71
Fixed a typo in the SQL statement (#21872) (#22075)
mergify[bot] Dec 22, 2021
f31593b
Update jsonrpc-api.md to document 'owner' property (#22074) (#22077)
mergify[bot] Dec 23, 2021
a70eb09
Fix transaction pk violation (#22057) (#22076)
mergify[bot] Dec 23, 2021
7d61935
Bump bpf-tools to v1.21 (#22083)
mergify[bot] Dec 23, 2021
8f3e37c
Remove msg spam from deploying
RLaursen Dec 23, 2021
8708186
Update checks.rs
RLaursen Dec 23, 2021
be0bcd8
tracks erasure coding shreds' indices explicitly (#21822) (#22094)
mergify[bot] Dec 23, 2021
3ad4c33
Add PubsubClient::vote_subscribe (#22114)
mergify[bot] Dec 25, 2021
584e9bf
docs: fix typo (#22116) (#22118)
mergify[bot] Dec 26, 2021
16f821e
Ensure AncestorHashesSerice selects an open port (#21919) (#21997)
mergify[bot] Dec 28, 2021
810ca36
skip reporting all-zero stats (#22054)
mergify[bot] Dec 28, 2021
adc584e
Add (preflight) simulation to BanksClient (#22084) (#22149)
mergify[bot] Dec 28, 2021
14ed446
cargo-build-bpf: Add Windows support (#20276) (#22155)
mergify[bot] Dec 29, 2021
401c542
Count compute units even when transaction errors (backport #22059) (#…
mergify[bot] Dec 29, 2021
9fb67f9
Prevent log spam (#22148) (#22152)
mergify[bot] Dec 29, 2021
74b98c2
get_signatures_for_address does not correctly account for result sets…
mergify[bot] Dec 29, 2021
9c9d3e8
discards serialized gossip crds votes if cannot parse tx (backport #2…
mergify[bot] Dec 29, 2021
531f36c
Don't forward packets received from TPU forwards port (#22078) (#22171)
mergify[bot] Dec 30, 2021
0cd4540
Add docs for notifying transactions via plugin (#22097) (#22178)
mergify[bot] Dec 30, 2021
6a556c5
Stream additional block metadata via plugin (#22023) (#22179)
mergify[bot] Dec 30, 2021
7efd039
Revert "Count compute units even when transaction errors (backport #2…
carllin Dec 30, 2021
4645be3
fix: Installer increase download req timeout from 30 seconds to 6 min…
Arrowana Dec 28, 2021
6a2b62d
Add connect timeout and change overall timeout to None
Arrowana Dec 29, 2021
d5c0ffc
Update install/src/command.rs
Arrowana Dec 30, 2021
c6ab915
chore: update transaction error links in docs (#22189) (#22197)
mergify[bot] Dec 30, 2021
113d261
Count compute units even when transaction errors (backport #22182) (#…
mergify[bot] Dec 31, 2021
ca451ea
checks for authorized voter early on in the vote-listener pipeline (b…
mergify[bot] Dec 31, 2021
70d5b6a
Bump solana_rbpf to version v0.2.20 (#22164) (#22207)
mergify[bot] Dec 31, 2021
7c5d3e5
Exit early on BigTable error (#22200) (#22209)
mergify[bot] Jan 1, 2022
264bb90
Bump rbpf to v0.2.21 (#22216) (#22217)
Lichtso Jan 1, 2022
735f000
Remove Xargo.toml reference (#22239)
mergify[bot] Jan 3, 2022
478c641
Fix token-balance owner type in docs (#22240) (#22242)
mergify[bot] Jan 3, 2022
0a9460e
re-calibrate limit based on mainnet data (backport #21995) (#22212)
mergify[bot] Jan 3, 2022
fd4754e
Correctly set CI_OS_NAME for macOs buildkite agents
mvines Jan 3, 2022
3e4e2e9
Prevent lookup tables from being closed during deactivation slot (#22…
mergify[bot] Jan 3, 2022
b3fa128
Use experimential docker virtualization framework for arm64
mvines Jan 3, 2022
d7a673f
Add support for arm64-apple-darwin release/channel artifacts
mvines Jan 3, 2022
794f28d
Switch from arm64-apple-darwin to aarch64-apple-darwin to align with …
mvines Jan 4, 2022
5bd27dd
Correctly set CI_COMMIT when Buildkite provides HEAD instead of a rea…
mvines Jan 4, 2022
35fb47d
removes epoch_authorized_voters from VoteTracker (backport #22192) (#…
mergify[bot] Jan 4, 2022
f8bf478
Fix bug, add error specific timings (#22225) (#22252)
mergify[bot] Jan 4, 2022
464d533
Flip iter operations to keep associated address/header/packets togeth…
mergify[bot] Jan 4, 2022
77558c3
Fixed issue #22124 -- missing historical data if slot updated later. …
mergify[bot] Jan 4, 2022
7d2589e
Documentation typos (#22262) (#22268)
mergify[bot] Jan 4, 2022
3b59f67
Limit number of accounts that a transaction can lock (backport #22201…
mergify[bot] Jan 4, 2022
185f52b
Lower vote-only-mode to 400 (#22210) (#22272)
mergify[bot] Jan 4, 2022
d84b994
shrinks size of Packet.Meta (backport #22224) (#22273)
mergify[bot] Jan 4, 2022
9764d43
Add return types to generate_index() (#21735) (#22275)
mergify[bot] Jan 4, 2022
09dbf06
Add test to enforce that program id account info for CPI is optional …
mergify[bot] Jan 4, 2022
edfd8c1
Fix program log filtering (#22133) (#22151)
mergify[bot] Jan 4, 2022
c99aed4
Update address map proposal to improve dev experience (#21576) (#22283)
mergify[bot] Jan 4, 2022
f89bf7b
Compute accounts data len during generate_index() (#21757) (#22277)
mergify[bot] Jan 4, 2022
f4ded6f
Updates to the address lookup table proposal (#22269) (#22270)
mergify[bot] Jan 4, 2022
fb0e5ad
patches bug in recv_mmsg when npkts != nrecv (backport #22276) (#22280)
mergify[bot] Jan 4, 2022
17411f9
Add accounts_data_len to Bank (#21781) (#22285)
mergify[bot] Jan 5, 2022
87f4a1f
Bank gets accounts data len delta from MessageProcessor::process_mess…
mergify[bot] Jan 5, 2022
8578429
Refactor: Improve type safety and readability of transaction executio…
mergify[bot] Jan 5, 2022
05b9a2f
fix(rpc): recreate dead and uncleaned subscriptions (#22281) (#22294)
mergify[bot] Jan 5, 2022
ba0188a
Bump version to 1.9.4 (#22304)
willhickey Jan 5, 2022
9968b86
Fix broken build from bpf/tests/programs.rs
brooksprumo Jan 5, 2022
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
fix(rpc): recreate dead and uncleaned subscriptions (#22281) (#22294)
(cherry picked from commit c1995c6)

Co-authored-by: Nikita <bananaelecitrus@gmail.com>
  • Loading branch information
mergify[bot] and 00nktk authored Jan 5, 2022
commit 05b9a2f20357a5281ac1e2e4022c127b129efb44
53 changes: 35 additions & 18 deletions rpc/src/rpc_subscription_tracker.rs
Original file line number Diff line number Diff line change
Expand Up @@ -180,9 +180,10 @@ pub struct SignatureSubscriptionParams {

#[derive(Clone)]
pub struct SubscriptionControl(Arc<SubscriptionControlInner>);
pub struct WeakSubscriptionTokenRef(Weak<SubscriptionTokenInner>, SubscriptionId);

struct SubscriptionControlInner {
subscriptions: DashMap<SubscriptionParams, Weak<SubscriptionTokenInner>>,
subscriptions: DashMap<SubscriptionParams, WeakSubscriptionTokenRef>,
next_id: AtomicU64,
max_active_subscriptions: usize,
sender: crossbeam_channel::Sender<TimestampedNotificationEntry>,
Expand Down Expand Up @@ -216,33 +217,44 @@ impl SubscriptionControl {
self.0.subscriptions.len()
);
let count = self.0.subscriptions.len();
match self.0.subscriptions.entry(params) {
DashEntry::Occupied(entry) => Ok(SubscriptionToken(
entry
.get()
.upgrade()
.expect("dead subscription encountered in SubscriptionControl"),
let create_token_and_weak_ref = |id, params| {
let token = SubscriptionToken(
Arc::new(SubscriptionTokenInner {
control: Arc::clone(&self.0),
params,
id,
}),
self.0.counter.create_token(),
)),
);
let weak_ref = WeakSubscriptionTokenRef(Arc::downgrade(&token.0), token.0.id);
(token, weak_ref)
};

match self.0.subscriptions.entry(params) {
DashEntry::Occupied(mut entry) => match entry.get().0.upgrade() {
Some(token_ref) => Ok(SubscriptionToken(token_ref, self.0.counter.create_token())),
// This means the last Arc for this Weak pointer entered the drop just before us,
// but could not remove the entry since we are holding the write lock.
// See `Drop` implementation for `SubscriptionTokenInner` for further info.
None => {
let (token, weak_ref) =
create_token_and_weak_ref(entry.get().1, entry.key().clone());
entry.insert(weak_ref);
Ok(token)
}
},
DashEntry::Vacant(entry) => {
if count >= self.0.max_active_subscriptions {
inc_new_counter_info!("rpc-subscription-refused-limit-reached", 1);
return Err(Error::TooManySubscriptions);
}
let id = SubscriptionId::from(self.0.next_id.fetch_add(1, Ordering::AcqRel));
let token = SubscriptionToken(
Arc::new(SubscriptionTokenInner {
control: Arc::clone(&self.0),
params: entry.key().clone(),
id,
}),
self.0.counter.create_token(),
);
let (token, weak_ref) = create_token_and_weak_ref(id, entry.key().clone());
let _ = self
.0
.sender
.send(NotificationEntry::Subscribed(token.0.params.clone(), id).into());
entry.insert(Arc::downgrade(&token.0));
entry.insert(weak_ref);
datapoint_info!(
"rpc-subscription",
("total", self.0.subscriptions.len(), i64)
Expand Down Expand Up @@ -529,7 +541,9 @@ impl Drop for SubscriptionTokenInner {
DashEntry::Vacant(_) => {
warn!("Subscriptions inconsistency (missing entry in by_params)");
}
DashEntry::Occupied(entry) => {
// Check the strong refs count to ensure no other thread recreated this subscription (not token)
// while we were acquiring the lock.
DashEntry::Occupied(entry) if entry.get().0.strong_count() == 0 => {
let _ = self
.control
.sender
Expand All @@ -540,6 +554,9 @@ impl Drop for SubscriptionTokenInner {
("total", self.control.subscriptions.len(), i64)
);
}
// This branch handles the case in which this entry got recreated
// while we were waiting for the lock (inside the `DashMap::entry` method).
DashEntry::Occupied(_entry) /* if _entry.get().0.strong_count() > 0 */ => (),
}
}
}
Expand Down