1#[doc = "Register `LPM` reader"]
2pub struct R(crate::pac::generic::R<LPM_SPEC>);
3impl core::ops::Deref for R {
4 type Target = crate::pac::generic::R<LPM_SPEC>;
5 #[inline(always)]
6 fn deref(&self) -> &Self::Target {
7 &self.0
8 }
9}
10impl From<crate::pac::generic::R<LPM_SPEC>> for R {
11 #[inline(always)]
12 fn from(reader: crate::pac::generic::R<LPM_SPEC>) -> Self {
13 R(reader)
14 }
15}
16#[doc = "Register `LPM` writer"]
17pub struct W(crate::pac::generic::W<LPM_SPEC>);
18impl core::ops::Deref for W {
19 type Target = crate::pac::generic::W<LPM_SPEC>;
20 #[inline(always)]
21 fn deref(&self) -> &Self::Target {
22 &self.0
23 }
24}
25impl core::ops::DerefMut for W {
26 #[inline(always)]
27 fn deref_mut(&mut self) -> &mut Self::Target {
28 &mut self.0
29 }
30}
31impl From<crate::pac::generic::W<LPM_SPEC>> for W {
32 #[inline(always)]
33 fn from(writer: crate::pac::generic::W<LPM_SPEC>) -> Self {
34 W(writer)
35 }
36}
37#[doc = "Field `HIRD_HW` reader - Host Initiated Resume Duration - HW. This is the HIRD value from the last received LPM token"]
38pub struct HIRD_HW_R(crate::pac::generic::FieldReader<u8, u8>);
39impl HIRD_HW_R {
40 #[inline(always)]
41 pub(crate) fn new(bits: u8) -> Self {
42 HIRD_HW_R(crate::pac::generic::FieldReader::new(bits))
43 }
44}
45impl core::ops::Deref for HIRD_HW_R {
46 type Target = crate::pac::generic::FieldReader<u8, u8>;
47 #[inline(always)]
48 fn deref(&self) -> &Self::Target {
49 &self.0
50 }
51}
52#[doc = "Field `HIRD_SW` reader - Host Initiated Resume Duration - SW. This is the time duration required by the USB device system to come out of LPM initiated suspend after receiving the host initiated LPM resume."]
53pub struct HIRD_SW_R(crate::pac::generic::FieldReader<u8, u8>);
54impl HIRD_SW_R {
55 #[inline(always)]
56 pub(crate) fn new(bits: u8) -> Self {
57 HIRD_SW_R(crate::pac::generic::FieldReader::new(bits))
58 }
59}
60impl core::ops::Deref for HIRD_SW_R {
61 type Target = crate::pac::generic::FieldReader<u8, u8>;
62 #[inline(always)]
63 fn deref(&self) -> &Self::Target {
64 &self.0
65 }
66}
67#[doc = "Field `HIRD_SW` writer - Host Initiated Resume Duration - SW. This is the time duration required by the USB device system to come out of LPM initiated suspend after receiving the host initiated LPM resume."]
68pub struct HIRD_SW_W<'a> {
69 w: &'a mut W,
70}
71impl<'a> HIRD_SW_W<'a> {
72 #[doc = r"Writes raw bits to the field"]
73 #[inline(always)]
74 pub unsafe fn bits(self, value: u8) -> &'a mut W {
75 self.w.bits = (self.w.bits & !(0x0f << 4)) | ((value as u32 & 0x0f) << 4);
76 self.w
77 }
78}
79#[doc = "Field `DATA_PENDING` reader - As long as this bit is set to one and LPM supported bit is set to one, HW will return a NYET handshake on every LPM token it receives. If LPM supported bit is set to one and this bit is zero, HW will return an ACK handshake on every LPM token it receives. If SW has still data pending and LPM is supported, it must set this bit to 1."]
80pub struct DATA_PENDING_R(crate::pac::generic::FieldReader<bool, bool>);
81impl DATA_PENDING_R {
82 #[inline(always)]
83 pub(crate) fn new(bits: bool) -> Self {
84 DATA_PENDING_R(crate::pac::generic::FieldReader::new(bits))
85 }
86}
87impl core::ops::Deref for DATA_PENDING_R {
88 type Target = crate::pac::generic::FieldReader<bool, bool>;
89 #[inline(always)]
90 fn deref(&self) -> &Self::Target {
91 &self.0
92 }
93}
94#[doc = "Field `DATA_PENDING` writer - As long as this bit is set to one and LPM supported bit is set to one, HW will return a NYET handshake on every LPM token it receives. If LPM supported bit is set to one and this bit is zero, HW will return an ACK handshake on every LPM token it receives. If SW has still data pending and LPM is supported, it must set this bit to 1."]
95pub struct DATA_PENDING_W<'a> {
96 w: &'a mut W,
97}
98impl<'a> DATA_PENDING_W<'a> {
99 #[doc = r"Sets the field bit"]
100 #[inline(always)]
101 pub fn set_bit(self) -> &'a mut W {
102 self.bit(true)
103 }
104 #[doc = r"Clears the field bit"]
105 #[inline(always)]
106 pub fn clear_bit(self) -> &'a mut W {
107 self.bit(false)
108 }
109 #[doc = r"Writes raw bits to the field"]
110 #[inline(always)]
111 pub fn bit(self, value: bool) -> &'a mut W {
112 self.w.bits = (self.w.bits & !(0x01 << 8)) | ((value as u32 & 0x01) << 8);
113 self.w
114 }
115}
116impl R {
117 #[doc = "Bits 0:3 - Host Initiated Resume Duration - HW. This is the HIRD value from the last received LPM token"]
118 #[inline(always)]
119 pub fn hird_hw(&self) -> HIRD_HW_R {
120 HIRD_HW_R::new((self.bits & 0x0f) as u8)
121 }
122 #[doc = "Bits 4:7 - Host Initiated Resume Duration - SW. This is the time duration required by the USB device system to come out of LPM initiated suspend after receiving the host initiated LPM resume."]
123 #[inline(always)]
124 pub fn hird_sw(&self) -> HIRD_SW_R {
125 HIRD_SW_R::new(((self.bits >> 4) & 0x0f) as u8)
126 }
127 #[doc = "Bit 8 - As long as this bit is set to one and LPM supported bit is set to one, HW will return a NYET handshake on every LPM token it receives. If LPM supported bit is set to one and this bit is zero, HW will return an ACK handshake on every LPM token it receives. If SW has still data pending and LPM is supported, it must set this bit to 1."]
128 #[inline(always)]
129 pub fn data_pending(&self) -> DATA_PENDING_R {
130 DATA_PENDING_R::new(((self.bits >> 8) & 0x01) != 0)
131 }
132}
133impl W {
134 #[doc = "Bits 4:7 - Host Initiated Resume Duration - SW. This is the time duration required by the USB device system to come out of LPM initiated suspend after receiving the host initiated LPM resume."]
135 #[inline(always)]
136 pub fn hird_sw(&mut self) -> HIRD_SW_W {
137 HIRD_SW_W { w: self }
138 }
139 #[doc = "Bit 8 - As long as this bit is set to one and LPM supported bit is set to one, HW will return a NYET handshake on every LPM token it receives. If LPM supported bit is set to one and this bit is zero, HW will return an ACK handshake on every LPM token it receives. If SW has still data pending and LPM is supported, it must set this bit to 1."]
140 #[inline(always)]
141 pub fn data_pending(&mut self) -> DATA_PENDING_W {
142 DATA_PENDING_W { w: self }
143 }
144 #[doc = "Writes raw bits to the register."]
145 #[inline(always)]
146 pub unsafe fn bits(&mut self, bits: u32) -> &mut Self {
147 self.0.bits(bits);
148 self
149 }
150}
151#[doc = "USB Link Power Management register\n\nThis register you can [`read`](crate::pac::generic::generic::Reg::read), [`write_with_zero`](crate::pac::generic::generic::Reg::write_with_zero), [`reset`](crate::pac::generic::generic::Reg::reset), [`write`](crate::pac::generic::generic::Reg::write), [`modify`](crate::pac::generic::generic::Reg::modify). See [API](https://docs.rs/svd2rust/#read--modify--write-api).\n\nFor information about available fields see [lpm](index.html) module"]
152pub struct LPM_SPEC;
153impl crate::pac::generic::RegisterSpec for LPM_SPEC {
154 type Ux = u32;
155}
156#[doc = "`read()` method returns [lpm::R](R) reader structure"]
157impl crate::pac::generic::Readable for LPM_SPEC {
158 type Reader = R;
159}
160#[doc = "`write(|w| ..)` method takes [lpm::W](W) writer structure"]
161impl crate::pac::generic::Writable for LPM_SPEC {
162 type Writer = W;
163}
164#[doc = "`reset()` method sets LPM to value 0"]
165impl crate::pac::generic::Resettable for LPM_SPEC {
166 #[inline(always)]
167 fn reset_value() -> Self::Ux {
168 0
169 }
170}