Fix overflow

uint8_t -> uint16_t
This commit is contained in:
Elp03 2024-03-20 14:18:45 +01:00
parent 25050d4500
commit 1b6294b04b
4 changed files with 188 additions and 181 deletions

View File

@ -23,7 +23,7 @@ int main() {
stdout = &USART_stream; stdout = &USART_stream;
while (1) { while (1) {
voltage_values(); uint16_t adcVal = voltage_values();
//printf("The values: \n%u , %u\n",VREF_REFSEL_VDD_gc , adcVal); printf("The values: \n%u , %u\n",VREF_REFSEL_VDD_gc , adcVal);
} }
} }

View File

@ -1,174 +1,180 @@
<?xml version="1.0" encoding="UTF-8"?> <?xml version="1.0" encoding="UTF-8"?>
<configurationDescriptor version="65"> <configurationDescriptor version="65">
<logicalFolder name="root" displayName="root" projectFiles="true"> <logicalFolder name="root" displayName="root" projectFiles="true">
<logicalFolder name="HeaderFiles" <logicalFolder name="HeaderFiles"
displayName="Header Files" displayName="Header Files"
projectFiles="true"> projectFiles="true">
<itemPath>uart.h</itemPath> <itemPath>uart.h</itemPath>
<itemPath>voltage.h</itemPath> <itemPath>voltage.h</itemPath>
</logicalFolder> </logicalFolder>
<logicalFolder name="ExternalFiles" <logicalFolder name="ExternalFiles"
displayName="Important Files" displayName="Important Files"
projectFiles="true"> projectFiles="true">
<itemPath>Makefile</itemPath> <itemPath>Makefile</itemPath>
</logicalFolder> </logicalFolder>
<logicalFolder name="LinkerScript" <logicalFolder name="LinkerScript"
displayName="Linker Files" displayName="Linker Files"
projectFiles="true"> projectFiles="true">
</logicalFolder> </logicalFolder>
<logicalFolder name="SourceFiles" <logicalFolder name="SourceFiles"
displayName="Source Files" displayName="Source Files"
projectFiles="true"> projectFiles="true">
<itemPath>main.c</itemPath> <itemPath>main.c</itemPath>
<itemPath>uart.c</itemPath> <itemPath>uart.c</itemPath>
<itemPath>voltage.c</itemPath> <itemPath>voltage.c</itemPath>
</logicalFolder> </logicalFolder>
</logicalFolder> </logicalFolder>
<projectmakefile>Makefile</projectmakefile> <projectmakefile>Makefile</projectmakefile>
<confs> <confs>
<conf name="default" type="2"> <conf name="default" type="2">
<toolsSet> <toolsSet>
<developmentServer>localhost</developmentServer> <developmentServer>localhost</developmentServer>
<targetDevice>AVR128DB48</targetDevice> <targetDevice>AVR128DB48</targetDevice>
<targetHeader></targetHeader> <targetHeader></targetHeader>
<targetPluginBoard></targetPluginBoard> <targetPluginBoard></targetPluginBoard>
<platformTool>nEdbgTool</platformTool> <platformTool>nEdbgTool</platformTool>
<languageToolchain>XC8</languageToolchain> <languageToolchain>XC8</languageToolchain>
<languageToolchainVersion>2.46</languageToolchainVersion> <languageToolchainVersion>2.45</languageToolchainVersion>
<platform>3</platform> <platform>2</platform>
</toolsSet> </toolsSet>
<packs> <packs>
<pack name="AVR-Dx_DFP" vendor="Microchip" version="2.3.272"/> <pack name="AVR-Dx_DFP" vendor="Microchip" version="2.3.272"/>
</packs> </packs>
<ScriptingSettings> <ScriptingSettings>
</ScriptingSettings> </ScriptingSettings>
<compileType> <compileType>
<linkerTool> <linkerTool>
<linkerLibItems> <linkerLibItems>
</linkerLibItems> </linkerLibItems>
</linkerTool> </linkerTool>
<archiverTool> <archiverTool>
</archiverTool> </archiverTool>
<loading> <loading>
<useAlternateLoadableFile>false</useAlternateLoadableFile> <useAlternateLoadableFile>false</useAlternateLoadableFile>
<parseOnProdLoad>false</parseOnProdLoad> <parseOnProdLoad>false</parseOnProdLoad>
<alternateLoadableFile></alternateLoadableFile> <alternateLoadableFile></alternateLoadableFile>
</loading> </loading>
<subordinates> <subordinates>
</subordinates> </subordinates>
</compileType> </compileType>
<makeCustomizationType> <makeCustomizationType>
<makeCustomizationPreStepEnabled>false</makeCustomizationPreStepEnabled> <makeCustomizationPreStepEnabled>false</makeCustomizationPreStepEnabled>
<makeUseCleanTarget>false</makeUseCleanTarget> <makeUseCleanTarget>false</makeUseCleanTarget>
<makeCustomizationPreStep></makeCustomizationPreStep> <makeCustomizationPreStep></makeCustomizationPreStep>
<makeCustomizationPostStepEnabled>false</makeCustomizationPostStepEnabled> <makeCustomizationPostStepEnabled>false</makeCustomizationPostStepEnabled>
<makeCustomizationPostStep></makeCustomizationPostStep> <makeCustomizationPostStep></makeCustomizationPostStep>
<makeCustomizationPutChecksumInUserID>false</makeCustomizationPutChecksumInUserID> <makeCustomizationPutChecksumInUserID>false</makeCustomizationPutChecksumInUserID>
<makeCustomizationEnableLongLines>false</makeCustomizationEnableLongLines> <makeCustomizationEnableLongLines>false</makeCustomizationEnableLongLines>
<makeCustomizationNormalizeHexFile>false</makeCustomizationNormalizeHexFile> <makeCustomizationNormalizeHexFile>false</makeCustomizationNormalizeHexFile>
</makeCustomizationType> </makeCustomizationType>
<HI-TECH-COMP> <HI-TECH-COMP>
<property key="additional-warnings" value="true"/> <property key="additional-warnings" value="true"/>
<property key="asmlist" value="true"/> <property key="asmlist" value="true"/>
<property key="call-prologues" value="false"/> <property key="call-prologues" value="false"/>
<property key="default-bitfield-type" value="true"/> <property key="default-bitfield-type" value="true"/>
<property key="default-char-type" value="true"/> <property key="default-char-type" value="true"/>
<property key="define-macros" value=""/> <property key="define-macros" value=""/>
<property key="disable-optimizations" value="false"/> <property key="disable-optimizations" value="false"/>
<property key="extra-include-directories" value=""/> <property key="extra-include-directories" value=""/>
<property key="favor-optimization-for" value="-speed,+space"/> <property key="favor-optimization-for" value="-speed,+space"/>
<property key="garbage-collect-data" value="true"/> <property key="garbage-collect-data" value="true"/>
<property key="garbage-collect-functions" value="true"/> <property key="garbage-collect-functions" value="true"/>
<property key="identifier-length" value="255"/> <property key="identifier-length" value="255"/>
<property key="local-generation" value="false"/> <property key="local-generation" value="false"/>
<property key="operation-mode" value="free"/> <property key="operation-mode" value="free"/>
<property key="opt-xc8-compiler-strict_ansi" value="false"/> <property key="opt-xc8-compiler-strict_ansi" value="false"/>
<property key="optimization-assembler" value="true"/> <property key="optimization-assembler" value="true"/>
<property key="optimization-assembler-files" value="true"/> <property key="optimization-assembler-files" value="true"/>
<property key="optimization-debug" value="false"/> <property key="optimization-debug" value="false"/>
<property key="optimization-invariant-enable" value="false"/> <property key="optimization-invariant-enable" value="false"/>
<property key="optimization-invariant-value" value="16"/> <property key="optimization-invariant-value" value="16"/>
<property key="optimization-level" value="-O1"/> <property key="optimization-level" value="-O1"/>
<property key="optimization-speed" value="false"/> <property key="optimization-speed" value="false"/>
<property key="optimization-stable-enable" value="false"/> <property key="optimization-stable-enable" value="false"/>
<property key="preprocess-assembler" value="true"/> <property key="preprocess-assembler" value="true"/>
<property key="short-enums" value="true"/> <property key="short-enums" value="true"/>
<property key="tentative-definitions" value="-fno-common"/> <property key="tentative-definitions" value="-fno-common"/>
<property key="undefine-macros" value=""/> <property key="undefine-macros" value=""/>
<property key="use-cci" value="false"/> <property key="use-cci" value="false"/>
<property key="use-iar" value="false"/> <property key="use-iar" value="false"/>
<property key="verbose" value="false"/> <property key="verbose" value="false"/>
<property key="warning-level" value="-3"/> <property key="warning-level" value="-3"/>
<property key="what-to-do" value="ignore"/> <property key="what-to-do" value="ignore"/>
</HI-TECH-COMP> </HI-TECH-COMP>
<HI-TECH-LINK> <HI-TECH-LINK>
<property key="additional-options-checksum" value=""/> <property key="additional-options-checksum" value=""/>
<property key="additional-options-code-offset" value=""/> <property key="additional-options-code-offset" value=""/>
<property key="additional-options-command-line" value=""/> <property key="additional-options-command-line" value=""/>
<property key="additional-options-errata" value=""/> <property key="additional-options-errata" value=""/>
<property key="additional-options-extend-address" value="false"/> <property key="additional-options-extend-address" value="false"/>
<property key="additional-options-trace-type" value=""/> <property key="additional-options-trace-type" value=""/>
<property key="additional-options-use-response-files" value="false"/> <property key="additional-options-use-response-files" value="false"/>
<property key="backup-reset-condition-flags" value="false"/> <property key="backup-reset-condition-flags" value="false"/>
<property key="calibrate-oscillator" value="false"/> <property key="calibrate-oscillator" value="false"/>
<property key="calibrate-oscillator-value" value="0x3400"/> <property key="calibrate-oscillator-value" value="0x3400"/>
<property key="clear-bss" value="true"/> <property key="clear-bss" value="true"/>
<property key="code-model-external" value="wordwrite"/> <property key="code-model-external" value="wordwrite"/>
<property key="code-model-rom" value=""/> <property key="code-model-rom" value=""/>
<property key="create-html-files" value="false"/> <property key="create-html-files" value="false"/>
<property key="data-model-ram" value=""/> <property key="data-model-ram" value=""/>
<property key="data-model-size-of-double" value="24"/> <property key="data-model-size-of-double" value="24"/>
<property key="data-model-size-of-double-gcc" value="no-short-double"/> <property key="data-model-size-of-double-gcc" value="no-short-double"/>
<property key="data-model-size-of-float" value="24"/> <property key="data-model-size-of-float" value="24"/>
<property key="data-model-size-of-float-gcc" value="no-short-float"/> <property key="data-model-size-of-float-gcc" value="no-short-float"/>
<property key="display-class-usage" value="false"/> <property key="display-class-usage" value="false"/>
<property key="display-hex-usage" value="false"/> <property key="display-hex-usage" value="false"/>
<property key="display-overall-usage" value="true"/> <property key="display-overall-usage" value="true"/>
<property key="display-psect-usage" value="false"/> <property key="display-psect-usage" value="false"/>
<property key="extra-lib-directories" value=""/> <property key="extra-lib-directories" value=""/>
<property key="fill-flash-options-addr" value=""/> <property key="fill-flash-options-addr" value=""/>
<property key="fill-flash-options-const" value=""/> <property key="fill-flash-options-const" value=""/>
<property key="fill-flash-options-how" value="0"/> <property key="fill-flash-options-how" value="0"/>
<property key="fill-flash-options-inc-const" value="1"/> <property key="fill-flash-options-inc-const" value="1"/>
<property key="fill-flash-options-increment" value=""/> <property key="fill-flash-options-increment" value=""/>
<property key="fill-flash-options-seq" value=""/> <property key="fill-flash-options-seq" value=""/>
<property key="fill-flash-options-what" value="0"/> <property key="fill-flash-options-what" value="0"/>
<property key="format-hex-file-for-download" value="false"/> <property key="format-hex-file-for-download" value="false"/>
<property key="initialize-data" value="true"/> <property key="initialize-data" value="true"/>
<property key="input-libraries" value="libm"/> <property key="input-libraries" value="libm"/>
<property key="keep-generated-startup.as" value="false"/> <property key="keep-generated-startup.as" value="false"/>
<property key="link-in-c-library" value="true"/> <property key="link-in-c-library" value="true"/>
<property key="link-in-c-library-gcc" value=""/> <property key="link-in-c-library-gcc" value=""/>
<property key="link-in-peripheral-library" value="false"/> <property key="link-in-peripheral-library" value="false"/>
<property key="managed-stack" value="false"/> <property key="managed-stack" value="false"/>
<property key="opt-xc8-linker-file" value="false"/> <property key="opt-xc8-linker-file" value="false"/>
<property key="opt-xc8-linker-link_startup" value="false"/> <property key="opt-xc8-linker-link_startup" value="false"/>
<property key="opt-xc8-linker-serial" value=""/> <property key="opt-xc8-linker-serial" value=""/>
<property key="program-the-device-with-default-config-words" value="false"/> <property key="program-the-device-with-default-config-words" value="false"/>
<property key="remove-unused-sections" value="true"/> <property key="remove-unused-sections" value="true"/>
</HI-TECH-LINK> </HI-TECH-LINK>
<XC8-CO> <Tool>
<property key="coverage-enable" value=""/> <property key="debugoptions.useswbreakpoints" value="true"/>
<property key="stack-guidance" value="false"/> </Tool>
</XC8-CO> <XC8-CO>
<XC8-config-global> <property key="coverage-enable" value=""/>
<property key="advanced-elf" value="true"/> <property key="stack-guidance" value="false"/>
<property key="constdata-progmem" value="true"/> </XC8-CO>
<property key="gcc-opt-driver-new" value="true"/> <XC8-config-global>
<property key="gcc-opt-std" value="-std=c99"/> <property key="advanced-elf" value="true"/>
<property key="gcc-output-file-format" value="dwarf-3"/> <property key="constdata-progmem" value="true"/>
<property key="mapped-progmem" value="false"/> <property key="gcc-opt-driver-new" value="true"/>
<property key="omit-pack-options" value="false"/> <property key="gcc-opt-std" value="-std=c99"/>
<property key="omit-pack-options-new" value="1"/> <property key="gcc-output-file-format" value="dwarf-3"/>
<property key="output-file-format" value="-mcof,+elf"/> <property key="mapped-progmem" value="false"/>
<property key="smart-io-format" value=""/> <property key="omit-pack-options" value="false"/>
<property key="stack-size-high" value="auto"/> <property key="omit-pack-options-new" value="1"/>
<property key="stack-size-low" value="auto"/> <property key="output-file-format" value="-mcof,+elf"/>
<property key="stack-size-main" value="auto"/> <property key="smart-io-format" value=""/>
<property key="stack-type" value="compiled"/> <property key="stack-size-high" value="auto"/>
<property key="user-pack-device-support" value=""/> <property key="stack-size-low" value="auto"/>
<property key="wpo-lto" value="false"/> <property key="stack-size-main" value="auto"/>
</XC8-config-global> <property key="stack-type" value="compiled"/>
</conf> <property key="user-pack-device-support" value=""/>
</confs> <property key="wpo-lto" value="false"/>
</configurationDescriptor> </XC8-config-global>
<nEdbgTool>
<property key="debugoptions.useswbreakpoints" value="true"/>
</nEdbgTool>
</conf>
</confs>
</configurationDescriptor>

