abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
AbcLinuxu hledá autory!
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    včera 22:55 | Nová verze

    Byla vydána únorová aktualizace aneb nová verze 1.110 editoru zdrojových kódů Visual Studio Code (Wikipedie). Přehled novinek i s náhledy a videi v poznámkách k vydání. Ve verzi 1.110 vyjde také VSCodium, tj. komunitní sestavení Visual Studia Code bez telemetrie a licenčních podmínek Microsoftu.

    Ladislav Hagara | Komentářů: 4
    včera 18:11 | IT novinky

    Apple představil 13palcový MacBook Neo s čipem A18 Pro. V základní konfiguraci za 16 990 Kč.

    Ladislav Hagara | Komentářů: 29
    včera 12:22 | Komunita

    Kalifornský zákon AB 1043 platný od 1. ledna 2027 vyžaduje, aby operační systémy požadovaly po uživatelích věk nebo datum narození a skrze API poskytovaly aplikacím informaci, zda je uživatel mladší 13 let, má 13 až 16 let, má 16 až 18 let nebo má alespoň 18 let. Vývojáři linuxových distribucí řeší, co s tím (Ubuntu, Fedora, …).

    Ladislav Hagara | Komentářů: 70
    včera 11:44 | Pozvánky

    Konference LinuxDays 2026 proběhne o víkendu 3. a 4. října v Praze v areálu ČVUT v Dejvicích na FIT. Čekají vás desítky přednášek, workshopy, stánky a setkání se spoustou chytrých lidí.

    Petr Krčmář | Komentářů: 0
    včera 00:44 | Humor

    Nové verze webových prohlížečů Chrome a Firefox jsou vydávány každé 4 týdny. Aktuální verze Chrome je 145. Aktuální verze Firefoxu je 148. Od září přejde Chrome na dvoutýdenní cyklus vydávání. V kterém týdnu bude mít Chrome větší číslo verze než Firefox? 😀

    Ladislav Hagara | Komentářů: 1
    3.3. 21:55 | IT novinky Ladislav Hagara | Komentářů: 4
    3.3. 13:44 | Komunita

    Bylo spuštěno hlasování o přednáškách a workshopech pro letošní Installfest, jenž proběhne o víkendu 28. a 29. března v Praze na Karlově náměstí 13.

    Ladislav Hagara | Komentářů: 4
    3.3. 04:33 | Nová verze

    Byla vydána (Mastodon, 𝕏) třetí RC verze GIMPu 3.2. Přehled novinek v oznámení o vydání. Podrobně v souboru NEWS na GitLabu.

    Ladislav Hagara | Komentářů: 0
    2.3. 21:44 | IT novinky

    Apple představil iPhone 17e a iPad Air s čipem M4.

    Ladislav Hagara | Komentářů: 18
    2.3. 21:11 | Zajímavý software

    Byla vydána verze 1.0 editoru kódů Gram. Jedná se o fork editoru Zed bez telemetrie a umělé inteligence.

    Ladislav Hagara | Komentářů: 0
    Které desktopové prostředí na Linuxu používáte?
     (17%)
     (7%)
     (0%)
     (11%)
     (28%)
     (2%)
     (5%)
     (1%)
     (13%)
     (25%)
    Celkem 1015 hlasů
     Komentářů: 25, poslední 3.2. 19:50
    Rozcestník

    Dotaz: C - chybné čtení id 1. sensoru

    28.5.2010 17:14 mcuProg
    C - chybné čtení id 1. sensoru
    Přečteno: 367×
    Mám naprogramovaný termostat. Blbne mi ale část kódu, která má za úkol ukládat do eeprom IDčka teplotních sensorů.
    uint8_t search_sensors(void) {
    	uint8_t i;
    	uint8_t id[OW_ROMCODE_SIZE];
    	uint8_t diff;
    	bool akva1, akva2, lednice, mistnost;
    	
    
    	while(1) {
    		//writestr("+4 NACITAM SENZORY");
    		//lfcr();
    
    		m_delay_ms(250);
    
    		nSensors = 0;
    		akva1_id = -1;
    		akva2_id = -1;
    		lednice_id = -1;
    		mistnost_id = -1;
    		for(uint8_t iN = 0; iN<MAXSENSORS; iN++) { // nemá vliv na chování
    			for(uint8_t iN2 = 0; iN2<OW_ROMCODE_SIZE; iN2++) {
    				gSensorIDs[iN][iN2] = 0;
    			}
    		}
    
    
    		for(diff = OW_SEARCH_FIRST; diff != OW_LAST_DEVICE && nSensors < MAXSENSORS; ) {
    			DS18X20_find_sensor( &diff, &id[0] );
    		
    			if( diff == OW_PRESENCE_ERR ) break;
    			if( diff == OW_DATA_ERR ) break;
    
    			akva1 = true;
    			akva2 = true;
    			lednice = true;
    			mistnost = true;
    
    			for (i=0;i<OW_ROMCODE_SIZE;i++) {
    				gSensorIDs[nSensors][i]=id[i];
    
    				if(akva1) {
    					eeprom_busy_wait();
    					if( gSensorIDs[nSensors][i] != eeprom_read_byte((uint8_t*)(EEPROM_AKVA1_SENSOR+i)) ) akva1 = false;
    				}
    
    				if(akva2) {
    					eeprom_busy_wait();
    					if( gSensorIDs[nSensors][i] != eeprom_read_byte((uint8_t*)(EEPROM_AKVA2_SENSOR+i)) ) akva2 = false;
    				}
    
    				if(lednice) {
    					eeprom_busy_wait();
    					if( gSensorIDs[nSensors][i] != eeprom_read_byte((uint8_t*)(EEPROM_LEDNICE_SENSOR+i)) ) lednice = false;
    				}
    
    				if(mistnost) {
    					eeprom_busy_wait();
    					if( gSensorIDs[nSensors][i] != eeprom_read_byte((uint8_t*)(EEPROM_MISTNOST_SENSOR+i)) ) mistnost = false;
    				}
    			}
    
    			if(akva1 && !akva2 && !lednice && !mistnost) {
    				akva1_id = nSensors;
    				leds_add(port_led_akva1);
    			}
    			if(!akva1 && akva2 && !lednice && !mistnost) {
    				akva2_id = nSensors;
    				leds_add(port_led_akva2);
    			}
    			if(!akva1 && !akva2 && lednice && !mistnost) {
    				lednice_id = nSensors;
    				leds_add(port_led_lednice);
    			}
    			if(!akva1 && !akva2 && !lednice && mistnost) {
    				mistnost_id = nSensors;
    			}		
    			nSensors++;
    		}
    	
    		if( nSensors ) return nSensors;
    
    		leds_search();
    
    		leds_blink(LED_BLINK_FAST_INTERVAL);
    
    		m_delay_s(1);
    	}
    }
    
    void vypsat_senzory() {
    	nSensors = search_sensors();
    
    	for ( int i=0; i<nSensors; i++ ) {
    		writestr("#");
    		writestr_integer((int) i);
    		if(i == akva1_id)
    			writestr(":AKVA1:");
    		if(i == akva2_id)
    			writestr(":AKVA2:");
    		if(i == lednice_id)
    			writestr(":LEDNICE:");
    		if(i == mistnost_id)
    			writestr(":MISTNOST:");
    		writestr(" ");
    		writetemp(getTemp(i));
    		lfcr();
    	}
    }
    
    void uloz_senzor( uint8_t *id, uint8_t kam ) {
    	for (int i=0; i<OW_ROMCODE_SIZE; i++) {
    		eeprom_busy_wait();
    		eeprom_write_byte((uint8_t*)(kam+i),id[i]);
    	}
    }
    
    void nastav_senzor(char cilselekt) {
    	uint8_t sensT = (uint8_t)(rx_buffer[0]-48);
    	writestr_integer((int) sensT); lfcr();
    	if ( sensT < nSensors ) {
    		if(cilselekt == '1')
    			uloz_senzor(&gSensorIDs[sensT][0], EEPROM_AKVA1_SENSOR);
    		else if(cilselekt == '2')
    			uloz_senzor(&gSensorIDs[sensT][0], EEPROM_AKVA2_SENSOR);
    		else if(cilselekt == 'l')
    			uloz_senzor(&gSensorIDs[sensT][0], EEPROM_LEDNICE_SENSOR);
    		else if(cilselekt == 'm')
    			uloz_senzor(&gSensorIDs[sensT][0], EEPROM_MISTNOST_SENSOR);
    		else errorWrite(1);
    		writestr("+1 OK");
    		lfcr();
    		nSensors = search_sensors();
    		vypsat_senzory();
    	}
    	else
    		errorWrite(1);
    }
    
    void eeprog_vstup_podprogram() {
    	if(citac_ee > 0) {
    		for (uint8_t i=RX_BUFFER_SIZE; i>0; i--) rx_buffer[i]=0;
    		rs232enter=0;
    		rs232ready=true;
    		while(1) {
    			if(rs232enter) {
    				rs232ready=false;
    				if(cmdtest('L','S',0))
    					vypsat_senzory();
    				else if(cmdtest('S','A',1))
    					nastav_senzor('1');
    				else if(cmdtest('S','B',1))
    					nastav_senzor('2');
    				else if(cmdtest('S','L',1))
    					nastav_senzor('l');
    				else if(cmdtest('S','M',1))
    					nastav_senzor('m');
    				else if(cmdtest('E','Q',0)) {
    					writestr("+1 OK"); lfcr();
    					break;
    				}
    				else
    					errorWrite(3);
    				for (uint8_t i=RX_BUFFER_SIZE; i>0; i--) rx_buffer[i]=0;
    				rs232enter=0;
    				rs232ready=true;
    			}
    		}
    	}
    	else
    		errorWrite(4);
    }
    
    
    Samotné search_sensors(void) funguje dobře, opravdu porovnává všechny bajty identifikace senzoru vs. uložená identifikace v eeprom. Problém nastává, pokud chci uložit nový senzor. Všechny se ukládají dobře, kromě 1.(senzor #0). Pokud se jednoduše snažím uložit senzor 0 jako cokoliv, tak je první bajt vždy 0x00. Takhle vypadá část eepromky: 00FBFA97020000A728D6F797020000B72820BA9702000072. Správně ale má být 28FBFA97020000A728D6F797020000B72820BA9702000072. Co mám špatně?

    Řešení dotazu:


    Odpovědi

    28.5.2010 21:29 mcuProg
    Rozbalit Rozbalit vše Re: C - chybné čtení id 1. sensoru
    Uz jsem to nasel, asi bych nemel jen tak bezhlave kopirovat :[ for (uint8_t i=RX_BUFFER_SIZE; i>0; i--) se dostane mimo pole
    30.5.2010 12:19 tom
    Rozbalit Rozbalit vše Re: C - chybné čtení id 1. sensoru
    Doporucuju cykly pres pole psat se sizeof jako napr. for (uint8_t i = sizeof id - 1; i>=0; i--)

    Založit nové vláknoNahoru

    Tiskni Sdílej: Linkuj Jaggni to Vybrali.sme.sk Google Del.icio.us Facebook

    ISSN 1214-1267   www.czech-server.cz
    © 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.