Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

SendCarCAN Restructure #337

Merged
merged 33 commits into from
Dec 17, 2023
Merged

SendCarCAN Restructure #337

merged 33 commits into from
Dec 17, 2023

Conversation

NathanielDelgado
Copy link
Contributor

Just merging SendCarCAN into Telemetry due to them both just sending data on the CarCAN line.

The only thing I worry about is if sending the motor feedback blocks (CarQueuePost is a blocking call. No non-blocking call available) which stops the other data being sent as well. But this probably doesn't matter much

@IshDeshpa
Copy link
Contributor

IshDeshpa commented Jul 9, 2023

I would like to handle the restructuring of SendCarCAN (in terms of merging in CANQueue, #331 ) in this PR as well. I will start work on that.

@IshDeshpa
Copy link
Contributor

Also, I'd like to keep the name SendCarCAN instead of Telemetry. It fits more with our naming scheme (SendCarCAN, ReadCarCAN, SendTritium, ReadTritium).

@IshDeshpa IshDeshpa changed the title Merged SendCarCAN and Telemetry Tasks SendCarCAN Restructure Jul 12, 2023
@IshDeshpa IshDeshpa marked this pull request as ready for review July 12, 2023 20:50
This was linked to issues Jul 13, 2023
NathanielDelgado

This comment was marked as resolved.

@IshDeshpa IshDeshpa mentioned this pull request Jul 13, 2023
6 tasks
Copy link
Contributor Author

@NathanielDelgado NathanielDelgado left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Looks good. Just some questions and prefrences

Apps/Inc/fifo_protected.h Outdated Show resolved Hide resolved
Apps/Inc/fifo_protected.h Outdated Show resolved Hide resolved
Apps/Src/SendCarCAN.c Show resolved Hide resolved
Apps/Src/SendCarCAN.c Outdated Show resolved Hide resolved
@IshDeshpa
Copy link
Contributor

Task linked: CU-8685u78f5 SendCarCAN Restructure

…on a semaphore. The loop will check two semaphores- one to see if it's time to put an IO State message in the queue (based on if the putIOState timer has expired or not) and one to see if there's a message in the queuethat we should send.
… sendCarCAN loop to send the IO message at approximately the same frequency as before (250 ms), but this time using loops, delays, and counters. It won't be as accurate, but it should still be at a relatively similar frequency.
…t info while running tests on hardware or also define __TEST_SENDTRITIUM_SOFTWAREONLY to bypass hardware inputs/outputs.
…at the SendCarCAN file by exposing it with a macro mess. controls-leader code compiles, but the test file does not compile yet.
…ader file and added a wrapper instead. Test compiles but hasn't been verified to work successfully yet.
@IshDeshpa
Copy link
Contributor

Is this ready for review? Also, merge in master.

…y at which we forwared motor messages onto CarCAN, moved init functions in test file, added Renode independent watchdog fix.
Copy link
Contributor Author

@NathanielDelgado NathanielDelgado left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

_**Code seems fine but there is so much old shit in here. I can help you fix this **_

Apps/Src/SendTritium.c Outdated Show resolved Hide resolved
Copy link
Contributor

@Cam0Cow Cam0Cow left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Didn't review the test file.

Apps/Src/SendCarCAN.c Outdated Show resolved Hide resolved
Apps/Src/SendCarCAN.c Outdated Show resolved Hide resolved
Apps/Src/SendCarCAN.c Outdated Show resolved Hide resolved
Apps/Src/SendCarCAN.c Outdated Show resolved Hide resolved
Apps/Src/SendCarCAN.c Outdated Show resolved Hide resolved
Apps/Src/SendCarCAN.c Outdated Show resolved Hide resolved
Apps/Src/common.c Outdated Show resolved Hide resolved
Apps/Src/common.c Show resolved Hide resolved
Docs/source/index.rst Outdated Show resolved Hide resolved
…ed in GDB using variables instead of prints which were overwhelming UART.
…earing out old data in the rest of the bytes, updated comments in the test file.
…n PutIOState to account for the inverted logic, added a new bit of information to PutIOState in byte 3, bit 2 which tells BPS if the array contactor should be turned on or not (true if IGN_1 or IGN_2 are on). This is necessary because when the ignition is switched to motor state, the array pin is turned off (only one or the other is on at a time). Note: in the future we'd like to use the GPIO read settings to account for the inverted ignition logic so we don't have to negate every Minions_Read.
Copy link
Contributor

@diyarajon diyarajon left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I like how the code was written -- made it easy to understand.

Apps/Src/SendCarCAN.c Show resolved Hide resolved
Apps/Inc/Tasks.h Outdated Show resolved Hide resolved
Apps/Src/SendCarCAN.c Show resolved Hide resolved
Apps/Src/SendCarCAN.c Show resolved Hide resolved
Apps/Src/SendCarCAN.c Show resolved Hide resolved
… other, added to the comment for SendCarCAN_Put.
diyarajon
diyarajon previously approved these changes Dec 15, 2023
Copy link
Contributor

@diyarajon diyarajon left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Looks good to me!

Copy link
Contributor

@IshDeshpa IshDeshpa left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Just a couple of changes/questions. Otherwise looks good; merge in master.

Apps/Inc/SendCarCAN.h Outdated Show resolved Hide resolved
Apps/Inc/fifo.h Outdated Show resolved Hide resolved
Copy link
Contributor

@IshDeshpa IshDeshpa left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM!

@IshDeshpa IshDeshpa merged commit 66958b8 into master Dec 17, 2023
2 checks passed
IshDeshpa added a commit that referenced this pull request Dec 17, 2023
* Merged functionality of SendCarCAN into Telemetry and removed SendCarCAN remnants

* renamed telemetry to send car can

* adapted CAN_Queue into a library file and integrated with SendCarCAN

* merge conflict resolved

* Started a test file for SendCarCAN.

* Changed main loop to check the queue periodically instead of pending on a semaphore. The loop will check two semaphores- one to see if it's time to put an IO State message in the queue (based on if the putIOState timer has expired or not) and one to see if there's a message in the queuethat we should send.

* Deleted most putIOStateTimer thigns, added a macro and counter in the sendCarCAN loop to send the IO message at approximately the same frequency as before (250 ms), but this time using loops, delays, and counters. It won't be as accurate, but it should still be at a relatively similar frequency.

* Added line to put messages from the motor into the CarCAN queue to be sent.

* Altered test macros so that we can define __TEST_SENDTRITIUM and print info while running tests on hardware or also define __TEST_SENDTRITIUM_SOFTWAREONLY to bypass hardware inputs/outputs.

* Made aa first draft of the SendCarCAN test file and attempted to get at the SendCarCAN file by exposing it with a macro mess. controls-leader code compiles, but the test file does not compile yet.

* SendCarCAN test file compiles! But at what cost...

* Cleaned up and worked on test file, removed attempt to put fifo in header file and added a wrapper instead. Test compiles but hasn't been verified to work successfully yet.

* Added ability to print FIFO queue indexes, added ReadTritium task in SendCarCAN test, fixed CAN initialization to read CarCAN but also initialize MOTORCAN.

* Test file updates from testing on hardware.

* Deleted extra lines added when merging.

* Moved mutex, semaphore creation and fifo renewal to a new SendCarCAN_Init function so that other tasks can put things into the queue before SendCarCAN is ready. Additionally, created a new static task in SendCarCAN.c called PutIOState which periodically sends messages over CarCAN.

* Changed PutIOState to send directly instead of putting messages in the queue to be sent by SendCarCAN later.

* Updates from hardware testing: added counter array to reduce frequency at which we forwared motor messages onto CarCAN, moved init functions in test file, added Renode independent watchdog fix.

* Added while loop to putIOState

* Test file changes for last minute panic debugging. Added an array to see what IDS are being received.

* Addressing review comments: updated SendTritium macros, removed motorMsgCount queue, downsized SendCarCAN FIFO.

* Revisions to SendCarCAN and test file to allow messages to be inspected in GDB using variables instead of prints which were overwhelming UART.

* Updated NUM_CAN_IDS to MAX_CAN_ID in the CANId enum.

* Added commas to enum to match new enum generation format.

* Memset the gTxMessage.Data to zero since one-byte messages weren't clearing out old data in the rest of the bytes, updated comments in the test file.

* Fixed accidental deletion in docs.

* Changes from integration with BPS: flipped reading of ignition pins in PutIOState to account for the inverted logic, added a new bit of information to PutIOState in byte 3, bit 2 which tells BPS if the array contactor should be turned on or not (true if IGN_1 or IGN_2 are on). This is necessary because  when the ignition is switched to motor state, the array pin is turned off (only one or the other is on at a time). Note: in the future we'd like to use the GPIO read settings to account for the inverted ignition logic so we don't have to negate every Minions_Read.

* Addressed review comments: Shifted task priorities to be next to each other, added to the comment for SendCarCAN_Put.

* addressed review comments

---------

Co-authored-by: ishdeshpa <[email protected]>
Co-authored-by: Madeleine Lee <[email protected]>
IshDeshpa added a commit that referenced this pull request Dec 17, 2023
commit 66958b8
Author: Nathaniel Delgado <[email protected]>
Date:   Sat Dec 16 18:29:35 2023 -0600

    SendCarCAN Restructure (#337)

    * Merged functionality of SendCarCAN into Telemetry and removed SendCarCAN remnants

    * renamed telemetry to send car can

    * adapted CAN_Queue into a library file and integrated with SendCarCAN

    * merge conflict resolved

    * Started a test file for SendCarCAN.

    * Changed main loop to check the queue periodically instead of pending on a semaphore. The loop will check two semaphores- one to see if it's time to put an IO State message in the queue (based on if the putIOState timer has expired or not) and one to see if there's a message in the queuethat we should send.

    * Deleted most putIOStateTimer thigns, added a macro and counter in the sendCarCAN loop to send the IO message at approximately the same frequency as before (250 ms), but this time using loops, delays, and counters. It won't be as accurate, but it should still be at a relatively similar frequency.

    * Added line to put messages from the motor into the CarCAN queue to be sent.

    * Altered test macros so that we can define __TEST_SENDTRITIUM and print info while running tests on hardware or also define __TEST_SENDTRITIUM_SOFTWAREONLY to bypass hardware inputs/outputs.

    * Made aa first draft of the SendCarCAN test file and attempted to get at the SendCarCAN file by exposing it with a macro mess. controls-leader code compiles, but the test file does not compile yet.

    * SendCarCAN test file compiles! But at what cost...

    * Cleaned up and worked on test file, removed attempt to put fifo in header file and added a wrapper instead. Test compiles but hasn't been verified to work successfully yet.

    * Added ability to print FIFO queue indexes, added ReadTritium task in SendCarCAN test, fixed CAN initialization to read CarCAN but also initialize MOTORCAN.

    * Test file updates from testing on hardware.

    * Deleted extra lines added when merging.

    * Moved mutex, semaphore creation and fifo renewal to a new SendCarCAN_Init function so that other tasks can put things into the queue before SendCarCAN is ready. Additionally, created a new static task in SendCarCAN.c called PutIOState which periodically sends messages over CarCAN.

    * Changed PutIOState to send directly instead of putting messages in the queue to be sent by SendCarCAN later.

    * Updates from hardware testing: added counter array to reduce frequency at which we forwared motor messages onto CarCAN, moved init functions in test file, added Renode independent watchdog fix.

    * Added while loop to putIOState

    * Test file changes for last minute panic debugging. Added an array to see what IDS are being received.

    * Addressing review comments: updated SendTritium macros, removed motorMsgCount queue, downsized SendCarCAN FIFO.

    * Revisions to SendCarCAN and test file to allow messages to be inspected in GDB using variables instead of prints which were overwhelming UART.

    * Updated NUM_CAN_IDS to MAX_CAN_ID in the CANId enum.

    * Added commas to enum to match new enum generation format.

    * Memset the gTxMessage.Data to zero since one-byte messages weren't clearing out old data in the rest of the bytes, updated comments in the test file.

    * Fixed accidental deletion in docs.

    * Changes from integration with BPS: flipped reading of ignition pins in PutIOState to account for the inverted logic, added a new bit of information to PutIOState in byte 3, bit 2 which tells BPS if the array contactor should be turned on or not (true if IGN_1 or IGN_2 are on). This is necessary because  when the ignition is switched to motor state, the array pin is turned off (only one or the other is on at a time). Note: in the future we'd like to use the GPIO read settings to account for the inverted ignition logic so we don't have to negate every Minions_Read.

    * Addressed review comments: Shifted task priorities to be next to each other, added to the comment for SendCarCAN_Put.

    * addressed review comments

    ---------

    Co-authored-by: ishdeshpa <[email protected]>
    Co-authored-by: Madeleine Lee <[email protected]>

commit 5c13022
Author: Nathaniel Delgado <[email protected]>
Date:   Wed Dec 13 14:59:37 2023 -0600

    Added bps can sim for integration simulation
IshDeshpa added a commit that referenced this pull request Dec 17, 2023
commit 66958b8
Author: Nathaniel Delgado <[email protected]>
Date:   Sat Dec 16 18:29:35 2023 -0600

    SendCarCAN Restructure (#337)

    * Merged functionality of SendCarCAN into Telemetry and removed SendCarCAN remnants

    * renamed telemetry to send car can

    * adapted CAN_Queue into a library file and integrated with SendCarCAN

    * merge conflict resolved

    * Started a test file for SendCarCAN.

    * Changed main loop to check the queue periodically instead of pending on a semaphore. The loop will check two semaphores- one to see if it's time to put an IO State message in the queue (based on if the putIOState timer has expired or not) and one to see if there's a message in the queuethat we should send.

    * Deleted most putIOStateTimer thigns, added a macro and counter in the sendCarCAN loop to send the IO message at approximately the same frequency as before (250 ms), but this time using loops, delays, and counters. It won't be as accurate, but it should still be at a relatively similar frequency.

    * Added line to put messages from the motor into the CarCAN queue to be sent.

    * Altered test macros so that we can define __TEST_SENDTRITIUM and print info while running tests on hardware or also define __TEST_SENDTRITIUM_SOFTWAREONLY to bypass hardware inputs/outputs.

    * Made aa first draft of the SendCarCAN test file and attempted to get at the SendCarCAN file by exposing it with a macro mess. controls-leader code compiles, but the test file does not compile yet.

    * SendCarCAN test file compiles! But at what cost...

    * Cleaned up and worked on test file, removed attempt to put fifo in header file and added a wrapper instead. Test compiles but hasn't been verified to work successfully yet.

    * Added ability to print FIFO queue indexes, added ReadTritium task in SendCarCAN test, fixed CAN initialization to read CarCAN but also initialize MOTORCAN.

    * Test file updates from testing on hardware.

    * Deleted extra lines added when merging.

    * Moved mutex, semaphore creation and fifo renewal to a new SendCarCAN_Init function so that other tasks can put things into the queue before SendCarCAN is ready. Additionally, created a new static task in SendCarCAN.c called PutIOState which periodically sends messages over CarCAN.

    * Changed PutIOState to send directly instead of putting messages in the queue to be sent by SendCarCAN later.

    * Updates from hardware testing: added counter array to reduce frequency at which we forwared motor messages onto CarCAN, moved init functions in test file, added Renode independent watchdog fix.

    * Added while loop to putIOState

    * Test file changes for last minute panic debugging. Added an array to see what IDS are being received.

    * Addressing review comments: updated SendTritium macros, removed motorMsgCount queue, downsized SendCarCAN FIFO.

    * Revisions to SendCarCAN and test file to allow messages to be inspected in GDB using variables instead of prints which were overwhelming UART.

    * Updated NUM_CAN_IDS to MAX_CAN_ID in the CANId enum.

    * Added commas to enum to match new enum generation format.

    * Memset the gTxMessage.Data to zero since one-byte messages weren't clearing out old data in the rest of the bytes, updated comments in the test file.

    * Fixed accidental deletion in docs.

    * Changes from integration with BPS: flipped reading of ignition pins in PutIOState to account for the inverted logic, added a new bit of information to PutIOState in byte 3, bit 2 which tells BPS if the array contactor should be turned on or not (true if IGN_1 or IGN_2 are on). This is necessary because  when the ignition is switched to motor state, the array pin is turned off (only one or the other is on at a time). Note: in the future we'd like to use the GPIO read settings to account for the inverted ignition logic so we don't have to negate every Minions_Read.

    * Addressed review comments: Shifted task priorities to be next to each other, added to the comment for SendCarCAN_Put.

    * addressed review comments

    ---------

    Co-authored-by: ishdeshpa <[email protected]>
    Co-authored-by: Madeleine Lee <[email protected]>

commit 5c13022
Author: Nathaniel Delgado <[email protected]>
Date:   Wed Dec 13 14:59:37 2023 -0600

    Added bps can sim for integration simulation
IshDeshpa added a commit that referenced this pull request Jan 2, 2024
* Remove contactor handling and extraneous delays from main

* Create CommandLine task in main.c

* changed ordering of task prios

* Actually switch to hard floats, remove duplicated flags

* disabled regen

* Squashed commit of the following:

commit f72917b
Author: Madeleine Lee <[email protected]>
Date:   Fri Nov 17 15:55:26 2023 +0000

    Fixed accidental deletion in docs.

commit 2755a69
Author: Madeleine Lee <[email protected]>
Date:   Fri Nov 17 15:50:32 2023 +0000

    Memset the gTxMessage.Data to zero since one-byte messages weren't clearing out old data in the rest of the bytes, updated comments in the test file.

commit 5d3ddfb
Author: Madeleine Lee <[email protected]>
Date:   Fri Nov 17 14:50:01 2023 +0000

    Added commas to enum to match new enum generation format.

commit 347ef98
Author: Madeleine Lee <[email protected]>
Date:   Fri Nov 17 14:27:58 2023 +0000

    Updated NUM_CAN_IDS to MAX_CAN_ID in the CANId enum.

commit 03f262c
Merge: 362628e e6c9fb6
Author: Madeleine Lee <[email protected]>
Date:   Fri Nov 17 10:31:31 2023 +0000

    Merge branch 'master' into sendcarcan-telemetry-merge

commit 362628e
Author: Madeleine Lee <[email protected]>
Date:   Fri Nov 17 10:24:37 2023 +0000

    Revisions to SendCarCAN and test file to allow messages to be inspected in GDB using variables instead of prints which were overwhelming UART.

commit 8bdf6bb
Author: Madeleine Lee <[email protected]>
Date:   Mon Nov 13 23:04:14 2023 +0000

    Addressing review comments: updated SendTritium macros, removed motorMsgCount queue, downsized SendCarCAN FIFO.

commit 0079ce4
Author: Madeleine Lee <[email protected]>
Date:   Sat Nov 11 17:57:19 2023 +0000

    Test file changes for last minute panic debugging. Added an array to see what IDS are being received.

commit de12ac1
Author: Madeleine Lee <[email protected]>
Date:   Sat Nov 11 17:32:41 2023 +0000

    Added while loop to putIOState

commit ff4bf0a
Author: Madeleine Lee <[email protected]>
Date:   Sat Nov 11 08:16:23 2023 +0000

    Updates from hardware testing: added counter array to reduce frequency at which we forwared motor messages onto CarCAN, moved init functions in test file, added Renode independent watchdog fix.

commit 77dbc2a
Author: Madeleine Lee <[email protected]>
Date:   Sat Nov 11 03:22:40 2023 +0000

    Changed PutIOState to send directly instead of putting messages in the queue to be sent by SendCarCAN later.

commit ce1d74a
Author: Madeleine Lee <[email protected]>
Date:   Sat Nov 11 03:20:33 2023 +0000

    Moved mutex, semaphore creation and fifo renewal to a new SendCarCAN_Init function so that other tasks can put things into the queue before SendCarCAN is ready. Additionally, created a new static task in SendCarCAN.c called PutIOState which periodically sends messages over CarCAN.

commit 9043b7b
Author: Madeleine Lee <[email protected]>
Date:   Fri Nov 10 23:57:18 2023 +0000

    Deleted extra lines added when merging.

commit a5e63df
Merge: d303e9b 5ae3439
Author: Madeleine Lee <[email protected]>
Date:   Fri Nov 10 23:41:44 2023 +0000

    Merge branch 'master' into sendcarcan-telemetry-merge

commit d303e9b
Author: Madeleine Lee <[email protected]>
Date:   Fri Nov 10 23:07:18 2023 +0000

    Test file updates from testing on hardware.

commit 9c755ba
Author: Madeleine Lee <[email protected]>
Date:   Sat Nov 4 21:08:49 2023 +0000

    Added ability to print FIFO queue indexes, added ReadTritium task in SendCarCAN test, fixed CAN initialization to read CarCAN but also initialize MOTORCAN.

commit 489a494
Author: Madeleine Lee <[email protected]>
Date:   Fri Oct 27 14:44:45 2023 +0000

    Cleaned up and worked on test file, removed attempt to put fifo in header file and added a wrapper instead. Test compiles but hasn't been verified to work successfully yet.

commit c38a3d7
Author: Madeleine Lee <[email protected]>
Date:   Sat Oct 21 04:57:18 2023 +0000

    SendCarCAN test file compiles! But at what cost...

commit ad84abf
Author: Madeleine Lee <[email protected]>
Date:   Sat Oct 21 04:47:33 2023 +0000

    Made aa first draft of the SendCarCAN test file and attempted to get at the SendCarCAN file by exposing it with a macro mess. controls-leader code compiles, but the test file does not compile yet.

commit 3d1d906
Author: Madeleine Lee <[email protected]>
Date:   Fri Oct 20 21:06:52 2023 +0000

    Altered test macros so that we can define __TEST_SENDTRITIUM and print info while running tests on hardware or also define __TEST_SENDTRITIUM_SOFTWAREONLY to bypass hardware inputs/outputs.

commit 73dddf7
Author: Madeleine Lee <[email protected]>
Date:   Fri Oct 20 03:02:13 2023 +0000

    Added line to put messages from the motor into the CarCAN queue to be sent.

commit 90cb9c6
Author: Madeleine Lee <[email protected]>
Date:   Fri Oct 20 02:50:50 2023 +0000

    Deleted most putIOStateTimer thigns, added a macro and counter in the sendCarCAN loop to send the IO message at approximately the same frequency as before (250 ms), but this time using loops, delays, and counters. It won't be as accurate, but it should still be at a relatively similar frequency.

commit 5185426
Author: Madeleine Lee <[email protected]>
Date:   Sat Oct 14 20:29:23 2023 +0000

    Changed main loop to check the queue periodically instead of pending on a semaphore. The loop will check two semaphores- one to see if it's time to put an IO State message in the queue (based on if the putIOState timer has expired or not) and one to see if there's a message in the queuethat we should send.

commit 2d7dbbf
Author: Madeleine Lee <[email protected]>
Date:   Sat Oct 7 23:21:43 2023 +0000

    Started a test file for SendCarCAN.

commit 2f45100
Merge: 6f69ba9 fd33899
Author: ishdeshpa <[email protected]>
Date:   Tue Sep 26 00:09:02 2023 +0000

    merged in master, now builds. test still needs to be written and bugfixes made. also ignition switch message needs to be added.

commit 6f69ba9
Author: ishdeshpa <[email protected]>
Date:   Mon Sep 25 23:50:29 2023 +0000

    merge conflict resolved

commit de426c5
Author: ishdeshpa <[email protected]>
Date:   Mon Jul 10 19:36:13 2023 +0000

    adapted CAN_Queue into a library file and integrated with SendCarCAN

commit cfd0b7c
Author: ishdeshpa <[email protected]>
Date:   Sun Jul 9 22:16:56 2023 +0000

    renamed telemetry to send car can

commit 771a916
Author: Nathaniel Delgado <[email protected]>
Date:   Sat Jul 8 03:13:27 2023 +0000

    Merged functionality of SendCarCAN into Telemetry and removed SendCarCAN remnants

* test commit

* Changes from integration with BPS: uncommented initialization of Task_ReadCarCAN, changed BPS_CONTACTOR CAN message ID to 0x102 instead of x101 (which is for BPS All Clear)

* test commit

* Squashed commit of the following:

commit 6cf7996
Author: Madeleine Lee <[email protected]>
Date:   Sun Dec 3 05:59:52 2023 +0000

    Changes from integration with BPS: flipped reading of ignition pins in PutIOState to account for the inverted logic, added a new bit of information to PutIOState in byte 3, bit 2 which tells BPS if the array contactor should be turned on or not (true if IGN_1 or IGN_2 are on). This is necessary because  when the ignition is switched to motor state, the array pin is turned off (only one or the other is on at a time). Note: in the future we'd like to use the GPIO read settings to account for the inverted ignition logic so we don't have to negate every Minions_Read.

commit f72917b
Author: Madeleine Lee <[email protected]>
Date:   Fri Nov 17 15:55:26 2023 +0000

    Fixed accidental deletion in docs.

commit 2755a69
Author: Madeleine Lee <[email protected]>
Date:   Fri Nov 17 15:50:32 2023 +0000

    Memset the gTxMessage.Data to zero since one-byte messages weren't clearing out old data in the rest of the bytes, updated comments in the test file.

commit 5d3ddfb
Author: Madeleine Lee <[email protected]>
Date:   Fri Nov 17 14:50:01 2023 +0000

    Added commas to enum to match new enum generation format.

commit 347ef98
Author: Madeleine Lee <[email protected]>
Date:   Fri Nov 17 14:27:58 2023 +0000

    Updated NUM_CAN_IDS to MAX_CAN_ID in the CANId enum.

commit 03f262c
Merge: 362628e e6c9fb6
Author: Madeleine Lee <[email protected]>
Date:   Fri Nov 17 10:31:31 2023 +0000

    Merge branch 'master' into sendcarcan-telemetry-merge

commit 362628e
Author: Madeleine Lee <[email protected]>
Date:   Fri Nov 17 10:24:37 2023 +0000

    Revisions to SendCarCAN and test file to allow messages to be inspected in GDB using variables instead of prints which were overwhelming UART.

commit 8bdf6bb
Author: Madeleine Lee <[email protected]>
Date:   Mon Nov 13 23:04:14 2023 +0000

    Addressing review comments: updated SendTritium macros, removed motorMsgCount queue, downsized SendCarCAN FIFO.

commit 0079ce4
Author: Madeleine Lee <[email protected]>
Date:   Sat Nov 11 17:57:19 2023 +0000

    Test file changes for last minute panic debugging. Added an array to see what IDS are being received.

commit de12ac1
Author: Madeleine Lee <[email protected]>
Date:   Sat Nov 11 17:32:41 2023 +0000

    Added while loop to putIOState

commit ff4bf0a
Author: Madeleine Lee <[email protected]>
Date:   Sat Nov 11 08:16:23 2023 +0000

    Updates from hardware testing: added counter array to reduce frequency at which we forwared motor messages onto CarCAN, moved init functions in test file, added Renode independent watchdog fix.

commit 77dbc2a
Author: Madeleine Lee <[email protected]>
Date:   Sat Nov 11 03:22:40 2023 +0000

    Changed PutIOState to send directly instead of putting messages in the queue to be sent by SendCarCAN later.

commit ce1d74a
Author: Madeleine Lee <[email protected]>
Date:   Sat Nov 11 03:20:33 2023 +0000

    Moved mutex, semaphore creation and fifo renewal to a new SendCarCAN_Init function so that other tasks can put things into the queue before SendCarCAN is ready. Additionally, created a new static task in SendCarCAN.c called PutIOState which periodically sends messages over CarCAN.

commit 9043b7b
Author: Madeleine Lee <[email protected]>
Date:   Fri Nov 10 23:57:18 2023 +0000

    Deleted extra lines added when merging.

commit a5e63df
Merge: d303e9b 5ae3439
Author: Madeleine Lee <[email protected]>
Date:   Fri Nov 10 23:41:44 2023 +0000

    Merge branch 'master' into sendcarcan-telemetry-merge

commit d303e9b
Author: Madeleine Lee <[email protected]>
Date:   Fri Nov 10 23:07:18 2023 +0000

    Test file updates from testing on hardware.

commit 9c755ba
Author: Madeleine Lee <[email protected]>
Date:   Sat Nov 4 21:08:49 2023 +0000

    Added ability to print FIFO queue indexes, added ReadTritium task in SendCarCAN test, fixed CAN initialization to read CarCAN but also initialize MOTORCAN.

commit 489a494
Author: Madeleine Lee <[email protected]>
Date:   Fri Oct 27 14:44:45 2023 +0000

    Cleaned up and worked on test file, removed attempt to put fifo in header file and added a wrapper instead. Test compiles but hasn't been verified to work successfully yet.

commit c38a3d7
Author: Madeleine Lee <[email protected]>
Date:   Sat Oct 21 04:57:18 2023 +0000

    SendCarCAN test file compiles! But at what cost...

commit ad84abf
Author: Madeleine Lee <[email protected]>
Date:   Sat Oct 21 04:47:33 2023 +0000

    Made aa first draft of the SendCarCAN test file and attempted to get at the SendCarCAN file by exposing it with a macro mess. controls-leader code compiles, but the test file does not compile yet.

commit 3d1d906
Author: Madeleine Lee <[email protected]>
Date:   Fri Oct 20 21:06:52 2023 +0000

    Altered test macros so that we can define __TEST_SENDTRITIUM and print info while running tests on hardware or also define __TEST_SENDTRITIUM_SOFTWAREONLY to bypass hardware inputs/outputs.

commit 73dddf7
Author: Madeleine Lee <[email protected]>
Date:   Fri Oct 20 03:02:13 2023 +0000

    Added line to put messages from the motor into the CarCAN queue to be sent.

commit 90cb9c6
Author: Madeleine Lee <[email protected]>
Date:   Fri Oct 20 02:50:50 2023 +0000

    Deleted most putIOStateTimer thigns, added a macro and counter in the sendCarCAN loop to send the IO message at approximately the same frequency as before (250 ms), but this time using loops, delays, and counters. It won't be as accurate, but it should still be at a relatively similar frequency.

commit 5185426
Author: Madeleine Lee <[email protected]>
Date:   Sat Oct 14 20:29:23 2023 +0000

    Changed main loop to check the queue periodically instead of pending on a semaphore. The loop will check two semaphores- one to see if it's time to put an IO State message in the queue (based on if the putIOState timer has expired or not) and one to see if there's a message in the queuethat we should send.

commit 2d7dbbf
Author: Madeleine Lee <[email protected]>
Date:   Sat Oct 7 23:21:43 2023 +0000

    Started a test file for SendCarCAN.

commit 2f45100
Merge: 6f69ba9 fd33899
Author: ishdeshpa <[email protected]>
Date:   Tue Sep 26 00:09:02 2023 +0000

    merged in master, now builds. test still needs to be written and bugfixes made. also ignition switch message needs to be added.

commit 6f69ba9
Author: ishdeshpa <[email protected]>
Date:   Mon Sep 25 23:50:29 2023 +0000

    merge conflict resolved

commit de426c5
Author: ishdeshpa <[email protected]>
Date:   Mon Jul 10 19:36:13 2023 +0000

    adapted CAN_Queue into a library file and integrated with SendCarCAN

commit cfd0b7c
Author: ishdeshpa <[email protected]>
Date:   Sun Jul 9 22:16:56 2023 +0000

    renamed telemetry to send car can

commit 771a916
Author: Nathaniel Delgado <[email protected]>
Date:   Sat Jul 8 03:13:27 2023 +0000

    Merged functionality of SendCarCAN into Telemetry and removed SendCarCAN remnants

* mostly working

* ReadTritium fixes

* Squashed commit of the following:

commit 66958b8
Author: Nathaniel Delgado <[email protected]>
Date:   Sat Dec 16 18:29:35 2023 -0600

    SendCarCAN Restructure (#337)

    * Merged functionality of SendCarCAN into Telemetry and removed SendCarCAN remnants

    * renamed telemetry to send car can

    * adapted CAN_Queue into a library file and integrated with SendCarCAN

    * merge conflict resolved

    * Started a test file for SendCarCAN.

    * Changed main loop to check the queue periodically instead of pending on a semaphore. The loop will check two semaphores- one to see if it's time to put an IO State message in the queue (based on if the putIOState timer has expired or not) and one to see if there's a message in the queuethat we should send.

    * Deleted most putIOStateTimer thigns, added a macro and counter in the sendCarCAN loop to send the IO message at approximately the same frequency as before (250 ms), but this time using loops, delays, and counters. It won't be as accurate, but it should still be at a relatively similar frequency.

    * Added line to put messages from the motor into the CarCAN queue to be sent.

    * Altered test macros so that we can define __TEST_SENDTRITIUM and print info while running tests on hardware or also define __TEST_SENDTRITIUM_SOFTWAREONLY to bypass hardware inputs/outputs.

    * Made aa first draft of the SendCarCAN test file and attempted to get at the SendCarCAN file by exposing it with a macro mess. controls-leader code compiles, but the test file does not compile yet.

    * SendCarCAN test file compiles! But at what cost...

    * Cleaned up and worked on test file, removed attempt to put fifo in header file and added a wrapper instead. Test compiles but hasn't been verified to work successfully yet.

    * Added ability to print FIFO queue indexes, added ReadTritium task in SendCarCAN test, fixed CAN initialization to read CarCAN but also initialize MOTORCAN.

    * Test file updates from testing on hardware.

    * Deleted extra lines added when merging.

    * Moved mutex, semaphore creation and fifo renewal to a new SendCarCAN_Init function so that other tasks can put things into the queue before SendCarCAN is ready. Additionally, created a new static task in SendCarCAN.c called PutIOState which periodically sends messages over CarCAN.

    * Changed PutIOState to send directly instead of putting messages in the queue to be sent by SendCarCAN later.

    * Updates from hardware testing: added counter array to reduce frequency at which we forwared motor messages onto CarCAN, moved init functions in test file, added Renode independent watchdog fix.

    * Added while loop to putIOState

    * Test file changes for last minute panic debugging. Added an array to see what IDS are being received.

    * Addressing review comments: updated SendTritium macros, removed motorMsgCount queue, downsized SendCarCAN FIFO.

    * Revisions to SendCarCAN and test file to allow messages to be inspected in GDB using variables instead of prints which were overwhelming UART.

    * Updated NUM_CAN_IDS to MAX_CAN_ID in the CANId enum.

    * Added commas to enum to match new enum generation format.

    * Memset the gTxMessage.Data to zero since one-byte messages weren't clearing out old data in the rest of the bytes, updated comments in the test file.

    * Fixed accidental deletion in docs.

    * Changes from integration with BPS: flipped reading of ignition pins in PutIOState to account for the inverted logic, added a new bit of information to PutIOState in byte 3, bit 2 which tells BPS if the array contactor should be turned on or not (true if IGN_1 or IGN_2 are on). This is necessary because  when the ignition is switched to motor state, the array pin is turned off (only one or the other is on at a time). Note: in the future we'd like to use the GPIO read settings to account for the inverted ignition logic so we don't have to negate every Minions_Read.

    * Addressed review comments: Shifted task priorities to be next to each other, added to the comment for SendCarCAN_Put.

    * addressed review comments

    ---------

    Co-authored-by: ishdeshpa <[email protected]>
    Co-authored-by: Madeleine Lee <[email protected]>

commit 5c13022
Author: Nathaniel Delgado <[email protected]>
Date:   Wed Dec 13 14:59:37 2023 -0600

    Added bps can sim for integration simulation

* removed duplicates

* fixed merge issue in SendTritium.c (closes #381)

* moved macros from ReadCarCAN.c to ReadCarCAN.h so they are visible in docs

* fixed header comment so doxygen recognizes it

* changed lang to en

* created helper script for printing all sphinx references

* updated readtritium docs

* updated Minions.rst

* Revert mistakenly pushed docs commits.

Revert "updated Minions.rst"

This reverts commit 96aab88.

Revert "updated readtritium docs"

This reverts commit 6c10365.

Revert "created helper script for printing all sphinx references"

This reverts commit a9a9b4e.

Revert "changed lang to en"

This reverts commit 929f242.

Revert "fixed header comment so doxygen recognizes it"

This reverts commit dd36bc4.

Revert "moved macros from ReadCarCAN.c to ReadCarCAN.h so they are visible in docs"

This reverts commit 47d011f.

* Removed redundant code

* Apply suggestions from code review

Co-authored-by: Diya Rajon <[email protected]>
Co-authored-by: Madeleine Lee <[email protected]>

* Feature/GitHub workflow fix (#396)

* Changed github actions workflow to use install script from Embedded-Sharepoint

* initialize submodules before install tools

* fixed directory

* changed flags

* changed the target that is the phony so that later we could add additional targets and change what 'leader' points to

* addressed more review comments

* Apply suggestions from code review

Co-authored-by: Madeleine Lee <[email protected]>

* Apply suggestions from code review

Co-authored-by: Diya Rajon <[email protected]>

---------

Co-authored-by: ishdeshpa <[email protected]>
Co-authored-by: Madeleine Lee <[email protected]>
Co-authored-by: Nathaniel Delgado <[email protected]>
Co-authored-by: Diya Rajon <[email protected]>
Co-authored-by: Madeleine Lee <[email protected]>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Get rid of CAN Queue Rewrite SendCarCAN
6 participants