开云体育

ctrl + shift + ? for shortcuts
© 2025 开云体育

Has anyone fully decoded the X9000 memory mapping?


 

As a die hard analog dinosaur I concur. These beasts were built to survive, and have, I see you've found the RSS that allowed 32 MPL. I think that was the 255 mode version. As the fuzzy clears a bit from my memory, I made an error (or two or more...lol)
A 2k EEPROM can hold up to 64 (not 255) modes if one ventures above the 32nd mode's data space. An 8k EEPROM can hold up to 255 mode w/o the 255 RSS quirks if you venture above the (stock for and 8k) 64th mode's dataspace. The byte that sets the MPL count will go to FFh too, but I think you will run out of codeplug? before you get that many in. Also, I think the max modes the CH will handle w/alpha tags is 224 not 240.
As built? it is a challenge. You cant get to the EEPROM from the "outside" without complying with RSS/SB9600 rules and protocols, and that'a a whole 'nother can o' worms.
An in circuit EEPROM emulation scheme like Casey and Skip are referring to with a accessible port to the outside world, in the case of an ESP32, TCP/IP over WiFi has promise.
I'm not familiar with the ESP device(s), or it's IO capabilities. I had no idea it was a dual core uP at 270mhz.
. That smokes the Teensy devices I was looking at a few years back, although I bet it's a 3v device so there;s some level transition needed as well if so.





 

Casey, are you on the "emulate the exisiting EEPROM" path or the "hijack the synth registers and latches" path?


 

Emulation. It's the only viable option. Otherwise, you have to forego all the CTCSS/DCS, and whatever I/O and options the radio is capable of and reproduce them with other devices since the radio's uP does the signalling processing. I think using the radio's native capabilies is the simples, cleanest and most cost effective option.


 

Let's see... 2K x 8 requires 19 GPIO lines (11 address + 8 data). 8K
x 8 requires 21.

The ESP32-S3 (latest chip) has 45. That's the raw chip, the modules
use some of the GPIO internally and don't bring everything out. The
ESP32-S3-WROOM-1 module brings out 36 GPIOs.

My memory was faulty, it ONLY has 240 Mhz dual core CPUs, not 270. It
has WiFi and Bluetooth but the antenna is part of the module and RF
isn't going to get from a buttoned up case. Maybe far enough??
Personally I would prefer routing a serial port out like we did with
the Xcat rather than having an "intentional emitter" inside of the
radio.

GPIO0->GPIO7 - EEPROM data.
GPIO8->GPIO15 - bottom 8 bits of address line
GPIO16->GPIO20 - top 5 bits of address line
GPIO21 - chip select.

There are a couple of gotchas of course... The ESP32 is NOT 5 volt
tolerant so there would need to be some level conversion (just a bunch
of FETs perhaps?). Additionally some of the pins are strapping pins
that have special meaning at power up. For example if GPIO0 is held
low at reset then the ESP32 enters boot mode.

So my napkin says it can be done, but not as cleanly as just hooking
up the pins.

73's Skip WB6YMH

On Thu, Jul 28, 2022 at 10:04 PM Casey Crane <ccrane148@...> wrote:

Emulation. It's the only viable option. Otherwise, you have to forego all the CTCSS/DCS, and whatever I/O and options the radio is capable of and reproduce them with other devices since the radio's uP does the signalling processing. I think using the radio's native capabilies is the simples, cleanest and most cost effective option.


 

I just found this:??are you guy's aware of it?? I remember searching and searching for SB9600 "back in the day" and finding little., times have changed!

I think my Spectra speaks SB9600 ... I sense a time sink coming.

73's Skip WB6YMH



 

the second arduino which ingested that data and did the math to
> convert to the corresponding parallel data lines into the synthesizer
> divider.

What did you do about the VCO V-bits?

De


 

I will have to look at the data again but if I recall correctly it's part of the 4 but data word I believe. I recall doing a (if frequency is between.... Then bit high or low) type thing. It was then bit masked with the parallel data.?


 

I would prefer seeing the discussion.

