#[doc = "Reader of register IOGCSR"]
pub type R = crate::R<u32, super::IOGCSR>;
#[doc = "Writer for register IOGCSR"]
pub type W = crate::W<u32, super::IOGCSR>;
#[doc = "Register IOGCSR `reset()`'s with value 0"]
impl crate::ResetValue for super::IOGCSR {
type Type = u32;
#[inline(always)]
fn reset_value() -> Self::Type {
0
}
}
#[doc = "Reader of field `G8S`"]
pub type G8S_R = crate::R<bool, bool>;
#[doc = "Write proxy for field `G8S`"]
pub struct G8S_W<'a> {
w: &'a mut W,
}
impl<'a> G8S_W<'a> {
#[doc = r"Sets the field bit"]
#[inline(always)]
pub fn set_bit(self) -> &'a mut W {
self.bit(true)
}
#[doc = r"Clears the field bit"]
#[inline(always)]
pub fn clear_bit(self) -> &'a mut W {
self.bit(false)
}
#[doc = r"Writes raw bits to the field"]
#[inline(always)]
pub fn bit(self, value: bool) -> &'a mut W {
self.w.bits = (self.w.bits & !(0x01 << 23)) | (((value as u32) & 0x01) << 23);
self.w
}
}
#[doc = "Reader of field `G7S`"]
pub type G7S_R = crate::R<bool, bool>;
#[doc = "Write proxy for field `G7S`"]
pub struct G7S_W<'a> {
w: &'a mut W,
}
impl<'a> G7S_W<'a> {
#[doc = r"Sets the field bit"]
#[inline(always)]
pub fn set_bit(self) -> &'a mut W {
self.bit(true)
}
#[doc = r"Clears the field bit"]
#[inline(always)]
pub fn clear_bit(self) -> &'a mut W {
self.bit(false)
}
#[doc = r"Writes raw bits to the field"]
#[inline(always)]
pub fn bit(self, value: bool) -> &'a mut W {
self.w.bits = (self.w.bits & !(0x01 << 22)) | (((value as u32) & 0x01) << 22);
self.w
}
}
#[doc = "Reader of field `G6S`"]
pub type G6S_R = crate::R<bool, bool>;
#[doc = "Reader of field `G5S`"]
pub type G5S_R = crate::R<bool, bool>;
#[doc = "Reader of field `G4S`"]
pub type G4S_R = crate::R<bool, bool>;
#[doc = "Reader of field `G3S`"]
pub type G3S_R = crate::R<bool, bool>;
#[doc = "Reader of field `G2S`"]
pub type G2S_R = crate::R<bool, bool>;
#[doc = "Reader of field `G1S`"]
pub type G1S_R = crate::R<bool, bool>;
#[doc = "Reader of field `G8E`"]
pub type G8E_R = crate::R<bool, bool>;
#[doc = "Write proxy for field `G8E`"]
pub struct G8E_W<'a> {
w: &'a mut W,
}
impl<'a> G8E_W<'a> {
#[doc = r"Sets the field bit"]
#[inline(always)]
pub fn set_bit(self) -> &'a mut W {
self.bit(true)
}
#[doc = r"Clears the field bit"]
#[inline(always)]
pub fn clear_bit(self) -> &'a mut W {
self.bit(false)
}
#[doc = r"Writes raw bits to the field"]
#[inline(always)]
pub fn bit(self, value: bool) -> &'a mut W {
self.w.bits = (self.w.bits & !(0x01 << 7)) | (((value as u32) & 0x01) << 7);
self.w
}
}
#[doc = "Reader of field `G7E`"]
pub type G7E_R = crate::R<bool, bool>;
#[doc = "Write proxy for field `G7E`"]
pub struct G7E_W<'a> {
w: &'a mut W,
}
impl<'a> G7E_W<'a> {
#[doc = r"Sets the field bit"]
#[inline(always)]
pub fn set_bit(self) -> &'a mut W {
self.bit(true)
}
#[doc = r"Clears the field bit"]
#[inline(always)]
pub fn clear_bit(self) -> &'a mut W {
self.bit(false)
}
#[doc = r"Writes raw bits to the field"]
#[inline(always)]
pub fn bit(self, value: bool) -> &'a mut W {
self.w.bits = (self.w.bits & !(0x01 << 6)) | (((value as u32) & 0x01) << 6);
self.w
}
}
#[doc = "Reader of field `G6E`"]
pub type G6E_R = crate::R<bool, bool>;
#[doc = "Write proxy for field `G6E`"]
pub struct G6E_W<'a> {
w: &'a mut W,
}
impl<'a> G6E_W<'a> {
#[doc = r"Sets the field bit"]
#[inline(always)]
pub fn set_bit(self) -> &'a mut W {
self.bit(true)
}
#[doc = r"Clears the field bit"]
#[inline(always)]
pub fn clear_bit(self) -> &'a mut W {
self.bit(false)
}
#[doc = r"Writes raw bits to the field"]
#[inline(always)]
pub fn bit(self, value: bool) -> &'a mut W {
self.w.bits = (self.w.bits & !(0x01 << 5)) | (((value as u32) & 0x01) << 5);
self.w
}
}
#[doc = "Reader of field `G5E`"]
pub type G5E_R = crate::R<bool, bool>;
#[doc = "Write proxy for field `G5E`"]
pub struct G5E_W<'a> {
w: &'a mut W,
}
impl<'a> G5E_W<'a> {
#[doc = r"Sets the field bit"]
#[inline(always)]
pub fn set_bit(self) -> &'a mut W {
self.bit(true)
}
#[doc = r"Clears the field bit"]
#[inline(always)]
pub fn clear_bit(self) -> &'a mut W {
self.bit(false)
}
#[doc = r"Writes raw bits to the field"]
#[inline(always)]
pub fn bit(self, value: bool) -> &'a mut W {
self.w.bits = (self.w.bits & !(0x01 << 4)) | (((value as u32) & 0x01) << 4);
self.w
}
}
#[doc = "Reader of field `G4E`"]
pub type G4E_R = crate::R<bool, bool>;
#[doc = "Write proxy for field `G4E`"]
pub struct G4E_W<'a> {
w: &'a mut W,
}
impl<'a> G4E_W<'a> {
#[doc = r"Sets the field bit"]
#[inline(always)]
pub fn set_bit(self) -> &'a mut W {
self.bit(true)
}
#[doc = r"Clears the field bit"]
#[inline(always)]
pub fn clear_bit(self) -> &'a mut W {
self.bit(false)
}
#[doc = r"Writes raw bits to the field"]
#[inline(always)]
pub fn bit(self, value: bool) -> &'a mut W {
self.w.bits = (self.w.bits & !(0x01 << 3)) | (((value as u32) & 0x01) << 3);
self.w
}
}
#[doc = "Reader of field `G3E`"]
pub type G3E_R = crate::R<bool, bool>;
#[doc = "Write proxy for field `G3E`"]
pub struct G3E_W<'a> {
w: &'a mut W,
}
impl<'a> G3E_W<'a> {
#[doc = r"Sets the field bit"]
#[inline(always)]
pub fn set_bit(self) -> &'a mut W {
self.bit(true)
}
#[doc = r"Clears the field bit"]
#[inline(always)]
pub fn clear_bit(self) -> &'a mut W {
self.bit(false)
}
#[doc = r"Writes raw bits to the field"]
#[inline(always)]
pub fn bit(self, value: bool) -> &'a mut W {
self.w.bits = (self.w.bits & !(0x01 << 2)) | (((value as u32) & 0x01) << 2);
self.w
}
}
#[doc = "Reader of field `G2E`"]
pub type G2E_R = crate::R<bool, bool>;
#[doc = "Write proxy for field `G2E`"]
pub struct G2E_W<'a> {
w: &'a mut W,
}
impl<'a> G2E_W<'a> {
#[doc = r"Sets the field bit"]
#[inline(always)]
pub fn set_bit(self) -> &'a mut W {
self.bit(true)
}
#[doc = r"Clears the field bit"]
#[inline(always)]
pub fn clear_bit(self) -> &'a mut W {
self.bit(false)
}
#[doc = r"Writes raw bits to the field"]
#[inline(always)]
pub fn bit(self, value: bool) -> &'a mut W {
self.w.bits = (self.w.bits & !(0x01 << 1)) | (((value as u32) & 0x01) << 1);
self.w
}
}
#[doc = "Reader of field `G1E`"]
pub type G1E_R = crate::R<bool, bool>;
#[doc = "Write proxy for field `G1E`"]
pub struct G1E_W<'a> {
w: &'a mut W,
}
impl<'a> G1E_W<'a> {
#[doc = r"Sets the field bit"]
#[inline(always)]
pub fn set_bit(self) -> &'a mut W {
self.bit(true)
}
#[doc = r"Clears the field bit"]
#[inline(always)]
pub fn clear_bit(self) -> &'a mut W {
self.bit(false)
}
#[doc = r"Writes raw bits to the field"]
#[inline(always)]
pub fn bit(self, value: bool) -> &'a mut W {
self.w.bits = (self.w.bits & !0x01) | ((value as u32) & 0x01);
self.w
}
}
impl R {
#[doc = "Bit 23 - Analog I/O group x status"]
#[inline(always)]
pub fn g8s(&self) -> G8S_R {
G8S_R::new(((self.bits >> 23) & 0x01) != 0)
}
#[doc = "Bit 22 - Analog I/O group x status"]
#[inline(always)]
pub fn g7s(&self) -> G7S_R {
G7S_R::new(((self.bits >> 22) & 0x01) != 0)
}
#[doc = "Bit 21 - Analog I/O group x status"]
#[inline(always)]
pub fn g6s(&self) -> G6S_R {
G6S_R::new(((self.bits >> 21) & 0x01) != 0)
}
#[doc = "Bit 20 - Analog I/O group x status"]
#[inline(always)]
pub fn g5s(&self) -> G5S_R {
G5S_R::new(((self.bits >> 20) & 0x01) != 0)
}
#[doc = "Bit 19 - Analog I/O group x status"]
#[inline(always)]
pub fn g4s(&self) -> G4S_R {
G4S_R::new(((self.bits >> 19) & 0x01) != 0)
}
#[doc = "Bit 18 - Analog I/O group x status"]
#[inline(always)]
pub fn g3s(&self) -> G3S_R {
G3S_R::new(((self.bits >> 18) & 0x01) != 0)
}
#[doc = "Bit 17 - Analog I/O group x status"]
#[inline(always)]
pub fn g2s(&self) -> G2S_R {
G2S_R::new(((self.bits >> 17) & 0x01) != 0)
}
#[doc = "Bit 16 - Analog I/O group x status"]
#[inline(always)]
pub fn g1s(&self) -> G1S_R {
G1S_R::new(((self.bits >> 16) & 0x01) != 0)
}
#[doc = "Bit 7 - Analog I/O group x enable"]
#[inline(always)]
pub fn g8e(&self) -> G8E_R {
G8E_R::new(((self.bits >> 7) & 0x01) != 0)
}
#[doc = "Bit 6 - Analog I/O group x enable"]
#[inline(always)]
pub fn g7e(&self) -> G7E_R {
G7E_R::new(((self.bits >> 6) & 0x01) != 0)
}
#[doc = "Bit 5 - Analog I/O group x enable"]
#[inline(always)]
pub fn g6e(&self) -> G6E_R {
G6E_R::new(((self.bits >> 5) & 0x01) != 0)
}
#[doc = "Bit 4 - Analog I/O group x enable"]
#[inline(always)]
pub fn g5e(&self) -> G5E_R {
G5E_R::new(((self.bits >> 4) & 0x01) != 0)
}
#[doc = "Bit 3 - Analog I/O group x enable"]
#[inline(always)]
pub fn g4e(&self) -> G4E_R {
G4E_R::new(((self.bits >> 3) & 0x01) != 0)
}
#[doc = "Bit 2 - Analog I/O group x enable"]
#[inline(always)]
pub fn g3e(&self) -> G3E_R {
G3E_R::new(((self.bits >> 2) & 0x01) != 0)
}
#[doc = "Bit 1 - Analog I/O group x enable"]
#[inline(always)]
pub fn g2e(&self) -> G2E_R {
G2E_R::new(((self.bits >> 1) & 0x01) != 0)
}
#[doc = "Bit 0 - Analog I/O group x enable"]
#[inline(always)]
pub fn g1e(&self) -> G1E_R {
G1E_R::new((self.bits & 0x01) != 0)
}
}
impl W {
#[doc = "Bit 23 - Analog I/O group x status"]
#[inline(always)]
pub fn g8s(&mut self) -> G8S_W {
G8S_W { w: self }
}
#[doc = "Bit 22 - Analog I/O group x status"]
#[inline(always)]
pub fn g7s(&mut self) -> G7S_W {
G7S_W { w: self }
}
#[doc = "Bit 7 - Analog I/O group x enable"]
#[inline(always)]
pub fn g8e(&mut self) -> G8E_W {
G8E_W { w: self }
}
#[doc = "Bit 6 - Analog I/O group x enable"]
#[inline(always)]
pub fn g7e(&mut self) -> G7E_W {
G7E_W { w: self }
}
#[doc = "Bit 5 - Analog I/O group x enable"]
#[inline(always)]
pub fn g6e(&mut self) -> G6E_W {
G6E_W { w: self }
}
#[doc = "Bit 4 - Analog I/O group x enable"]
#[inline(always)]
pub fn g5e(&mut self) -> G5E_W {
G5E_W { w: self }
}
#[doc = "Bit 3 - Analog I/O group x enable"]
#[inline(always)]
pub fn g4e(&mut self) -> G4E_W {
G4E_W { w: self }
}
#[doc = "Bit 2 - Analog I/O group x enable"]
#[inline(always)]
pub fn g3e(&mut self) -> G3E_W {
G3E_W { w: self }
}
#[doc = "Bit 1 - Analog I/O group x enable"]
#[inline(always)]
pub fn g2e(&mut self) -> G2E_W {
G2E_W { w: self }
}
#[doc = "Bit 0 - Analog I/O group x enable"]
#[inline(always)]
pub fn g1e(&mut self) -> G1E_W {
G1E_W { w: self }
}
}