| 
									
										
										
										
											2020-09-19 12:17:46 -07:00
										 |  |  | #![feature(test)]
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | extern crate test;
 | 
					
						
							|  |  |  | use bincode::{deserialize, serialize};
 | 
					
						
							|  |  |  | use solana_sdk::instruction::{AccountMeta, Instruction};
 | 
					
						
							|  |  |  | use solana_sdk::message::Message;
 | 
					
						
							| 
									
										
										
										
											2020-10-19 12:23:14 -07:00
										 |  |  | use solana_sdk::pubkey;
 | 
					
						
							| 
									
										
										
										
											2020-09-19 12:17:46 -07:00
										 |  |  | use solana_sdk::sysvar::instructions;
 | 
					
						
							|  |  |  | use test::Bencher;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | fn make_instructions() -> Vec<Instruction> {
 | 
					
						
							| 
									
										
										
										
											2020-10-19 12:23:14 -07:00
										 |  |  |     let meta = AccountMeta::new(pubkey::new_rand(), false);
 | 
					
						
							| 
									
										
										
										
											2021-03-03 21:46:48 -08:00
										 |  |  |     let inst = Instruction::new_with_bincode(pubkey::new_rand(), &[0; 10], vec![meta; 4]);
 | 
					
						
							| 
									
										
										
										
											2020-09-19 12:17:46 -07:00
										 |  |  |     vec![inst; 4]
 | 
					
						
							|  |  |  | }
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #[bench]
 | 
					
						
							|  |  |  | fn bench_bincode_instruction_serialize(b: &mut Bencher) {
 | 
					
						
							|  |  |  |     let instructions = make_instructions();
 | 
					
						
							|  |  |  |     b.iter(|| {
 | 
					
						
							|  |  |  |         test::black_box(serialize(&instructions).unwrap());
 | 
					
						
							|  |  |  |     });
 | 
					
						
							|  |  |  | }
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #[bench]
 | 
					
						
							|  |  |  | fn bench_manual_instruction_serialize(b: &mut Bencher) {
 | 
					
						
							|  |  |  |     let instructions = make_instructions();
 | 
					
						
							|  |  |  |     let message = Message::new(&instructions, None);
 | 
					
						
							|  |  |  |     b.iter(|| {
 | 
					
						
							| 
									
										
										
										
											2021-03-30 10:05:09 -07:00
										 |  |  |         test::black_box(message.serialize_instructions(
 | 
					
						
							|  |  |  |             true, // demote_sysvar_write_locks
 | 
					
						
							|  |  |  |         ));
 | 
					
						
							| 
									
										
										
										
											2020-09-19 12:17:46 -07:00
										 |  |  |     });
 | 
					
						
							|  |  |  | }
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #[bench]
 | 
					
						
							|  |  |  | fn bench_bincode_instruction_deserialize(b: &mut Bencher) {
 | 
					
						
							|  |  |  |     let instructions = make_instructions();
 | 
					
						
							|  |  |  |     let serialized = serialize(&instructions).unwrap();
 | 
					
						
							|  |  |  |     b.iter(|| {
 | 
					
						
							|  |  |  |         test::black_box(deserialize::<Vec<Instruction>>(&serialized).unwrap());
 | 
					
						
							|  |  |  |     });
 | 
					
						
							|  |  |  | }
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #[bench]
 | 
					
						
							|  |  |  | fn bench_manual_instruction_deserialize(b: &mut Bencher) {
 | 
					
						
							|  |  |  |     let instructions = make_instructions();
 | 
					
						
							|  |  |  |     let message = Message::new(&instructions, None);
 | 
					
						
							| 
									
										
										
										
											2021-03-30 10:05:09 -07:00
										 |  |  |     let serialized = message.serialize_instructions(
 | 
					
						
							|  |  |  |         true, // demote_sysvar_write_locks
 | 
					
						
							|  |  |  |     );
 | 
					
						
							| 
									
										
										
										
											2020-09-19 12:17:46 -07:00
										 |  |  |     b.iter(|| {
 | 
					
						
							|  |  |  |         for i in 0..instructions.len() {
 | 
					
						
							| 
									
										
										
										
											2020-09-20 10:58:12 -07:00
										 |  |  |             test::black_box(instructions::load_instruction_at(i, &serialized).unwrap());
 | 
					
						
							| 
									
										
										
										
											2020-09-19 12:17:46 -07:00
										 |  |  |         }
 | 
					
						
							|  |  |  |     });
 | 
					
						
							|  |  |  | }
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #[bench]
 | 
					
						
							|  |  |  | fn bench_manual_instruction_deserialize_single(b: &mut Bencher) {
 | 
					
						
							|  |  |  |     let instructions = make_instructions();
 | 
					
						
							|  |  |  |     let message = Message::new(&instructions, None);
 | 
					
						
							| 
									
										
										
										
											2021-03-30 10:05:09 -07:00
										 |  |  |     let serialized = message.serialize_instructions(
 | 
					
						
							|  |  |  |         true, // demote_sysvar_write_locks
 | 
					
						
							|  |  |  |     );
 | 
					
						
							| 
									
										
										
										
											2020-09-19 12:17:46 -07:00
										 |  |  |     b.iter(|| {
 | 
					
						
							| 
									
										
										
										
											2020-09-20 10:58:12 -07:00
										 |  |  |         test::black_box(instructions::load_instruction_at(3, &serialized).unwrap());
 | 
					
						
							| 
									
										
										
										
											2020-09-19 12:17:46 -07:00
										 |  |  |     });
 | 
					
						
							|  |  |  | }
 |