Joe M.

On 7/28/2022 7:42 PM, Skip Hansen wrote:
Well, I'm the list owner and I have no objections. It's been a
pretty quiet list for many years. If anyone else has any issues let us
know.

73's Skip

On Thu, Jul 28, 2022 at 3:36 PM Bradley Andrews via groups.io
<kb9bpf@...> wrote:

I'm very interested in what you guys have to say so if it were up to me (it's not) I'd say go ahead and continue your discussion here. Isn't it as good a place as any? Does anyone object?

Brad
On Thursday, July 28, 2022, 04:31:17 PM CDT, Casey Crane <ccrane148@...> wrote:


Yes, exactly. The thing was amazingly fast. The "problem" is the radio took on the attributes of whatever mode was selected at the time. So, if mode 1 was selected, had a PL of 151.4 etc.... if I tuned away to a different frequency those attributes followed, being only the frequency was changing. It would basically require duplicating all the other features of the radio in hardware/software to take advantage of this method fully which is of course absurd.

My thought was to present the uProcessor with one mode's worth of data and then change that data dynamically, allowing the uP to do all the rest of the work. I have the service manual and it appears it has a strobe line which basically thumbs through pages of the eeprom grabbing data for different modes. If it were fed data that we could dynamically update despite whatever mode (eeprom data offset) it's looking for then we could control it all.

As said earlier, life has taken priority and caused a stall on the project but I do have some very nice code I came up with for the Raspberry Pi which I think could be used to feed an arduino as an internal decoder resulting in a very nice full color capacitive touch screen 4.3" user control interface with infinitely configurable mode names, scan lists, search parameters etc... all fed to the radio via a simple lightweight serial interface or perhaps even via one of the bluetooth serial dongle boards leaving only audio paths to be dealt with.

As the solar cycle has heated up it's something that has got me thinking about it all again.

I just don't know if this is the place to discuss it and I don't want to infringe or step on any toes regarding the project this group is about so I should probably start another group so as not to clutter this one.

Casey



On Thu, Jul 28, 2022 at 4:16 PM swguest via groups.io <swguest@...> wrote:

Bradley,
Let me see what I can find. This was an X9000 but hardware wise at the point he made the connections the X and the X9000 *should* be the same animal. You will need service manuals for both to pursue the project.

He basicly severed the uC's data/control lines to the synthesizer and injected data calculated by his arduino from info Mike B. shared about the radio's divider/synthesizer operational process.

Again, POC. It would still take a fair amount of designing to hammer out the details and make an operational radio that doesnt resemble an alien autopsy.





 

Skip,
? Yup that got a lotta lotta good info in it......and? yes Spectras, A/S, MCS/MTS, and a lot more speak SB9600. To fully appreciate the coms you need to hook up your Spectra to your PC via you RIB and run a proggy called Mototools, the push some buttons etc on your Spectra and see the SB9600 coms in action. Casey prolly has that proggy handy for U/L. I'd have to search a few offline USB devices.........
I'm compiling some Q's regarding the ESP.....





 

Dennis,
? I dont recall the particulars of the reg/latch sequence. I'm not sure his code addressed them. However he was rx'ing in the 10m band so they apparently were in the correct 1 of the 4 possible state for a LB radio.
Yup, those V0/V1 bits can be a gotcha if you dont pay attention...lol


 

Jeez Casey,
I looked back thru my "archives". Mike's post on the Synth control was 10 years ago this passed Christmas. He call them out in the sequence but didnt make the definition, except 800 Mhz? radios didnt use them.
I guess you determined what they needed to be per the operating freq(s) you were using when you electrified your Frankenstein.
In a real world situation the RSS is hard coded to set those per the engineered "switchpoints".
There was another aspect to the hacked HAM RSS that added some 2m and and 70cm bandsplits where those were edited accordingly.
I wondered if those guys that had issues with a getting a range 2 VHF to move low enough for a stable VCO lock would have benefitted from altering those to suit.


 

