time/generic-queue: ensure queue goes in .bss instead of .data
This commit is contained in:
		
							parent
							
								
									560eecdb73
								
							
						
					
					
						commit
						4976cbbe60
					
				| @ -57,19 +57,11 @@ impl Ord for Timer { | |||||||
| 
 | 
 | ||||||
| struct InnerQueue { | struct InnerQueue { | ||||||
|     queue: SortedLinkedList<Timer, LinkedIndexU8, Min, { QUEUE_SIZE }>, |     queue: SortedLinkedList<Timer, LinkedIndexU8, Min, { QUEUE_SIZE }>, | ||||||
|     alarm: Option<AlarmHandle>, |     alarm: AlarmHandle, | ||||||
|     alarm_at: Instant, |     alarm_at: Instant, | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| impl InnerQueue { | impl InnerQueue { | ||||||
|     const fn new() -> Self { |  | ||||||
|         Self { |  | ||||||
|             queue: SortedLinkedList::new_u8(), |  | ||||||
|             alarm: None, |  | ||||||
|             alarm_at: Instant::MAX, |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     fn schedule_wake(&mut self, at: Instant, waker: &Waker) { |     fn schedule_wake(&mut self, at: Instant, waker: &Waker) { | ||||||
|         self.queue |         self.queue | ||||||
|             .find_mut(|timer| timer.waker.will_wake(waker)) |             .find_mut(|timer| timer.waker.will_wake(waker)) | ||||||
| @ -121,7 +113,7 @@ impl InnerQueue { | |||||||
|             if self.alarm_at != new_at { |             if self.alarm_at != new_at { | ||||||
|                 self.alarm_at = new_at; |                 self.alarm_at = new_at; | ||||||
| 
 | 
 | ||||||
|                 return set_alarm(self.alarm.unwrap(), self.alarm_at.as_ticks()); |                 return set_alarm(self.alarm, self.alarm_at.as_ticks()); | ||||||
|             } |             } | ||||||
|         } else { |         } else { | ||||||
|             self.alarm_at = Instant::MAX; |             self.alarm_at = Instant::MAX; | ||||||
| @ -138,13 +130,13 @@ impl InnerQueue { | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| struct Queue { | struct Queue { | ||||||
|     inner: Mutex<CriticalSectionRawMutex, RefCell<InnerQueue>>, |     inner: Mutex<CriticalSectionRawMutex, RefCell<Option<InnerQueue>>>, | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| impl Queue { | impl Queue { | ||||||
|     const fn new() -> Self { |     const fn new() -> Self { | ||||||
|         Self { |         Self { | ||||||
|             inner: Mutex::new(RefCell::new(InnerQueue::new())), |             inner: Mutex::new(RefCell::new(None)), | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
| @ -152,19 +144,25 @@ impl Queue { | |||||||
|         self.inner.lock(|inner| { |         self.inner.lock(|inner| { | ||||||
|             let mut inner = inner.borrow_mut(); |             let mut inner = inner.borrow_mut(); | ||||||
| 
 | 
 | ||||||
|             if inner.alarm.is_none() { |             if inner.is_none() {} | ||||||
|  | 
 | ||||||
|  |             inner | ||||||
|  |                 .get_or_insert_with(|| { | ||||||
|                     let handle = unsafe { allocate_alarm() }.unwrap(); |                     let handle = unsafe { allocate_alarm() }.unwrap(); | ||||||
|                 inner.alarm = Some(handle); |  | ||||||
| 
 |  | ||||||
|                     set_alarm_callback(handle, Self::handle_alarm_callback, self as *const _ as _); |                     set_alarm_callback(handle, Self::handle_alarm_callback, self as *const _ as _); | ||||||
|  |                     InnerQueue { | ||||||
|  |                         queue: SortedLinkedList::new_u8(), | ||||||
|  |                         alarm: handle, | ||||||
|  |                         alarm_at: Instant::MAX, | ||||||
|                     } |                     } | ||||||
| 
 |                 }) | ||||||
|             inner.schedule_wake(at, waker) |                 .schedule_wake(at, waker) | ||||||
|         }); |         }); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     fn handle_alarm(&self) { |     fn handle_alarm(&self) { | ||||||
|         self.inner.lock(|inner| inner.borrow_mut().handle_alarm()); |         self.inner | ||||||
|  |             .lock(|inner| inner.borrow_mut().as_mut().unwrap().handle_alarm()); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     fn handle_alarm_callback(ctx: *mut ()) { |     fn handle_alarm_callback(ctx: *mut ()) { | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user