mirror of
				https://github.com/RobotechLille/cdf2018-principal
				synced 2025-10-25 02:03:31 +02:00 
			
		
		
		
	Misc
This commit is contained in:
		
							parent
							
								
									1ef117c0ad
								
							
						
					
					
						commit
						48b2901da4
					
				
					 10 changed files with 99 additions and 14 deletions
				
			
		|  | @ -5,7 +5,7 @@ CC=gcc | ||||||
| # Bibliothèques
 | # Bibliothèques
 | ||||||
| LIBS= | LIBS= | ||||||
| ## Drapeaux pour le linker
 | ## Drapeaux pour le linker
 | ||||||
| LDFLAGS_CUSTOM += -lpthread -lwiringPi | LDFLAGS_CUSTOM += -lpthread -lwiringPi -lm | ||||||
| ## Drapeaux pour le compilateur
 | ## Drapeaux pour le compilateur
 | ||||||
| CFLAGS_CUSTOM += -g | CFLAGS_CUSTOM += -g | ||||||
| ## Générateurs de drapeaux pour les bibliothèques
 | ## Générateurs de drapeaux pour les bibliothèques
 | ||||||
|  |  | ||||||
|  | @ -10,7 +10,7 @@ | ||||||
| 
 | 
 | ||||||
| #define FPGA_PORTNAME "/dev/ttyUSB0" | #define FPGA_PORTNAME "/dev/ttyUSB0" | ||||||
| #define CF_BAUDRATE B115200 | #define CF_BAUDRATE B115200 | ||||||
| // #define PRINTRAWDATA
 | #define PRINTRAWDATA | ||||||
| 
 | 
 | ||||||
| int fpga; | int fpga; | ||||||
| pthread_mutex_t sSendCF; | pthread_mutex_t sSendCF; | ||||||
|  |  | ||||||
|  | @ -26,7 +26,7 @@ int nextId() | ||||||
| 
 | 
 | ||||||
