Feature: Add support for HC11 microcontrollers

This commit is contained in:
GaryOderNichts 2023-03-06 00:12:25 +01:00
parent a9baf9f6d8
commit aaf6337040
8 changed files with 2613 additions and 0 deletions

View File

View File

@ -0,0 +1,23 @@
/* ###
* IP: GHIDRA
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
apply from: "$rootProject.projectDir/gradle/distributableGhidraModule.gradle"
apply from: "$rootProject.projectDir/gradle/processorProject.gradle"
apply plugin: 'eclipse'
eclipse.project.name = 'Processors HC11'
sleighCompileOptions = [
'-l'
]

View File

@ -0,0 +1,7 @@
##VERSION: 2.0
Module.manifest||GHIDRA||||END|
data/languages/HC11.cspec||GHIDRA||||END|
data/languages/HC11.ldefs||GHIDRA||||END|
data/languages/HC11.opinion||GHIDRA||||END|
data/languages/HC11.pspec||GHIDRA||||END|
data/languages/HC11.slaspec||GHIDRA||||END|

View File

@ -0,0 +1,58 @@
<?xml version="1.0" encoding="UTF-8"?>
<compiler_spec>
<data_organization> <!-- These tags need to be verified -->
<absolute_max_alignment value="0" />
<machine_alignment value="1" />
<default_alignment value="1" />
<pointer_size value="2" />
<wchar_size value="4" />
<short_size value="2" />
<integer_size value="4" />
<long_size value="4" />
<long_long_size value="8" />
<float_size value="4" />
<double_size value="8" />
<long_double_size value="8" />
</data_organization>
<global>
<range space="RAM"/>
</global>
<stackpointer register="SP" space="RAM" growth="negative"/>
<default_proto>
<prototype name="__asmA" extrapop="2" stackshift="2" strategy="register">
<input>
<pentry minsize="1" maxsize="1">
<register name="A"/>
</pentry>
<pentry minsize="1" maxsize="1">
<register name="B"/>
</pentry>
<pentry minsize="2" maxsize="2">
<register name="D"/>
</pentry>
<pentry minsize="1" maxsize="2">
<register name="IY"/>
</pentry>
<pentry minsize="1" maxsize="2">
<register name="IX"/>
</pentry>
<pentry minsize="1" maxsize="500" align="1">
<addr offset="2" space="stack"/>
</pentry>
</input>
<output>
<pentry minsize="1" maxsize="2">
<register name="D"/>
</pentry>
</output>
<unaffected>
<register name="SP"/>
</unaffected>
</prototype>
</default_proto>
</compiler_spec>

View File

@ -0,0 +1,16 @@
<?xml version="1.0" encoding="UTF-8"?>
<language_definitions>
<language processor="HC-11"
endian="big"
size="16"
variant="default"
version="2.0"
slafile="HC11.sla"
processorspec="HC11.pspec"
id="HC-11:BE:16:default">
<description>HC11 Microcontroller Family</description>
<compiler name="default" spec="HC11.cspec" id="default"/>
<external_name tool="gnu" name="m68hc11"/>
</language>
</language_definitions>

View File

@ -0,0 +1,5 @@
<opinions>
<constraint loader="Executable and Linking Format (ELF)" compilerSpecID="default">
<constraint primary="70" processor="HC11" endian="big" size="16" variant="default"/>
</constraint>
</opinions>

View File

@ -0,0 +1,40 @@
<?xml version="1.0" encoding="UTF-8"?>
<processor_spec>
<programcounter register="PC"/>
<default_symbols>
<symbol name="VECTOR_Reset" address="FFFE" entry="true" type="code_ptr"/>
<symbol name="VECTOR_ClockMonitorFailReset" address="FFFC" entry="true" type="code_ptr"/>
<symbol name="VECTOR_COPFailureReset" address="FFFA" entry="true" type="code_ptr"/>
<symbol name="VECTOR_UnimplementedInstructionTrap" address="FFF8" entry="true" type="code_ptr"/>
<symbol name="VECTOR_SWI" address="FFF6" entry="true" type="code_ptr"/>
<symbol name="VECTOR_XIRQ" address="FFF4" entry="true" type="code_ptr"/>
<symbol name="VECTOR_IRQ" address="FFF2" entry="true" type="code_ptr"/>
<symbol name="VECTOR_RealTimeInterrupt" address="FFF0" entry="true" type="code_ptr"/>
<symbol name="VECTOR_TimerInputCapture1" address="FFEE" entry="true" type="code_ptr"/>
<symbol name="VECTOR_TimerInputCapture2" address="FFEC" entry="true" type="code_ptr"/>
<symbol name="VECTOR_TimerInputCapture3" address="FFEA" entry="true" type="code_ptr"/>
<symbol name="VECTOR_TimerOutputCompare1" address="FFE8" entry="true" type="code_ptr"/>
<symbol name="VECTOR_TimerOutputCompare2" address="FFE6" entry="true" type="code_ptr"/>
<symbol name="VECTOR_TimerOutputCompare3" address="FFE4" entry="true" type="code_ptr"/>
<symbol name="VECTOR_TimerOutputCompare4" address="FFE2" entry="true" type="code_ptr"/>
<symbol name="VECTOR_TimerOutputCompare5" address="FFE0" entry="true" type="code_ptr"/>
<symbol name="VECTOR_TimerOverflow" address="FFDE" entry="true" type="code_ptr"/>
<symbol name="VECTOR_PulseAccumulatorAOverflow" address="FFDC" entry="true" type="code_ptr"/>
<symbol name="VECTOR_PulseAccumulatorInputEdge" address="FFDA" entry="true" type="code_ptr"/>
<symbol name="VECTOR_SPI" address="FFD8" entry="true" type="code_ptr"/>
<symbol name="VECTOR_SCI" address="FFD6" entry="true" type="code_ptr"/>
<symbol name="VECTOR_Reserved_FFD4" address="FFD4" entry="true" type="code_ptr"/>
<symbol name="VECTOR_Reserved_FFD2" address="FFD2" entry="true" type="code_ptr"/>
<symbol name="VECTOR_Reserved_FFD0" address="FFD0" entry="true" type="code_ptr"/>
<symbol name="VECTOR_Reserved_FFCE" address="FFCE" entry="true" type="code_ptr"/>
<symbol name="VECTOR_Reserved_FFCC" address="FFCC" entry="true" type="code_ptr"/>
<symbol name="VECTOR_Reserved_FFCA" address="FFCA" entry="true" type="code_ptr"/>
<symbol name="VECTOR_Reserved_FFC8" address="FFC8" entry="true" type="code_ptr"/>
<symbol name="VECTOR_Reserved_FFC6" address="FFC6" entry="true" type="code_ptr"/>
<symbol name="VECTOR_Reserved_FFC4" address="FFC4" entry="true" type="code_ptr"/>
<symbol name="VECTOR_Reserved_FFC2" address="FFC2" entry="true" type="code_ptr"/>
<symbol name="VECTOR_Reserved_FFC0" address="FFC0" entry="true" type="code_ptr"/>
</default_symbols>
</processor_spec>

File diff suppressed because it is too large Load Diff