VMemory

Struct VMemory 

Source
struct VMemory {
Show 15 fields a_register: Unsigned36Bit, b_register: Unsigned36Bit, c_register: Unsigned36Bit, d_register: Unsigned36Bit, e_register: Unsigned36Bit, m_register_metabit: bool, unimplemented_shaft_encoder: MemoryWord, unimplemented_external_input_register: MemoryWord, rtc: MemoryWord, rtc_start: Duration, codabo_start_point: [Unsigned36Bit; 8], plugboard: [Unsigned36Bit; 32], permit_unknown_reads: bool, sacrificial_word_for_unknown_reads: MemoryWord, sacrificial_metabit: bool,
}
Expand description

The TX-2’s V-memory.

§Metabits

Arithmetic registers have no meta bit. Accesses which attempt to read the meta bit of registers A, B, , D, E actually return the meta bit in the M register. This is briefly described on page 5-23 of the User Handbook.

It says,

The data reference metabit (M⁴˙¹⁰) can be detected only when set (just as N⁴˙¹⁰ above). Note that it can be changed without a memory reference for it serves as the metabit of the A, B, C, D, and E registers. (i.e., MKC₄.₁₀ A or MKC₄.₁₀ B will change bit 4.10 of M).“

V memory in general does behave as if it has a meta bit. For example, there is a push-button on the console that acts as the value of the meta bit of the shaft encoder register.

See also https://github.com/TX-2/TX-2-simulator/issues/59.

Fields§

§a_register: Unsigned36Bit§b_register: Unsigned36Bit§c_register: Unsigned36Bit§d_register: Unsigned36Bit§e_register: Unsigned36Bit§m_register_metabit: bool§unimplemented_shaft_encoder: MemoryWord§unimplemented_external_input_register: MemoryWord§rtc: MemoryWord§rtc_start: Duration§codabo_start_point: [Unsigned36Bit; 8]§plugboard: [Unsigned36Bit; 32]§permit_unknown_reads: bool

Writes to unknown locations are required to be ignored, but reads have to return a value. If permit_unknown_reads is set, a special value is returned. If not, a QSAL alarm will be raised (though that alarm may in turn be suppressed).

§sacrificial_word_for_unknown_reads: MemoryWord§sacrificial_metabit: bool

Implementations§

Source§

impl VMemory

Source

fn new(ctx: &Context) -> VMemory

Source

fn get_a_register(&self) -> Unsigned36Bit

Source

fn get_b_register(&self) -> Unsigned36Bit

Source

fn get_c_register(&self) -> Unsigned36Bit

Source

fn get_d_register(&self) -> Unsigned36Bit

Source

fn get_e_register(&self) -> Unsigned36Bit

Source

fn set_a_register(&mut self, value: Unsigned36Bit)

Source

fn set_b_register(&mut self, value: Unsigned36Bit)

Source

fn set_c_register(&mut self, value: Unsigned36Bit)

Source

fn set_d_register(&mut self, value: Unsigned36Bit)

Source

fn set_e_register(&mut self, value: Unsigned36Bit)

Source

fn read_access<'a>( &'a mut self, ctx: &Context, addr: &Address, ) -> Result<MemoryReadRef<'a>, MemoryOpFailure>

Perform a memory read.

Source

fn write_access<'a>( &'a mut self, _ctx: &Context, addr: &Address, ) -> Result<Option<MemoryWriteRef<'a>>, MemoryOpFailure>

Perform a memory write. Return a mutable reference to the memory word being accessed or, if this is an attempt to write to a read-only location, return None.

Source

fn reset_rtc(&mut self, ctx: &Context)

Source

fn update_rtc(&mut self, ctx: &Context)

Trait Implementations§

Source§

impl Debug for VMemory

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
§

impl<Src, Scheme> ApproxFrom<Src, Scheme> for Src
where Scheme: ApproxScheme,

§

type Err = NoError

The error type produced by a failed conversion.
§

fn approx_from(src: Src) -> Result<Src, <Src as ApproxFrom<Src, Scheme>>::Err>

Convert the given value into an approximately equivalent representation.
§

impl<Dst, Src, Scheme> ApproxInto<Dst, Scheme> for Src
where Dst: ApproxFrom<Src, Scheme>, Scheme: ApproxScheme,

§

type Err = <Dst as ApproxFrom<Src, Scheme>>::Err

The error type produced by a failed conversion.
§

fn approx_into(self) -> Result<Dst, <Src as ApproxInto<Dst, Scheme>>::Err>

Convert the subject into an approximately equivalent representation.
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
§

impl<T, Dst> ConvAsUtil<Dst> for T

§

fn approx(self) -> Result<Dst, Self::Err>
where Self: Sized + ApproxInto<Dst>,

Approximate the subject with the default scheme.
§

fn approx_by<Scheme>(self) -> Result<Dst, Self::Err>
where Self: Sized + ApproxInto<Dst, Scheme>, Scheme: ApproxScheme,

Approximate the subject with a specific scheme.
§

impl<T> ConvUtil for T

§

fn approx_as<Dst>(self) -> Result<Dst, Self::Err>
where Self: Sized + ApproxInto<Dst>,

Approximate the subject to a given type with the default scheme.
§

fn approx_as_by<Dst, Scheme>(self) -> Result<Dst, Self::Err>
where Self: Sized + ApproxInto<Dst, Scheme>, Scheme: ApproxScheme,

Approximate the subject to a given type with a specific scheme.
§

fn into_as<Dst>(self) -> Dst
where Self: Sized + Into<Dst>,

Convert the subject to a given type.
§

fn try_as<Dst>(self) -> Result<Dst, Self::Err>
where Self: Sized + TryInto<Dst>,

Attempt to convert the subject to a given type.
§

fn value_as<Dst>(self) -> Result<Dst, Self::Err>
where Self: Sized + ValueInto<Dst>,

Attempt a value conversion of the subject to a given type.
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

§

impl<T> Instrument for T

§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided [Span], returning an Instrumented wrapper. Read more
§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

§

impl<Src> TryFrom<Src> for Src

§

type Err = NoError

The error type produced by a failed conversion.
§

fn try_from(src: Src) -> Result<Src, <Src as TryFrom<Src>>::Err>

Convert the given value into the subject type.
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
§

impl<Src, Dst> TryInto<Dst> for Src
where Dst: TryFrom<Src>,

§

type Err = <Dst as TryFrom<Src>>::Err

The error type produced by a failed conversion.
§

fn try_into(self) -> Result<Dst, <Src as TryInto<Dst>>::Err>

Convert the subject into the destination type.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
§

impl<Src> ValueFrom<Src> for Src

§

type Err = NoError

The error type produced by a failed conversion.
§

fn value_from(src: Src) -> Result<Src, <Src as ValueFrom<Src>>::Err>

Convert the given value into an exactly equivalent representation.
§

impl<Src, Dst> ValueInto<Dst> for Src
where Dst: ValueFrom<Src>,

§

type Err = <Dst as ValueFrom<Src>>::Err

The error type produced by a failed conversion.
§

fn value_into(self) -> Result<Dst, <Src as ValueInto<Dst>>::Err>

Convert the subject into an exactly equivalent representation.
§

impl<T> WithSubscriber for T

§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a [WithDispatch] wrapper. Read more
§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a [WithDispatch] wrapper. Read more
§

impl<T> ErasedDestructor for T
where T: 'static,