Comparar commits

..

36 commits

Autor SHA1 Mensaje Fecha
30fb6e7b75 Mettre à jour 'README.md' 2023-04-12 18:24:16 +02:00
d3a8307d90 Plateau a continuer 2023-04-11 15:34:05 +02:00
7163e05d17 Merge branch 'master' of https://git.etud.insa-toulouse.fr/marce/Voilier 2023-04-11 14:54:07 +02:00
bea44470ab Plateau à finir 2023-04-11 14:53:48 +02:00
7e19976938 Mettre à jour 'Drivers/Sources/Driver_ADC.c' 2023-04-11 14:16:32 +02:00
730d0cddd4 Mettre à jour 'Drivers/Sources/Driver_Timer.c' 2023-04-11 13:57:50 +02:00
da4f66ed73 Mettre à jour 'Drivers/Sources/Driver_Timer.c' 2023-04-11 13:57:19 +02:00
9e9fc9eb4e Mettre à jour 'Drivers/Sources/Driver_GPIO.c' 2023-04-11 13:52:20 +02:00
e06fea7cc1 Mettre à jour 'README.md' 2023-04-11 13:43:26 +02:00
4bf91d54e3 Mettre à jour 'README.md' 2023-04-11 13:43:17 +02:00
4d96c1d53e Mettre à jour 'README.md' 2023-04-11 13:43:01 +02:00
8e19bd842c Mettre à jour 'README.md' 2023-04-11 13:36:30 +02:00
6ac0111519 Mettre à jour 'README.md' 2023-04-11 12:38:40 +02:00
6b7db409d8 Mettre à jour 'README.md' 2023-04-11 12:27:07 +02:00
791fabf4a2 Mettre à jour 'README.md' 2023-04-11 12:26:11 +02:00
b1378c7cac Mettre à jour 'README.md' 2023-04-11 12:24:59 +02:00
24491a1b10 Mettre à jour 'README.md' 2023-04-11 12:24:06 +02:00
676a21ae66 Mettre à jour 'README.md' 2023-04-11 12:23:23 +02:00
9f8d4e08f3 Mettre à jour 'README.md' 2023-04-11 12:13:36 +02:00
6fb6599efe Merge branch 'master' of https://git.etud.insa-toulouse.fr/marce/Voilier 2023-04-11 12:11:55 +02:00
ed00a94bee Mettre à jour 'README.md' 2023-04-11 12:10:50 +02:00
f98a22a727 Image 2023-04-11 12:10:20 +02:00
bf18c62846 Mettre à jour 'README.md' 2023-04-11 12:08:42 +02:00
2ed0bbf2c6 Mettre à jour 'README.md' 2023-04-11 11:27:49 +02:00
b6bc2334cb Mettre à jour 'README.md' 2023-04-11 11:26:19 +02:00
913ea43e8e Mettre à jour 'README.md' 2023-04-11 11:26:11 +02:00
f66834b128 Mettre à jour 'README.md' 2023-04-11 11:25:53 +02:00
cacec5a10a Mettre à jour 'README.md' 2023-04-11 11:24:35 +02:00
79d21ffed0 Mettre à jour 'README.md' 2023-04-11 11:24:15 +02:00
810204ad34 Mettre à jour 'README.md' 2023-04-11 11:23:33 +02:00
8df17e9e8f Mettre à jour 'README.md' 2023-04-11 11:22:40 +02:00
d926eef475 Test picture 2023-04-11 11:22:02 +02:00
a631f22759 README Under Parts 2023-04-11 11:16:37 +02:00
aef43a4062 README Parts 2023-04-11 10:36:46 +02:00
8a7029b012 README on 2023-04-11 10:25:17 +02:00
78c82605ae Plateau Start 2023-04-07 15:36:11 +02:00
Se han modificado 17 ficheros con 448 adiciones y 234 borrados

Ver fichero

@ -9,6 +9,7 @@ char GPIO_Pin ; //numero de 0 a 15
char GPIO_Conf ; // voir ci dessous char GPIO_Conf ; // voir ci dessous
} MyGPIO_Struct_TypeDef ; } MyGPIO_Struct_TypeDef ;
#define Out_PullUp 0x01
#define In_Floating 0x4 #define In_Floating 0x4
#define In_PullDown 0x8 #define In_PullDown 0x8
#define In_PullUp 0x8 #define In_PullUp 0x8

Ver fichero