Skip,
?I dont know if I ticked "Notify Members" in time. I had already hit upload.....
Anyway Mototools is now in the files section...unless you mod the uploads...I didnt think about that.


 

There was another aspect to the hacked HAM RSS that added some 2m and
> and 70cm bandsplits where those were edited accordingly. I wondered
> if those guys that had issues with a getting a range 2 VHF to move
> low enough for a stable VCO lock would have benefitted from altering
> those to suit.

IIRC that configuration of that hacked RSS was sometimes referred to as
"Range 1.5". It had its v-bit splits modified to support the ham band,
but the retuned radio would have to be compatible with the implemented
ranges in order to get working results. I.e. you'd have to reconfigure
the VCO capacitors to get lock, as well as retuning (probably both sets
of) filters.

This is why syntorxgen lets you set your own v-bit splits. (It'll also
let you invert which setup is used for transmit, and which receive,
because it looked to me like that might enable converting a UHF T-band
VCO for use around 420-440. The Range 1 radio won't go high enough for
that. Some ham UHF link channels around here are in the low 430s.)

De


 

Dennis,
Yup, That was it Range 1.5. It didnt add a 2m enhancement as well? - Acute CRS. I hope I never get called as an eye witness...lol? I have not looked at that RSS in some time.

I've never seen a range I UHF. I know they exist and use Hi side injection while all the rest of the UHF ranges use Low side. I wasnt aware it fell short in the 430 portion.

Using a "flipped" T-band radio is an awesome idea for link radios presuming the filters will move down there.


 

Would love to see something arduino/pi based on these things.? ?I don't see a whole ton of Syntor X9000's in the wild -- I'm actually actively trying to liberate one from an in-service fire truck (I run a two-way shop) which I've been given full permission to do; however,need to remove the seats and parts of the interior to do so that require drilling out one-time-use pop-in retainers etc...? ??

I always wanted to find a way to remotely operate one of these with the ability to remotely switch between antennas (10M/6M) and Allstarlink gave me a good method to at least get the audio back and forth; however, the remote VCO control has had me using Maratracs (not a bad rig, but, limited to using BCD controls)? and I did come up with a way to re-program the radio remotely, and while that does give me *some* flexibility, it's not what i'd call 'agile' by any means!?


Sincerely,
Lee M. Lemoine
N3LEE - Amateur Radio
"Experience is something you don't get until just after you need it."


On Fri, Jul 29, 2022 at 1:45 PM Joe M. <mch@...> wrote:
I would prefer seeing the discussion.

Joe M.

On 7/28/2022 7:42 PM, Skip Hansen wrote:
> Well, I'm the list owner and I have no objections.? ?It's been a
> pretty quiet list for many years. If anyone else has any issues let us
> know.
>
> 73's Skip
>
> On Thu, Jul 28, 2022 at 3:36 PM Bradley Andrews via
> <kb9bpf=[email protected]> wrote:
>>
>> I'm very interested in what you guys have to say so if it were up to me (it's not) I'd say go ahead and continue your discussion here. Isn't it as good a place as any? Does anyone object?
>>
>> Brad
>> On Thursday, July 28, 2022, 04:31:17 PM CDT, Casey Crane <ccrane148@...> wrote:
>>
>>
>> Yes, exactly. The thing was amazingly fast. The "problem" is the radio took on the attributes of whatever mode was selected at the time. So, if mode 1 was selected, had a PL of 151.4 etc.... if I tuned away to a different frequency those attributes followed, being only the frequency was changing. It would basically require duplicating all the other features of the radio in hardware/software to take advantage of this method fully which is of course absurd.
>>
>> My thought was to present the uProcessor with one mode's worth of data and then change that data dynamically, allowing the uP to do all the rest of the work. I have the service manual and it appears it has a strobe line which basically thumbs through pages of the eeprom grabbing data for different modes. If it were fed data that we could dynamically update despite whatever mode (eeprom data offset) it's looking for then we could control it all.
>>
>> As said earlier, life has taken priority and caused a stall on the project but I do have some very nice code I came up with for the Raspberry Pi which I think could be used to feed an arduino as an internal decoder resulting in a very nice full color capacitive touch screen 4.3" user control interface with infinitely configurable mode names, scan lists, search parameters etc... all fed to the radio via a simple lightweight serial interface or perhaps even via one of the bluetooth serial dongle boards leaving only audio paths to be dealt with.
>>
>> As the solar cycle has heated up it's something that has got me thinking about it all again.
>>
>> I just don't know if this is the place to discuss it and I don't want to infringe or step on any toes regarding the project this group is about so I should probably start another group so as not to clutter this one.
>>
>> Casey
>>
>>
>>
>> On Thu, Jul 28, 2022 at 4:16 PM swguest via <swguest=[email protected]> wrote:
>>
>> Bradley,
>>? ? Let me see what I can find. This was an X9000 but hardware wise at the point he made the connections the X and the X9000 *should* be the same animal. You will need service manuals for both to pursue the project.
>>
>> He basicly severed the uC's data/control lines to the synthesizer and injected data calculated by his arduino from info Mike B. shared about the radio's divider/synthesizer operational process.
>>
>> Again, POC. It would still take a fair amount of designing to hammer out the details and make an operational radio that doesnt resemble an alien autopsy.
>>
>>
>
>
>
>
>
>






 