View File

@ -3,6 +3,7 @@
void sensor_init(void) { void sensor_init(void) {
/* Disable digital input buffer */ /* Disable digital input buffer */
} }
void ADC0_init(void) { void ADC0_init(void) {
@ -26,14 +27,14 @@ uint16_t ADC0_read(void) {
while (!(ADC0.INTFLAGS & ADC_RESRDY_bm)) { while (!(ADC0.INTFLAGS & ADC_RESRDY_bm)) {
; ;
} }
/* Clear the interrupt flag by writing 1: */ // Clear the interrupt flag by writing 1:
ADC0.INTFLAGS = ADC_RESRDY_bm; ADC0.INTFLAGS = ADC_RESRDY_bm;
return ADC0.RES; return ADC0.RES;
} }
uint8_t voltage_values(void) { uint16_t voltage_values(void) {
/* Gets values */ /* Gets values */
uint8_t adcVal = ADC0_read(); uint16_t adcVal = ADC0_read();
VREF.ADC0REF = VREF_REFSEL_VDD_gc; VREF.ADC0REF = VREF_REFSEL_VDD_gc;
return adcVal; return adcVal;
} }

View File

@ -53,7 +53,7 @@ void ADC0_init(void);
//Start ADC conversion //Start ADC conversion
uint16_t ADC0_read(void); uint16_t ADC0_read(void);
// Gets the value from sensor and internal voltage // Gets the value from sensor and internal voltage
uint8_t voltage_values(void); uint16_t voltage_values(void);
#ifdef __cplusplus #ifdef __cplusplus
} }
#endif /* __cplusplus */ #endif /* __cplusplus */