@ -2,29 +2,29 @@
#include "Driver_GPIO.h" #include "Driver_GPIO.h"
void (*PtrfctADC)(void); //Déclaration du pointeur de fonction ADC void (*PtrfctADC)(void); /* Déclaration du pointeur de fonction ADC pour l'interrupt */
//---------------------INIT-------------------// //---------------------INIT-------------------//
void MyADC_Base_Init(MyADC_Struct_TypeDef * ADC){ void MyADC_Base_Init(MyADC_Struct_TypeDef * ADC){
MyGPIO_Struct_TypeDef * GPIO_ADC; //Déclaration du GPIO de l'ADC MyGPIO_Struct_TypeDef * GPIO_ADC; /* Déclaration du GPIO lié à l'ADC */
RCC->CFGR |= RCC_CFGR_ADCPRE_DIV6; //Division par 6 de la clock (72MHz) pour l'ADC (12MHz) RCC->CFGR |= RCC_CFGR_ADCPRE_DIV6; /*Division par 6 de la clock (72MHz) pour l'ADC (12MHz) car clock max ADC : 14MHz */
RCC->APB2ENR |= RCC_APB2ENR_ADC1EN; //Start clock ADC1 RCC->APB2ENR |= RCC_APB2ENR_ADC1EN; /* Start clock de l'ADC1 */
GPIO_ADC->GPIO = GPIOC; //Initialisation du GPIO de l'ADC GPIO_ADC->GPIO = GPIOC; /* Initialisation du GPIO lié à l'ADC */
GPIO_ADC->GPIO_Conf = In_Analog; GPIO_ADC->GPIO_Conf = In_Analog;
GPIO_ADC->GPIO_Pin = 0; GPIO_ADC->GPIO_Pin = 0;
MyGPIO_Init(GPIO_ADC); MyGPIO_Init(GPIO_ADC);
ADC1->SQR1 &= ADC_SQR1_L; //fixe le nombre de conversion à 1 ADC1->SQR1 &= ADC_SQR1_L; /* Fixation du nombre de conversion à 1 */
ADC1->SQR3|= ADC->Channel; //indique la voie à convertir ADC1->SQR3|= ADC->Channel; /* Choix de la voie à convertir */
ADC1->CR2 |= ADC_CR2_EXTTRIG; //activation du trigger externe ADC1->CR2 |= ADC_CR2_EXTTRIG; /* Activation du trigger externe */
ADC1->CR2 |= ADC_CR2_EXTSEL; //event externe choisis : SWSTART ADC1->CR2 |= ADC_CR2_EXTSEL; /* event externe choisis : SWSTART */
MyADC_Base_Start(ADC->ADC); //Sart ADC1 et Horloge ADC1 MyADC_Base_Start(ADC->ADC); /* Sart ADC1 et Horloge ADC1 */
} }
@ -36,26 +36,25 @@ void MyADC_Base_Start(ADC_TypeDef * ADC){
//------------------INTERRUPTION--------------// //------------------INTERRUPTION--------------//
void MyADC_Base_Interuption(ADC_TypeDef * ADC){ void MyADC_Base_Interuption(ADC_TypeDef * ADC){
//Activation du trigger externe /* Activation du trigger externe */
ADC->CR1 |= ADC_CR1_EOCIE; //Interruption de l'ADC autorisée ADC->CR1 |= ADC_CR1_EOCIE; /* Interruption de l'ADC autorisée */
NVIC->ISER[0] |= (0x1<<ADC1_2_IRQn); //Interruption active au niveau NVIC NVIC->ISER[0] |= (0x1<<ADC1_2_IRQn); /* Interruption active au niveau NVIC */
NVIC->IP[ADC1_2_IRQn] |= 1<<4; //Affectation du niveau de priorité NVIC->IP[ADC1_2_IRQn] |= 1<<4; /* Affectation du niveau de priorité */
} }
//--------------------HANDLER-----------------// //--------------------HANDLER-----------------//
void ADC1_2_IRQHandler (void) { void ADC1_2_IRQHandler (void) {
(*PtrfctADC)(); //Appel de la fonction pointée par le pointeur fonction ADC (*PtrfctADC)(); /* Appel de la fonction pointée par le pointeur fonction ADC */
MyADC_Base_Start(ADC1); MyADC_Base_Start(ADC1);
ADC1->SR &= ~ADC_SR_EOC; //RAZ du flag end of conversion ADC1->SR &= ~ADC_SR_EOC; /* RAZ du flag de fin de conversion */
} }
//--------------------DATA--------------------// //--------------------DATA--------------------//
int MyADC_Base_Result (MyADC_Struct_TypeDef * ADC){ int MyADC_Base_Result (MyADC_Struct_TypeDef * ADC){
return ADC1->DR & ~((0x0F)<<12); //Retour de la conversion de l'ADC return ADC1->DR & ~((0x0F)<<12); /* Récuperation du résultat de la conversion de l'ADC */
} }
//-------------------POINTEUR-----------------// //-------------------POINTEUR-----------------//
void MyADC_Init_Periph (void (*fct)(void)){ void MyADC_Init_Periph (void (*fct)(void)){
PtrfctADC=fct; //Affectation du pointeur de fonction ADC PtrfctADC=fct; /* Affectation du pointeur de fonction ADC */
} }

Ver fichero

@ -5,26 +5,26 @@
void MyGPIO_Init ( MyGPIO_Struct_TypeDef * GPIOStructPtr ) void MyGPIO_Init ( MyGPIO_Struct_TypeDef * GPIOStructPtr )
{ {
/* Activation of the GPIO port specific clock */ /* Activation de la clock liée au GPIO sélectionné */
if (GPIOStructPtr->GPIO == GPIOA) if (GPIOStructPtr->GPIO == GPIOA)
{ {
RCC->APB2ENR |= RCC_APB2ENR_IOPAEN; RCC->APB2ENR |= RCC_APB2ENR_IOPAEN;
} }
else if (GPIOStructPtr->GPIO == GPIOB) else if (GPIOStructPtr->GPIO == GPIOB)
{ {
RCC->APB2ENR |= RCC_APB2ENR_IOPBEN; RCC->APB2ENR |= RCC_APB2ENR_IOPBEN;
} }
else if (GPIOStructPtr->GPIO == GPIOC) else if (GPIOStructPtr->GPIO == GPIOC)
{ {
RCC->APB2ENR |= RCC_APB2ENR_IOPCEN; RCC->APB2ENR |= RCC_APB2ENR_IOPCEN;
} }
else if (GPIOStructPtr->GPIO == GPIOD) else if (GPIOStructPtr->GPIO == GPIOD)
{ {
RCC->APB2ENR |= RCC_APB2ENR_IOPDEN; RCC->APB2ENR |= RCC_APB2ENR_IOPDEN;
} }
/* Reset, and then configuration writing of the selected GPIO Pin */ /* Reset & configuration de la pin avec le mode adéquat */
if(GPIOStructPtr->GPIO_Pin <= 8) if(GPIOStructPtr->GPIO_Pin <= 8)
{ {
GPIOStructPtr->GPIO->CRL &= ~0xF<<(4*(GPIOStructPtr->GPIO_Pin)); GPIOStructPtr->GPIO->CRL &= ~0xF<<(4*(GPIOStructPtr->GPIO_Pin));
@ -36,6 +36,7 @@ void MyGPIO_Init ( MyGPIO_Struct_TypeDef * GPIOStructPtr )
GPIOStructPtr->GPIO->CRH |= (GPIOStructPtr->GPIO_Conf)<<(4*((GPIOStructPtr->GPIO_Pin)%8)); GPIOStructPtr->GPIO->CRH |= (GPIOStructPtr->GPIO_Conf)<<(4*((GPIOStructPtr->GPIO_Pin)%8));
} }
/* Ecriture de l'ODR pour choisir entre pulldown & pushpull*/
if(GPIOStructPtr->GPIO_Conf == (char)In_PullDown) if(GPIOStructPtr->GPIO_Conf == (char)In_PullDown)
{ {
GPIOStructPtr->GPIO->ODR &= ~(0x1<<(GPIOStructPtr->GPIO_Pin)); GPIOStructPtr->GPIO->ODR &= ~(0x1<<(GPIOStructPtr->GPIO_Pin));
@ -49,7 +50,8 @@ void MyGPIO_Init ( MyGPIO_Struct_TypeDef * GPIOStructPtr )
//----------------------------READ--------------------------// //----------------------------READ--------------------------//
int MyGPIO_Read ( GPIO_TypeDef * GPIO , char GPIO_Pin ){ int MyGPIO_Read ( GPIO_TypeDef * GPIO , char GPIO_Pin ){
int etatbit; int etatbit;
//On vérifie si la valeur lue dans l'IDR est un 0 ou un 1
/* Verification de la valeur de l'IDR */
if((GPIO->IDR & (1<<GPIO_Pin))!=0){ if((GPIO->IDR & (1<<GPIO_Pin))!=0){
etatbit = 1; etatbit = 1;
} }
@ -61,13 +63,16 @@ int MyGPIO_Read ( GPIO_TypeDef * GPIO , char GPIO_Pin ){
//---------------------SET-------------------// //---------------------SET-------------------//
void MyGPIO_Set ( GPIO_TypeDef * GPIO , char GPIO_Pin ){ void MyGPIO_Set ( GPIO_TypeDef * GPIO , char GPIO_Pin ){
/*Ecriture du 1 sur le numéro de la pin dans le registre BSRR*/
GPIO->BSRR |= (1 << GPIO_Pin); GPIO->BSRR |= (1 << GPIO_Pin);
} }
//---------------------RESET-----------------// //---------------------RESET-----------------//
void MyGPIO_Reset ( GPIO_TypeDef * GPIO , char GPIO_Pin ){ void MyGPIO_Reset ( GPIO_TypeDef * GPIO , char GPIO_Pin ){
/*Ecriture du 1 sur le numéro de la pin dans le registre BRR*/
GPIO->BRR = (1 << GPIO_Pin); GPIO->BRR = (1 << GPIO_Pin);
//Pas besoin de | puisque les 0 n'impactent pas la fonction reset
} }
//---------------------TOGGLE-----------------// //---------------------TOGGLE-----------------//

Ver fichero

@ -2,6 +2,8 @@
//-----------------------INITIALISATION TIMER---------------------// //-----------------------INITIALISATION TIMER---------------------//
void MyTimer_Base_Init(MyTimer_Struct_TypeDef * Timer){ void MyTimer_Base_Init(MyTimer_Struct_TypeDef * Timer){
/* Activation de la clock liée au TIMER sélectionné */
if(Timer->Timer == TIM1){ if(Timer->Timer == TIM1){
//RCC->APB2ENR |= 0x0001<<11; //RCC->APB2ENR |= 0x0001<<11;
RCC->APB2ENR |= RCC_APB2ENR_TIM1EN; RCC->APB2ENR |= RCC_APB2ENR_TIM1EN;
@ -19,6 +21,7 @@ void MyTimer_Base_Init(MyTimer_Struct_TypeDef * Timer){
RCC->APB1ENR |= RCC_APB1ENR_TIM4EN; RCC->APB1ENR |= RCC_APB1ENR_TIM4EN;
} }
/* Load des valeurs de l'ARR et du PSC pour définir la période de comptage du TIMER et sa limite*/
Timer->Timer->ARR = Timer->ARR; Timer->Timer->ARR = Timer->ARR;
Timer->Timer->PSC = Timer->PSC; Timer->Timer->PSC = Timer->PSC;
@ -27,20 +30,21 @@ void MyTimer_Base_Init(MyTimer_Struct_TypeDef * Timer){
//-----------------------START----------------------// //-----------------------START----------------------//
void MyTimer_Base_Start(TIM_TypeDef * Timer){ void MyTimer_Base_Start(TIM_TypeDef * Timer){
Timer->CR1 |= TIM_CR1_CEN; //Masque OU pour placer un 1 décalé avec des 0 Timer->CR1 |= TIM_CR1_CEN; //* Masque OU pour placer un 1 décalé avec des 0 */
} }
//------------------------STOP----------------------// //------------------------STOP----------------------//
void MyTimer_Base_Stop(TIM_TypeDef * Timer){ void MyTimer_Base_Stop(TIM_TypeDef * Timer){
Timer->CR1 |= ~TIM_CR1_CEN; //Masque ET pour placer un 0 décalé avec des 1 (~) Timer->CR1 |= ~TIM_CR1_CEN; /* Masque ET pour placer un 0 décalé avec des 1 (~) */
} }
void MyTimer_PWM( MyTimer_Struct_TypeDef * Timer, uint16_t cycle){ void MyTimer_PWM( MyTimer_Struct_TypeDef * Timer, uint16_t cycle){
Timer->Timer->CCMR1 &= ~TIM_CCMR1_OC1M_0; //Configuration du canal CH1
Timer->Timer->CCMR1 |= TIM_CCMR1_OC1M_1| TIM_CCMR1_OC1M_2; // Ajouter 110 aux bits OC1M (registre CCMR1)
Timer->Timer->CCER |= TIM_CCER_CC1E; // Canal CH1 validé par bit CC1E (registre CCER) Timer->Timer->CCMR1 &= ~TIM_CCMR1_OC1M_0; /* Configuration du canal CH1 */
Timer->Timer->CR1 |= TIM_CR1_CEN; // Lancement du timer Timer->Timer->CCMR1 |= TIM_CCMR1_OC1M_1| TIM_CCMR1_OC1M_2; /* Ajouter 110 aux bits OC1M (registre CCMR1) */
Timer->Timer->CCR1 = (cycle * Timer->ARR) / 100; // Fixer la durée à 20%
Timer->Timer->CCER |= TIM_CCER_CC1E; /* Canal CH1 validé par bit CC1E (registre CCER) */
Timer->Timer->CR1 |= TIM_CR1_CEN; /* Lancement du timer */
Timer->Timer->CCR1 = (cycle * Timer->ARR) / 100; /* Fixer la durée à 20% */
} }

Ver fichero

@ -18,12 +18,12 @@ void UART_init(MyUART_Struct_Typedef * UART)
USART1->CR1 |= USART_CR1_UE; // Activer l'USART USART1->CR1 |= USART_CR1_UE; // Activer l'USART
USART1->CR1 &= ~USART_CR1_M; // Choisir la taille 8bits de donnée USART1->CR1 &= ~USART_CR1_M; // Choisir la taille 8bits de donnée
USART1->CR2 |= USART_CR2_STOP; // 1 seul bit de stop USART1->CR2 |= USART_CR2_STOP; // 1 seul bit de stop
//USART1->BRR |= 468 << 4; // Fixe le baud rate à 9600bps partie entière //USART1->BRR |= 468 << 4; // Fixe le baud rate à 9600bps partie entière
//USART1->BRR |= 75; // Fixe le baud rate à 9600bps partie fractionnaire //USART1->BRR |= 75; // Fixe le baud rate à 9600bps partie fractionnaire
UART->UART->BRR = 72000000/(UART->baudrate); UART->UART->BRR = 72000000/(UART->baudrate);
USART1->CR1 |= USART_CR1_TE; // Autoriser la transmission USART1->CR1 |= USART_CR1_TE; // Autoriser la transmission
USART1->CR1 |= USART_CR1_RE; // Activer la réception USART1->CR1 |= USART_CR1_RE; // Activer la réception
// USART1->CR1 |= USART_CR1_TCIE; // Activer l'interruption de transmission // USART1->CR1 |= USART_CR1_TCIE; // Activer l'interruption de transmission
USART1->CR1 |= USART_CR1_RXNEIE; // Activer l'interruption de réception USART1->CR1 |= USART_CR1_RXNEIE; // Activer l'interruption de réception
UART_interruption(UART); UART_interruption(UART);

Ver fichero

@ -1,39 +1 @@
#include "Girouette.h"
#include "Driver_ADC.h"
#include "Driver_Timer.h" #include "Driver_Timer.h"
#include "Driver_GPIO.h"
void init_encoder_timer (void){
//Déclaration du Timer et de ses GPIO
MyGPIO_Struct_TypeDef * GPIO_PB6;
MyGPIO_Struct_TypeDef * GPIO_PB7;
MyTimer_Struct_TypeDef * Encoder_Timer;
//Parametrage des GPIO
GPIO_PB6->GPIO = GPIOB;
GPIO_PB6->GPIO_Conf = In_Floating;
GPIO_PB6->GPIO_Pin = 6;
MyGPIO_Init(GPIO_PB6);
GPIO_PB7->GPIO = GPIOB;
GPIO_PB7->GPIO_Conf = In_Floating;
GPIO_PB7->GPIO_Pin = 7;
MyGPIO_Init(GPIO_PB7);
//Parametrage du Timer
Encoder_Timer->Timer = TIM4;
Encoder_Timer->ARR = 400; //ARR doit être supérieur à 360° puisque la RAZ du Timer se fait au tour complet de la girouette
Encoder_Timer->PSC = 0; //On ne divise pas la précision de notre mesure
MyTimer_Base_Init(Encoder_Timer);
//Passage du Timer en mode Encoder
TIM4->SMCR &= ~(0x0007);
TIM4->SMCR |= TIM_SMCR_SMS_1;
TIM4->CCMR1 &= ~(0xF2F2);
TIM4->CCMR1 |= TIM_CCMR1_CC1S_0;
TIM4->CCMR1 |= TIM_CCMR1_CC2S_0;
TIM4->CCER &= TIM_CCER_CC1P;
TIM4->CCER &= TIM_CCER_CC2P;
TIM4->CR1 |= TIM_CR1_CEN;
}

Ver fichero

@ -1,3 +0,0 @@
void init_encoder_timer (void);

Ver fichero

@ -0,0 +1,42 @@
#include "Driver_Timer.h"
#include "Driver_UART.h"
#include "Plateau.h"
#include "Driver_GPIO.h"
void Plateau_init(void)
{
MyTimer_Struct_TypeDef Timer;
MyGPIO_Struct_TypeDef Pin_Sens;
Pin_Sens.GPIO=GPIOB;
Pin_Sens.GPIO_Pin=1;
Pin_Sens.GPIO_Conf = Out_PullUp;
//Fréquence
Timer.Timer = TIM3;
Timer.ARR=3599;
Timer.PSC=0;
MyTimer_Base_Init(&Timer);
MyGPIO_Init(&Pin_Sens);
MyTimer_PWM(&Timer, 50);
MyTimer_Base_Start(TIM3);
Plateau_direction(DROITE);
}
void Plateau_direction(uint8_t Sens)
{
if(Sens == DROITE)
MyGPIO_Set(GPIOB,1);
if (Sens == GAUCHE)
MyGPIO_Reset(GPIOB,1);
}

Ver fichero

@ -0,0 +1,12 @@
#ifndef MYPLATEAU_H
#define MYPLATEAU_H
#include "stm32f10x.h"
#define DROITE 0x1
#define GAUCHE 0x0
void Plateau_init(void);
void Plateau_direction(uint8_t Sens);
#endif

Ver fichero

@ -0,0 +1,32 @@
#include "telecommande.h"
#include "Driver_GPIO.h"
#include "Plateau.h"
MyUART_Struct_Typedef UART_plateau = {USART1,9600};
void init_telecommande(void)
{
UART_InitGPIO(&UART_plateau);
UART_init(&UART_plateau);
}
void telecommande_plateau (int data)
{
int datar;
UART_send(data);
datar = data;
if(datar >= 0)
Plateau_direction(DROITE);
else
Plateau_direction(GAUCHE);
}
void testRemote(void)
{
UART_send('t');
UART_send('e');
UART_send('s');
UART_send('t');
}

Ver fichero

@ -0,0 +1,12 @@
#ifndef TELECOMMANDE_H
#define TELECOMMANDE_H
#include "Driver_UART.h"
#include "stm32f10x.h"
void init_telecommande(void);
void telecommande_plateau (int data);
void testRemote(void);
#endif

Ver fichero

@ -26,7 +26,189 @@
<ToolsetNumber>0x4</ToolsetNumber> <ToolsetNumber>0x4</ToolsetNumber>
<ToolsetName>ARM-ADS</ToolsetName> <ToolsetName>ARM-ADS</ToolsetName>
<TargetOption> <TargetOption>
<CLKADS>12000000</CLKADS> <CLKADS>8000000</CLKADS>
<OPTTT>
<gFlags>1</gFlags>
<BeepAtEnd>1</BeepAtEnd>
<RunSim>0</RunSim>
<RunTarget>1</RunTarget>
<RunAbUc>0</RunAbUc>
</OPTTT>
<OPTHX>
<HexSelection>1</HexSelection>
<FlashByte>65535</FlashByte>
<HexRangeLowAddress>0</HexRangeLowAddress>
<HexRangeHighAddress>0</HexRangeHighAddress>
<HexOffset>0</HexOffset>
</OPTHX>
<OPTLEX>
<PageWidth>79</PageWidth>
<PageLength>66</PageLength>
<TabStop>8</TabStop>
<ListingPath>.\Listings\</ListingPath>
</OPTLEX>
<ListingPage>
<CreateCListing>1</CreateCListing>
<CreateAListing>1</CreateAListing>
<CreateLListing>1</CreateLListing>
<CreateIListing>0</CreateIListing>
<AsmCond>1</AsmCond>
<AsmSymb>1</AsmSymb>
<AsmXref>0</AsmXref>
<CCond>1</CCond>
<CCode>0</CCode>
<CListInc>0</CListInc>
<CSymb>0</CSymb>
<LinkerCodeListing>0</LinkerCodeListing>
</ListingPage>
<OPTXL>
<LMap>1</LMap>
<LComments>1</LComments>
<LGenerateSymbols>1</LGenerateSymbols>
<LLibSym>1</LLibSym>
<LLines>1</LLines>
<LLocSym>1</LLocSym>
<LPubSym>1</LPubSym>
<LXref>0</LXref>
<LExpSel>0</LExpSel>
</OPTXL>
<OPTFL>
<tvExp>1</tvExp>
<tvExpOptDlg>0</tvExpOptDlg>
<IsCurrentTarget>0</IsCurrentTarget>
</OPTFL>
<CpuCode>18</CpuCode>
<DebugOpt>
<uSim>1</uSim>
<uTrg>0</uTrg>
<sLdApp>1</sLdApp>
<sGomain>1</sGomain>
<sRbreak>1</sRbreak>
<sRwatch>1</sRwatch>
<sRmem>1</sRmem>
<sRfunc>1</sRfunc>
<sRbox>1</sRbox>
<tLdApp>1</tLdApp>
<tGomain>1</tGomain>
<tRbreak>1</tRbreak>
<tRwatch>1</tRwatch>
<tRmem>1</tRmem>
<tRfunc>0</tRfunc>
<tRbox>1</tRbox>
<tRtrace>1</tRtrace>
<sRSysVw>1</sRSysVw>
<tRSysVw>1</tRSysVw>
<sRunDeb>0</sRunDeb>
<sLrtime>0</sLrtime>
<bEvRecOn>1</bEvRecOn>
<bSchkAxf>0</bSchkAxf>
<bTchkAxf>0</bTchkAxf>
<nTsel>6</nTsel>
<sDll></sDll>
<sDllPa></sDllPa>
<sDlgDll></sDlgDll>
<sDlgPa></sDlgPa>
<sIfile></sIfile>
<tDll></tDll>
<tDllPa></tDllPa>
<tDlgDll></tDlgDll>
<tDlgPa></tDlgPa>
<tIfile></tIfile>
<pMon>STLink\ST-LINKIII-KEIL_SWO.dll</pMon>
</DebugOpt>
<TargetDriverDllRegistry>
<SetRegEntry>
<Number>0</Number>
<Key>ARMRTXEVENTFLAGS</Key>
<Name>-L70 -Z18 -C0 -M0 -T1</Name>
</SetRegEntry>
<SetRegEntry>
<Number>0</Number>
<Key>DLGDARM</Key>
<Name>(1010=937,133,1313,690,0)(1007=-1,-1,-1,-1,0)(1008=-1,-1,-1,-1,0)(1009=-1,-1,-1,-1,0)(100=-1,-1,-1,-1,0)(110=-1,-1,-1,-1,0)(111=-1,-1,-1,-1,0)(1011=-1,-1,-1,-1,0)(180=-1,-1,-1,-1,0)(120=1357,482,1778,909,0)(121=1042,189,1463,616,0)(122=546,289,967,716,0)(123=-1,-1,-1,-1,0)(140=-1,-1,-1,-1,0)(240=-1,-1,-1,-1,0)(190=-1,-1,-1,-1,0)(200=-1,-1,-1,-1,0)(170=-1,-1,-1,-1,0)(130=911,135,1505,886,0)(131=997,343,1591,1094,0)(132=-1,-1,-1,-1,0)(133=-1,-1,-1,-1,0)(160=1375,56,1823,470,0)(161=1383,268,1831,682,0)(162=-1,-1,-1,-1,0)(210=-1,-1,-1,-1,0)(211=-1,-1,-1,-1,0)(220=-1,-1,-1,-1,0)(221=-1,-1,-1,-1,0)(230=-1,-1,-1,-1,0)(234=-1,-1,-1,-1,0)(231=-1,-1,-1,-1,0)(232=-1,-1,-1,-1,0)(233=-1,-1,-1,-1,0)(150=240,283,843,1034,0)(151=-1,-1,-1,-1,0)</Name>
</SetRegEntry>
<SetRegEntry>
<Number>0</Number>
<Key>ARMDBGFLAGS</Key>
<Name>-T0</Name>
</SetRegEntry>
<SetRegEntry>
<Number>0</Number>
<Key>ST-LINKIII-KEIL_SWO</Key>
<Name>-U066FFF575256867067031930 -O206 -SF10000 -C0 -A0 -I0 -HNlocalhost -HP7184 -P1 -N00("ARM CoreSight SW-DP (ARM Core") -D00(1BA01477) -L00(0) -TO65554 -TC10000000 -TT10000000 -TP21 -TDS8007 -TDT0 -TDC1F -TIEFFFFFFFF -TIP8 -FO7 -FD20000000 -FC1000 -FN1 -FF0STM32F10x_128.FLM -FS08000000 -FL020000 -FP0($$Device:STM32F103RB$Flash\STM32F10x_128.FLM)</Name>
</SetRegEntry>
<SetRegEntry>
<Number>0</Number>
<Key>UL2CM3</Key>
<Name>-U -O206 -S8 -C0 -P00 -N00("") -D00(00000000) -L00(0) -TO65554 -TC10000000 -TT10000000 -TP21 -TDS8007 -TDT0 -TDC1F -TIEFFFFFFFF -TIP8 -FO7 -FD20000000 -FC1000 -FN1 -FF0STM32F10x_128.FLM -FS08000000 -FL020000 -FP0($$Device:STM32F103RB$Flash\STM32F10x_128.FLM)</Name>
</SetRegEntry>
</TargetDriverDllRegistry>
<Breakpoint/>
<Tracepoint>
<THDelay>0</THDelay>
</Tracepoint>
<DebugFlag>
<trace>0</trace>
<periodic>1</periodic>
<aLwin>0</aLwin>
<aCover>0</aCover>
<aSer1>1</aSer1>
<aSer2>0</aSer2>
<aPa>0</aPa>
<viewmode>1</viewmode>
<vrSel>0</vrSel>
<aSym>0</aSym>
<aTbox>0</aTbox>
<AscS1>0</AscS1>
<AscS2>0</AscS2>
<AscS3>0</AscS3>
<aSer3>0</aSer3>
<eProf>0</eProf>
<aLa>0</aLa>
<aPa1>0</aPa1>
<AscS4>0</AscS4>
<aSer4>0</aSer4>
<StkLoc>0</StkLoc>
<TrcWin>0</TrcWin>
<newCpu>0</newCpu>
<uProt>0</uProt>
</DebugFlag>
<LintExecutable></LintExecutable>
<LintConfigFile></LintConfigFile>
<bLintAuto>0</bLintAuto>
<bAutoGenD>0</bAutoGenD>
<LntExFlags>0</LntExFlags>
<pMisraName></pMisraName>
<pszMrule></pszMrule>
<pSingCmds></pSingCmds>
<pMultCmds></pMultCmds>
<pMisraNamep></pMisraNamep>
<pszMrulep></pszMrulep>
<pSingCmdsp></pSingCmdsp>
<pMultCmdsp></pMultCmdsp>
<LogicAnalyzers>
<Wi>
<IntNumber>0</IntNumber>
<FirstString>((PORTA &amp; 0x00000020) &gt;&gt; 5 &amp; 0x20) &gt;&gt; 5</FirstString>
<SecondString>FF000000000000000000000000000000E0FFEF400100000000000000000000000000000028504F5254412026203078303030303030323029203E3E2035000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000100000001000000000000000000F03F1700000000000000000000000000000000000000DA040008</SecondString>
</Wi>
</LogicAnalyzers>
<DebugDescription>
<Enable>1</Enable>
<EnableFlashSeq>0</EnableFlashSeq>
<EnableLog>0</EnableLog>
<Protocol>2</Protocol>
<DbgClock>10000000</DbgClock>
</DebugDescription>
</TargetOption>
</Target>
<Target>
<TargetName>cible</TargetName>
<ToolsetNumber>0x4</ToolsetNumber>
<ToolsetName>ARM-ADS</ToolsetName>
<TargetOption>
<CLKADS>8000000</CLKADS>
<OPTTT> <OPTTT>
<gFlags>1</gFlags> <gFlags>1</gFlags>
<BeepAtEnd>1</BeepAtEnd> <BeepAtEnd>1</BeepAtEnd>
@ -103,7 +285,7 @@
<bEvRecOn>1</bEvRecOn> <bEvRecOn>1</bEvRecOn>
<bSchkAxf>0</bSchkAxf> <bSchkAxf>0</bSchkAxf>
<bTchkAxf>0</bTchkAxf> <bTchkAxf>0</bTchkAxf>
<nTsel>0</nTsel> <nTsel>6</nTsel>
<sDll></sDll> <sDll></sDll>
<sDllPa></sDllPa> <sDllPa></sDllPa>
<sDlgDll></sDlgDll> <sDlgDll></sDlgDll>
@ -114,13 +296,38 @@
<tDlgDll></tDlgDll> <tDlgDll></tDlgDll>
<tDlgPa></tDlgPa> <tDlgPa></tDlgPa>
<tIfile></tIfile> <tIfile></tIfile>
<pMon>BIN\UL2CM3.DLL</pMon> <pMon>STLink\ST-LINKIII-KEIL_SWO.dll</pMon>
</DebugOpt> </DebugOpt>
<TargetDriverDllRegistry> <TargetDriverDllRegistry>
<SetRegEntry>
<Number>0</Number>
<Key>ARMRTXEVENTFLAGS</Key>
<Name>-L70 -Z18 -C0 -M0 -T1</Name>
</SetRegEntry>
<SetRegEntry>
<Number>0</Number>
<Key>DLGTARM</Key>
<Name>(1010=-1,-1,-1,-1,0)(1007=-1,-1,-1,-1,0)(1008=-1,-1,-1,-1,0)(1009=-1,-1,-1,-1,0)(100=-1,-1,-1,-1,0)(110=-1,-1,-1,-1,0)(111=-1,-1,-1,-1,0)(1011=-1,-1,-1,-1,0)(180=-1,-1,-1,-1,0)(120=-1,-1,-1,-1,0)(121=-1,-1,-1,-1,0)(122=-1,-1,-1,-1,0)(123=-1,-1,-1,-1,0)(140=-1,-1,-1,-1,0)(240=-1,-1,-1,-1,0)(190=-1,-1,-1,-1,0)(200=-1,-1,-1,-1,0)(170=-1,-1,-1,-1,0)(130=-1,-1,-1,-1,0)(131=-1,-1,-1,-1,0)(132=-1,-1,-1,-1,0)(133=-1,-1,-1,-1,0)(160=-1,-1,-1,-1,0)(161=-1,-1,-1,-1,0)(162=-1,-1,-1,-1,0)(210=-1,-1,-1,-1,0)(211=-1,-1,-1,-1,0)(220=-1,-1,-1,-1,0)(221=-1,-1,-1,-1,0)(230=-1,-1,-1,-1,0)(231=-1,-1,-1,-1,0)(232=-1,-1,-1,-1,0)(233=-1,-1,-1,-1,0)(150=-1,-1,-1,-1,0)(151=-1,-1,-1,-1,0)</Name>
</SetRegEntry>
<SetRegEntry>
<Number>0</Number>
<Key>ARMDBGFLAGS</Key>
<Name></Name>
</SetRegEntry>
<SetRegEntry>
<Number>0</Number>
<Key>DLGUARM</Key>
<Name>(105=-1,-1,-1,-1,0)</Name>
</SetRegEntry>
<SetRegEntry>
<Number>0</Number>
<Key>ST-LINKIII-KEIL_SWO</Key>
<Name>-U066FFF575256867067031930 -O206 -SF10000 -C0 -A0 -I0 -HNlocalhost -HP7184 -P1 -N00("ARM CoreSight SW-DP (ARM Core") -D00(1BA01477) -L00(0) -TO65554 -TC10000000 -TT10000000 -TP21 -TDS8007 -TDT0 -TDC1F -TIEFFFFFFFF -TIP8 -FO7 -FD20000000 -FC1000 -FN1 -FF0STM32F10x_128.FLM -FS08000000 -FL020000 -FP0($$Device:STM32F103RB$Flash\STM32F10x_128.FLM)</Name>
</SetRegEntry>
<SetRegEntry> <SetRegEntry>
<Number>0</Number> <Number>0</Number>
<Key>UL2CM3</Key> <Key>UL2CM3</Key>
<Name>UL2CM3(-S0 -C0 -P0 -FD20000000 -FC1000 -FN1 -FF0STM32F10x_128 -FS08000000 -FL020000 -FP0($$Device:STM32F103RB$Flash\STM32F10x_128.FLM))</Name> <Name>-U -O206 -S8 -C0 -P00 -N00("") -D00(00000000) -L00(0) -TO65554 -TC10000000 -TT10000000 -TP21 -TDS8007 -TDT0 -TDC1F -TIEFFFFFFFF -TIP8 -FO7 -FD20000000 -FC1000 -FN1 -FF0STM32F10x_128.FLM -FS08000000 -FL020000 -FP0($$Device:STM32F103RB$Flash\STM32F10x_128.FLM)</Name>
</SetRegEntry> </SetRegEntry>
</TargetDriverDllRegistry> </TargetDriverDllRegistry>
<Breakpoint/> <Breakpoint/>
@ -129,13 +336,13 @@
</Tracepoint> </Tracepoint>
<DebugFlag> <DebugFlag>
<trace>0</trace> <trace>0</trace>
<periodic>0</periodic> <periodic>1</periodic>
<aLwin>0</aLwin> <aLwin>0</aLwin>
<aCover>0</aCover> <aCover>0</aCover>
<aSer1>0</aSer1> <aSer1>1</aSer1>
<aSer2>0</aSer2> <aSer2>0</aSer2>
<aPa>0</aPa> <aPa>0</aPa>
<viewmode>0</viewmode> <viewmode>1</viewmode>
<vrSel>0</vrSel> <vrSel>0</vrSel>
<aSym>0</aSym> <aSym>0</aSym>
<aTbox>0</aTbox> <aTbox>0</aTbox>
@ -168,7 +375,7 @@
<pMultCmdsp></pMultCmdsp> <pMultCmdsp></pMultCmdsp>
<DebugDescription> <DebugDescription>
<Enable>1</Enable> <Enable>1</Enable>
<EnableFlashSeq>1</EnableFlashSeq> <EnableFlashSeq>0</EnableFlashSeq>
<EnableLog>0</EnableLog> <EnableLog>0</EnableLog>
<Protocol>2</Protocol> <Protocol>2</Protocol>
<DbgClock>10000000</DbgClock> <DbgClock>10000000</DbgClock>
@ -176,147 +383,6 @@
</TargetOption> </TargetOption>
</Target> </Target>
<Target>
<TargetName>cible</TargetName>
<ToolsetNumber>0x4</ToolsetNumber>
<ToolsetName>ARM-ADS</ToolsetName>
<TargetOption>
<CLKADS>12000000</CLKADS>
<OPTTT>
<gFlags>0</gFlags>
<BeepAtEnd>1</BeepAtEnd>
<RunSim>1</RunSim>
<RunTarget>0</RunTarget>
<RunAbUc>0</RunAbUc>
</OPTTT>
<OPTHX>
<HexSelection>1</HexSelection>
<FlashByte>65535</FlashByte>
<HexRangeLowAddress>0</HexRangeLowAddress>
<HexRangeHighAddress>0</HexRangeHighAddress>
<HexOffset>0</HexOffset>
</OPTHX>
<OPTLEX>
<PageWidth>79</PageWidth>
<PageLength>66</PageLength>
<TabStop>8</TabStop>
<ListingPath>.\Listings\</ListingPath>
</OPTLEX>
<ListingPage>
<CreateCListing>1</CreateCListing>
<CreateAListing>1</CreateAListing>
<CreateLListing>1</CreateLListing>
<CreateIListing>0</CreateIListing>
<AsmCond>1</AsmCond>
<AsmSymb>1</AsmSymb>
<AsmXref>0</AsmXref>
<CCond>1</CCond>
<CCode>0</CCode>
<CListInc>0</CListInc>
<CSymb>0</CSymb>
<LinkerCodeListing>0</LinkerCodeListing>
</ListingPage>
<OPTXL>
<LMap>1</LMap>
<LComments>1</LComments>
<LGenerateSymbols>1</LGenerateSymbols>
<LLibSym>1</LLibSym>
<LLines>1</LLines>
<LLocSym>1</LLocSym>
<LPubSym>1</LPubSym>
<LXref>0</LXref>
<LExpSel>0</LExpSel>
</OPTXL>
<OPTFL>
<tvExp>0</tvExp>
<tvExpOptDlg>0</tvExpOptDlg>
<IsCurrentTarget>0</IsCurrentTarget>
</OPTFL>
<CpuCode>18</CpuCode>
<DebugOpt>
<uSim>1</uSim>
<uTrg>0</uTrg>
<sLdApp>1</sLdApp>
<sGomain>1</sGomain>
<sRbreak>1</sRbreak>
<sRwatch>1</sRwatch>
<sRmem>1</sRmem>
<sRfunc>1</sRfunc>
<sRbox>1</sRbox>
<tLdApp>1</tLdApp>
<tGomain>0</tGomain>
<tRbreak>1</tRbreak>
<tRwatch>1</tRwatch>
<tRmem>1</tRmem>
<tRfunc>0</tRfunc>
<tRbox>1</tRbox>
<tRtrace>1</tRtrace>
<sRSysVw>1</sRSysVw>
<tRSysVw>1</tRSysVw>
<sRunDeb>0</sRunDeb>
<sLrtime>0</sLrtime>
<bEvRecOn>1</bEvRecOn>
<bSchkAxf>0</bSchkAxf>
<bTchkAxf>0</bTchkAxf>
<nTsel>-1</nTsel>
<sDll></sDll>
<sDllPa></sDllPa>
<sDlgDll></sDlgDll>
<sDlgPa></sDlgPa>
<sIfile></sIfile>
<tDll></tDll>
<tDllPa></tDllPa>
<tDlgDll></tDlgDll>
<tDlgPa></tDlgPa>
<tIfile></tIfile>
<pMon></pMon>
</DebugOpt>
<Breakpoint/>
<Tracepoint>
<THDelay>0</THDelay>
</Tracepoint>
<DebugFlag>
<trace>0</trace>
<periodic>0</periodic>
<aLwin>0</aLwin>
<aCover>0</aCover>
<aSer1>0</aSer1>
<aSer2>0</aSer2>
<aPa>0</aPa>
<viewmode>0</viewmode>
<vrSel>0</vrSel>
<aSym>0</aSym>
<aTbox>0</aTbox>
<AscS1>0</AscS1>
<AscS2>0</AscS2>
<AscS3>0</AscS3>
<aSer3>0</aSer3>
<eProf>0</eProf>
<aLa>0</aLa>
<aPa1>0</aPa1>
<AscS4>0</AscS4>
<aSer4>0</aSer4>
<StkLoc>0</StkLoc>
<TrcWin>0</TrcWin>
<newCpu>0</newCpu>
<uProt>0</uProt>
</DebugFlag>
<LintExecutable></LintExecutable>
<LintConfigFile></LintConfigFile>
<bLintAuto>0</bLintAuto>
<bAutoGenD>0</bAutoGenD>
<LntExFlags>0</LntExFlags>
<pMisraName></pMisraName>
<pszMrule></pszMrule>
<pSingCmds></pSingCmds>
<pMultCmds></pMultCmds>
<pMisraNamep></pMisraNamep>
<pszMrulep></pszMrulep>
<pSingCmdsp></pSingCmdsp>
<pMultCmdsp></pMultCmdsp>
</TargetOption>
</Target>
<Group> <Group>
<GroupName>Driver</GroupName> <GroupName>Driver</GroupName>
<tvExp>1</tvExp> <tvExp>1</tvExp>
@ -375,7 +441,7 @@
<Group> <Group>
<GroupName>SRC</GroupName> <GroupName>SRC</GroupName>
<tvExp>1</tvExp> <tvExp>0</tvExp>
<tvExpOptDlg>0</tvExpOptDlg> <tvExpOptDlg>0</tvExpOptDlg>
<cbSel>0</cbSel> <cbSel>0</cbSel>
<RteFlg>0</RteFlg> <RteFlg>0</RteFlg>
@ -406,11 +472,35 @@
<tvExp>0</tvExp> <tvExp>0</tvExp>
<tvExpOptDlg>0</tvExpOptDlg> <tvExpOptDlg>0</tvExpOptDlg>
<bDave2>0</bDave2> <bDave2>0</bDave2>
<PathWithFileName>..\Drivers\Voilier_fonction\telecommande.c</PathWithFileName>
<FilenameWithoutPath>telecommande.c</FilenameWithoutPath>
<RteFlg>0</RteFlg>
<bShared>0</bShared>
</File>
<File>
<GroupNumber>3</GroupNumber>
<FileNumber>7</FileNumber>
<FileType>1</FileType>
<tvExp>0</tvExp>
<tvExpOptDlg>0</tvExpOptDlg>
<bDave2>0</bDave2>
<PathWithFileName>..\Drivers\Voilier_fonction\Girouette.c</PathWithFileName> <PathWithFileName>..\Drivers\Voilier_fonction\Girouette.c</PathWithFileName>
<FilenameWithoutPath>Girouette.c</FilenameWithoutPath> <FilenameWithoutPath>Girouette.c</FilenameWithoutPath>
<RteFlg>0</RteFlg> <RteFlg>0</RteFlg>
<bShared>0</bShared> <bShared>0</bShared>
</File> </File>
<File>
<GroupNumber>3</GroupNumber>
<FileNumber>8</FileNumber>
<FileType>1</FileType>
<tvExp>0</tvExp>
<tvExpOptDlg>0</tvExpOptDlg>
<bDave2>0</bDave2>
<PathWithFileName>..\Drivers\Voilier_fonction\Plateau.c</PathWithFileName>
<FilenameWithoutPath>Plateau.c</FilenameWithoutPath>
<RteFlg>0</RteFlg>
<bShared>0</bShared>
</File>
</Group> </Group>
<Group> <Group>

Ver fichero

@ -418,11 +418,21 @@
<Group> <Group>
<GroupName>Voilier_fonction</GroupName> <GroupName>Voilier_fonction</GroupName>
<Files> <Files>
<File>
<FileName>telecommande.c</FileName>
<FileType>1</FileType>
<FilePath>..\Drivers\Voilier_fonction\telecommande.c</FilePath>
</File>
<File> <File>
<FileName>Girouette.c</FileName> <FileName>Girouette.c</FileName>
<FileType>1</FileType> <FileType>1</FileType>
<FilePath>..\Drivers\Voilier_fonction\Girouette.c</FilePath> <FilePath>..\Drivers\Voilier_fonction\Girouette.c</FilePath>
</File> </File>
<File>
<FileName>Plateau.c</FileName>
<FileType>1</FileType>
<FilePath>..\Drivers\Voilier_fonction\Plateau.c</FilePath>
</File>
</Files> </Files>
</Group> </Group>
<Group> <Group>
@ -766,7 +776,7 @@
<MiscControls></MiscControls> <MiscControls></MiscControls>
<Define></Define> <Define></Define>
<Undefine></Undefine> <Undefine></Undefine>
<IncludePath>..\Drivers\Include</IncludePath> <IncludePath>..\Drivers\Include;..\Drivers\Voilier_fonction</IncludePath>
</VariousControls> </VariousControls>
</Cads> </Cads>
<Aads> <Aads>
@ -845,11 +855,21 @@
<Group> <Group>
<GroupName>Voilier_fonction</GroupName> <GroupName>Voilier_fonction</GroupName>
<Files> <Files>
<File>
<FileName>telecommande.c</FileName>
<FileType>1</FileType>
<FilePath>..\Drivers\Voilier_fonction\telecommande.c</FilePath>
</File>
<File> <File>
<FileName>Girouette.c</FileName> <FileName>Girouette.c</FileName>
<FileType>1</FileType> <FileType>1</FileType>
<FilePath>..\Drivers\Voilier_fonction\Girouette.c</FilePath> <FilePath>..\Drivers\Voilier_fonction\Girouette.c</FilePath>
</File> </File>
<File>
<FileName>Plateau.c</FileName>
<FileType>1</FileType>
<FilePath>..\Drivers\Voilier_fonction\Plateau.c</FilePath>
</File>
</Files> </Files>
</Group> </Group>
<Group> <Group>

Ver fichero

@ -2,13 +2,32 @@
#include "Driver_Timer.h" #include "Driver_Timer.h"
#include "Driver_UART.h" #include "Driver_UART.h"
#include "Driver_ADC.h" #include "Driver_ADC.h"
#include "Plateau.h"
#include "telecommande.h"
int main (void){ int main (void){
MyGPIO_Struct_TypeDef * GPIO;
//init_telecommande();
//Plateau_init();
//Plateau_direction(DROITE);
//testRemote();
MyGPIO_Init(GPIO);
while(1){ while(1){
MyGPIO_Set(GPIOA,3);
} }
} }

19
README.md Archivo normal
Ver fichero

@ -0,0 +1,19 @@
# Projet Voilier
## Equipe 4
* Clement MARCE
* Louis ROUSSET
* Cedric CHANFREAU
## Réalisation des drivers :
* [GPIOS](https://git.etud.insa-toulouse.fr/marce/Voilier/src/branch/master/Drivers/Sources/Driver_GPIO.c) //Done
* [TIMERS](https://git.etud.insa-toulouse.fr/marce/Voilier/src/branch/master/Drivers/Sources/Driver_Timer.c) //Done
* [PWM](https://git.etud.insa-toulouse.fr/marce/Voilier/src/branch/master/Drivers/Sources/Driver_Timer.c) //Done (Cédric)
* [ADC](https://git.etud.insa-toulouse.fr/marce/Voilier/src/branch/master/Drivers/Sources/Driver_ADC.c) //Done (Clement+Louis)
* [UART](https://git.etud.insa-toulouse.fr/marce/Voilier/src/branch/master/Drivers/Sources/Driver_UART.c) //Done (Cédric)
## Réalisation des différentes fonctions du bateau :
* [Girouette](https://git.etud.insa-toulouse.fr/marce/Voilier/src/branch/master/Drivers/Voilier_fonction/Girouette.c) //Work in progress (Clement)
* [Plateau](https://git.etud.insa-toulouse.fr/marce/Voilier/src/branch/master/Drivers/Voilier_fonction/Plateau.c) //Need to test (Cédric)
! : Rousset Louis a été absent à 3séances de TP sur les 6 prévues, ce qui a causé du retard à l'équipe.

BIN
README_picture/APB2ENR.png Archivo normal

Archivo binario no mostrado.

Después

Anchura:  |  Altura:  |  Tamaño: 13 KiB

BIN
README_picture/Thumbs.db Archivo normal

Archivo binario no mostrado.