Well I can see it, hopefully others can as well.? I think you have to be a member of the list to see files, I tried a different account but I don't even see the files tag on the left.

Thanks, I was starting to google for mototools.? I did see my RIB when I was looking for the Xcats and I even remember (I hope) where it was.

Skip


 

Yup, That was it Range 1.5. It didnt add a 2m enhancement as well? -
> Acute CRS. I hope I never get called as an eye witness...lol I have
> not looked at that RSS in some time.

Pretty sure it enabled direct frequency entry as well. But I never used
it, as I wrote syntorxgen first, when I started playing with the radios.

> I've never seen a range I UHF. I know they exist and use Hi side
> injection while all the rest of the UHF ranges use Low side. I wasnt
> aware it fell short in the 430 portion.

Years ago we had a need for a packet link in the low 430s, and being a
Syntor X nut, I obtained to try to retune it. They just won't go high
enough. Sad face.

> Using a "flipped" T-band radio is an awesome idea for link radios
> presuming the filters will move down there.

I figured fiddling with those might be necessary too, but I never found
a T-band radio to play with. Would still be a fun project. Speaking of
CRS, I can't remember now whether I was planning to just modify the
T-bander, or move its VCO into a Range 1.

De


 

Yea I believe I used the data from the service manual which defines the vco range splits. Been a minute hah...?


On Fri, Jul 29, 2022, 14:45 swguest via <swguest=[email protected]> wrote:
Jeez Casey,
I looked back thru my "archives". Mike's post on the Synth control was 10 years ago this passed Christmas. He call them out in the sequence but didnt make the definition, except 800 Mhz? radios didnt use them.
I guess you determined what they needed to be per the operating freq(s) you were using when you electrified your Frankenstein.
In a real world situation the RSS is hard coded to set those per the engineered "switchpoints".
There was another aspect to the hacked HAM RSS that added some 2m and and 70cm bandsplits where those were edited accordingly.
I wondered if those guys that had issues with a getting a range 2 VHF to move low enough for a stable VCO lock would have benefitted from altering those to suit.


 

Lee,
?Not to discourage you from getting your hands on that X9000, but have you seen/hard about a project called Maxduino?


 

@ Skip...it's in the files section, at least I can see it bt I uploaded it. Did I need to set a global flag or someyhing?
PS Can I upload some non X/X9000 stuf for Lee if he is interested? I also found a .pdf I generated from the site that had the SyntorX codeplug breakdown...dont recall the authors but need to credit them if you allow me to upload it.
@ Casey....yeah just glimpsed you code...it's there...............
@ Dennis....I've passed up T-Band stuff, including X family radios. Back when TV was analog, and men were men and however else that goes...Houston had both a ch14 and a ch 20 so anything 470-512 was pretty much useless.
I never considered flipping one for link service.