|     if (d) { |     if (d) { | ||||||
|         while ((dir = readdir(d)) != NULL) { |         while ((dir = readdir(d)) != NULL) { | ||||||
|             ret = sscanf(dir->d_name, "%d", &id); |             ret = sscanf(dir->d_name, "%06d", &id); | ||||||
|             if (ret == 1 && id > maxId) { |             if (ret == 1 && id > maxId) { | ||||||
|                 maxId = id; |                 maxId = id; | ||||||
|             } |             } | ||||||
|  | @ -101,7 +101,7 @@ void configureDebug() | ||||||
| 
 | 
 | ||||||
|     // Génération du nom de fichier
 |     // Génération du nom de fichier
 | ||||||
|     char path[256]; |     char path[256]; | ||||||
|     sprintf(path, "log/%d.csv", nextId()); |     sprintf(path, "log/%06d.csv", nextId()); | ||||||
| 
 | 
 | ||||||
|     // Open file
 |     // Open file
 | ||||||
|     debugFd = fopen(path, "w"); |     debugFd = fopen(path, "w"); | ||||||
|  |  | ||||||
|  | @ -34,12 +34,11 @@ int setMoteurTension(float lVolt, float rVolt) | ||||||
| 
 | 
 | ||||||
|     msg.in = 0x00; |     msg.in = 0x00; | ||||||
| 
 | 
 | ||||||
|  |     // TODO Protections
 | ||||||
|  | 
 | ||||||
|     // Gauche
 |     // Gauche
 | ||||||
|     bool lFor = lVolt < 0; |     bool lFor = lVolt < 0; | ||||||
|     lVolt = fabs(lVolt); |     lVolt = fabs(lVolt); | ||||||
|     if (lVolt > MOT_MAX_V) { |  | ||||||
|         lVolt = MOT_MAX_V; |  | ||||||
|     } |  | ||||||
|     msg.in |= 1 << (lFor ? IN1 : IN2); |     msg.in |= 1 << (lFor ? IN1 : IN2); | ||||||
|     msg.ena = tensionToPWM(lVolt); |     msg.ena = tensionToPWM(lVolt); | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -3,12 +3,14 @@ | ||||||
|  */ |  */ | ||||||
| 
 | 
 | ||||||
| #include <stdio.h> | #include <stdio.h> | ||||||
|  | #include <math.h> | ||||||
| 
 | 
 | ||||||
| #include "debug.h" | #include "debug.h" | ||||||
| #include "position.h" | #include "position.h" | ||||||
|  | #include "dimensions.h" | ||||||
| 
 | 
 | ||||||
| // Globales
 | // Globales
 | ||||||
| struct position actuel; | struct position connu; | ||||||
| struct F2CI_CODERs deltaCoders; | struct F2CI_CODERs deltaCoders; | ||||||
| pthread_mutex_t posPolling; | pthread_mutex_t posPolling; | ||||||
| pthread_t tPosition; | pthread_t tPosition; | ||||||
|  | @ -42,6 +44,15 @@ void* TaskPosition(void* pData) | ||||||
|         nbCalcPos++; |         nbCalcPos++; | ||||||
|         lCodTot += deltaCoders.dL; |         lCodTot += deltaCoders.dL; | ||||||
|         rCodTot += deltaCoders.dR; |         rCodTot += deltaCoders.dR; | ||||||
|  | 
 | ||||||
|  |         float deltaO = atan2(deltaCoders.dR - deltaCoders.dL, DISTANCE_BETWEEN_WHEELS); | ||||||
|  |         float deltaD = (deltaCoders.dL + deltaCoders.dR) / 2; | ||||||
|  | 
 | ||||||
|  |         connu.o += deltaO; | ||||||
|  |         float deltaX = deltaD * cos(connu.o); | ||||||
|  |         float deltaY = deltaD * sin(connu.o); | ||||||
|  |         connu.x += deltaX; | ||||||
|  |         connu.y += deltaY; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     return NULL; |     return NULL; | ||||||
|  | @ -58,6 +69,12 @@ void configurePosition() | ||||||
|     registerRxHandler(F2CI_CODER, onF2CI_CODER); |     registerRxHandler(F2CI_CODER, onF2CI_CODER); | ||||||
|     registerDebugVar("lCodTot", ld, &lCodTot); |     registerDebugVar("lCodTot", ld, &lCodTot); | ||||||
|     registerDebugVar("rCodTot", ld, &rCodTot); |     registerDebugVar("rCodTot", ld, &rCodTot); | ||||||
|  |     connu.x = 0; | ||||||
|  |     connu.y = 0; | ||||||
|  |     connu.o = 0; | ||||||
|  |     registerDebugVar("xConnu", f, &connu.x); | ||||||
|  |     registerDebugVar("yConnu", f, &connu.y); | ||||||
|  |     registerDebugVar("oConnu", f, &connu.o); | ||||||
|     registerDebugVar("nbCalcPos", d, &nbCalcPos); |     registerDebugVar("nbCalcPos", d, &nbCalcPos); | ||||||
|     pthread_create(&tPosition, NULL, TaskPosition, NULL); |     pthread_create(&tPosition, NULL, TaskPosition, NULL); | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -12,6 +12,8 @@ | ||||||
| #include "movement.h" | #include "movement.h" | ||||||
| #include "buttons.h" | #include "buttons.h" | ||||||
| 
 | 
 | ||||||
|  | #define PATATE 3.3/2 | ||||||
|  | 
 | ||||||
| int main(int argc, char* argv[]) | int main(int argc, char* argv[]) | ||||||
| { | { | ||||||
| 
 | 
 | ||||||
|  | @ -29,22 +31,22 @@ int main(int argc, char* argv[]) | ||||||
|     for (;;) { |     for (;;) { | ||||||
|         clearLCD(); |         clearLCD(); | ||||||
|         printToLCD(LCD_LINE_1, "Forward"); |         printToLCD(LCD_LINE_1, "Forward"); | ||||||
|         changerMoteurs(3.3, 3.3); |         changerMoteurs(PATATE, PATATE); | ||||||
|         pressedButton(BUT_BLOCK); |         pressedButton(BUT_BLOCK); | ||||||
| 
 | 
 | ||||||
|         clearLCD(); |         clearLCD(); | ||||||
|         printToLCD(LCD_LINE_1, "Right"); |         printToLCD(LCD_LINE_1, "Right"); | ||||||
|         changerMoteurs(-3.3, 3.3); |         changerMoteurs(-PATATE, PATATE); | ||||||
|         pressedButton(BUT_BLOCK); |         pressedButton(BUT_BLOCK); | ||||||
| 
 | 
 | ||||||
|         clearLCD(); |         clearLCD(); | ||||||
|         printToLCD(LCD_LINE_1, "Left"); |         printToLCD(LCD_LINE_1, "Left"); | ||||||
|         changerMoteurs(-3.3, -3.3); |         changerMoteurs(-PATATE, -PATATE); | ||||||
|         pressedButton(BUT_BLOCK); |         pressedButton(BUT_BLOCK); | ||||||
| 
 | 
 | ||||||
|         clearLCD(); |         clearLCD(); | ||||||
|         printToLCD(LCD_LINE_1, "Backward"); |         printToLCD(LCD_LINE_1, "Backward"); | ||||||
|         changerMoteurs(3.3, -3.3); |         changerMoteurs(PATATE, -PATATE); | ||||||
|         pressedButton(BUT_BLOCK); |         pressedButton(BUT_BLOCK); | ||||||
| 
 | 
 | ||||||
|         clearLCD(); |         clearLCD(); | ||||||
|  |  | ||||||
							
								
								
									
										62
									
								
								chef/src/testUpDown.c
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										62
									
								
								chef/src/testUpDown.c
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,62 @@ | ||||||
|  | /* Teste si une broche est connecté à une autre */ | ||||||
|  | 
 | ||||||
|  | #include <stdint.h> | ||||||
|  | #include <stdio.h> | ||||||
|  | #include <stdlib.h> | ||||||
|  | #include <unistd.h> | ||||||
|  | #include <wiringPi.h> | ||||||
|  | #include <wiringPiI2C.h> | ||||||
|  | 
 | ||||||
|  | #include "lcd.h" | ||||||
|  | #include "CF.h" | ||||||
|  | #include "movement.h" | ||||||
|  | #include "buttons.h" | ||||||
|  | 
 | ||||||
|  | #define UP_TIME 1000 | ||||||
|  | #define HIGH_TIME 3000 | ||||||
|  | #define DOWN_TIME 1000 | ||||||
|  | #define LOW_TIME 2000 | ||||||
|  | #define MAXI 3.3 | ||||||
|  | #define INTERVAL 10 | ||||||
|  | 
 | ||||||
|  | void changerMoteursWrapper(float l, float r) { | ||||||
|  |     /* clearLCD(); */ | ||||||
|  |     printfToLCD(LCD_LINE_1, "L: %f", l); | ||||||
|  |     printfToLCD(LCD_LINE_2, "R: %f", r); | ||||||
|  |     changerMoteurs(l, r); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | int main(int argc, char* argv[]) | ||||||
|  | { | ||||||
|  | 
 | ||||||
|  |     (void)argc; | ||||||
|  |     (void)argv; | ||||||
|  | 
 | ||||||
|  |     wiringPiSetup(); | ||||||
|  | 
 | ||||||
|  |     initI2C(); | ||||||
|  |     initLCD(); | ||||||
|  |     configureCF(); | ||||||
|  |     configureButtons(); | ||||||
|  |     configureMovement(); | ||||||
|  | 
 | ||||||
|  |     for (;;) { | ||||||
|  |         for (int i = 0; i < UP_TIME; i += INTERVAL) { | ||||||
|  |             float p = (float)i / (float)UP_TIME; | ||||||
|  |             changerMoteursWrapper(p * MOT_MAX_V, p * MOT_MAX_V); | ||||||
|  |             delay(INTERVAL); | ||||||
|  |         } | ||||||
|  |         changerMoteursWrapper(MOT_MAX_V, MOT_MAX_V); | ||||||
|  |         delay(HIGH_TIME); | ||||||
|  | 
 | ||||||
|  |         for (int i = 0; i < DOWN_TIME; i += INTERVAL) { | ||||||
|  |             float p = (float)i / (float)DOWN_TIME; | ||||||
|  |             p = 1 - p; | ||||||
|  |             changerMoteursWrapper(p * MOT_MAX_V, p * MOT_MAX_V); | ||||||
|  |             delay(INTERVAL); | ||||||
|  |         } | ||||||
|  |         changerMoteursWrapper(0, 0); | ||||||
|  |         delay(LOW_TIME); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  | } | ||||||
							
								
								
									
										2
									
								
								log/.gitignore
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										2
									
								
								log/.gitignore
									
										
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,2 @@ | ||||||
|  | * | ||||||
|  | !.gitignore | ||||||
|  | @ -125,6 +125,10 @@ restart: | ||||||
| 	ssh -F sshconf principal true | 	ssh -F sshconf principal true | ||||||
| 	ssh -F sshconf principal /etc/init.d/S50chef restart | 	ssh -F sshconf principal /etc/init.d/S50chef restart | ||||||
| 
 | 
 | ||||||
|  | getlogs: | ||||||
|  | 	ssh -F sshconf principal true | ||||||
|  | 	rsync --rsh 'ssh -F sshconf' --archive principal:/opt/chef/log/* ../log/ | ||||||
|  | 
 | ||||||
| gdbcommands: | gdbcommands: | ||||||
| 	echo "set sysroot $(TARGET_DIR)" > "$@" | 	echo "set sysroot $(TARGET_DIR)" > "$@" | ||||||
| 	echo "exec-file $(TARGET_DIR)$(EXECDIR)$(EXECPATH)" >> "$@" | 	echo "exec-file $(TARGET_DIR)$(EXECDIR)$(EXECPATH)" >> "$@" | ||||||
|  |  | ||||||
|  | @ -7,6 +7,7 @@ start() { | ||||||
| 	printf "Starting Wi-Fi connection: " | 	printf "Starting Wi-Fi connection: " | ||||||
| 	# modprobe brcmfmac | 	# modprobe brcmfmac | ||||||
| 	modprobe r8188eu | 	modprobe r8188eu | ||||||
|  | 	modprobe 8192cu | ||||||
| 	ifup wlan0 | 	ifup wlan0 | ||||||
| 	echo "OK" | 	echo "OK" | ||||||
| } | } | ||||||
|  | @ -14,8 +15,6 @@ start() { | ||||||
| stop() { | stop() { | ||||||
| 	printf "Stopping Wi-Fi connection: " | 	printf "Stopping Wi-Fi connection: " | ||||||
| 	ifdown wlan0 | 	ifdown wlan0 | ||||||
| 	# rmmod brcmfmac |  | ||||||
| 	rmmod r8188eu |  | ||||||
| 	echo "OK" | 	echo "OK" | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue