Project

General

Profile

DevelopersDriverNotes » History » Version 3

Dan Smith, 12/26/2024 04:53 PM

1 1 Dan Smith
This is a set of notes about complex driver situations to help with consistency.
2
3
## Implied modes
4
5
Some radios have an annoying behavior where they determine the mode for a channel based on frequency. This is most commonly used to allow AM for airband frequencies, where the radio does not actually store a bit for "mode is AM" but instead just forces the receiver into AM mode in that range.
6
7
Using the airband example, this should be handled by the driver with the following steps:
8
9
- Expose `AM` as an option in `valid_modes`.
10
- Coerce the `Memory.mode` value to `AM` when the frequency is with in the airband range.
11
- Implement `validate_memory()` to check that `Memory.mode` is `AM` in the airband range, and `FM` in all other ranges. If there is a mismatch, return a `chirp_common.ValidationWarning` to indicate to the user that the mismatch will be corrected by the driver.
12
13
Here is an example `validate_memory()` implementation. Try to re-use the same exact strings to minimize translation overhead:
14
15
```
16
    AIRBAND = (118000000, 136000000)
17
    def validate_memory(self, mem):
18
        msgs = []
19
        in_range = chirp_common.in_range
20
        if in_range(mem.freq, [AIRBAND]) and not mem.mode == 'AM':
21
            msgs.append(chirp_common.ValidationWarning(
22
                _('Frequency in this range requires AM mode')))
23
        if not in_range(mem.freq, [AIRBAND]) and mem.mode == 'AM':
24
            msgs.append(chirp_common.ValidationWarning(
25
                _('Frequency in this range must not be AM mode')))
26
        return msgs + super().validate_memory(mem)
27
```
28
29
## Immutable memory fields
30
31
Immutable fields on a memory can be implemented by setting, for example, `mem.immutable = ['mode']` to prevent the `mode` from being changed. This should be used in cases where the radio has a special memory that has some required settings. Examples of where this is used:
32
33
- Some radios have a per-mode "call" special channel (i.e. `FM`, `DV`, etc) 
34
- Some radios have requirements that the first 22 channels be the GMRS channels where the name and power level are changeable by the user, but the frequency/duplex are not
35
36 2 Dan Smith
Effectively, the decision to mark a field as immutable should generally come down to "is this immutable because of the *location* of the memory?" If the fixed nature is related to other *content* of the memory (i.e. channels in the airband range must be `AM`, see above), then it's best to use `validate_memory()` to check/warn about a required value.
37 3 Dan Smith
38
## Radios that only support TX/RX frequency
39
40
CHIRP requires that drivers behave like a more conventional amateur radio and support Duplex/Offset at least. Supporting TX/RX frequencies with Duplex=split is also supported but Duplex=+/- is necessary. To do this, you should assume a TX/RX split of <= 70MHz to be a duplex mode. Greater separation should be implemented as Duplex=split. See `split_to_offset()` in source:chirp/chirp_common.py which you should use from your driver.