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í
×
    dnes 14:22 | Bezpečnostní upozornění

    V přihlašovací obrazovce LightDM KDE (lightdm-kde-greeter) byla nalezena a již opravena eskalace práv (CVE-2025-62876). Detaily v příspěvku na blogu SUSE Security.

    Ladislav Hagara | Komentářů: 0
    dnes 13:22 | Nová verze

    Byla vydána nová verze 7.2 živé linuxové distribuce Tails (The Amnesic Incognito Live System), jež klade důraz na ochranu soukromí uživatelů a anonymitu. Tor Browser byl povýšen na verzi 15.0.1. Další novinky v příslušném seznamu.

    Ladislav Hagara | Komentářů: 0
    dnes 10:33 | IT novinky

    Česká národní banka (ČNB) nakoupila digitální aktiva založená na blockchainu za milion dolarů (20,9 milionu korun). Na vytvořeném testovacím portfoliu, jehož součástí jsou bitcoin, stablecoiny navázané na dolar a tokenizované depozitum, chce získat praktickou zkušenost s držením digitálních aktiv. Portfolio nebude součástí devizových rezerv, uvedla dnes ČNB v tiskové zprávě.

    Ladislav Hagara | Komentářů: 13
    dnes 03:22 | IT novinky

    Apple představil iPhone Pocket pro stylové přenášení iPhonu. iPhone Pocket vzešel ze spolupráce značky ISSEY MIYAKE a Applu a jeho tělo tvoří jednolitý 3D úplet, který uschová všechny modely iPhonu. iPhone Pocket s krátkým popruhem se prodává za 149,95 dolarů (USA) a s dlouhým popruhem za 229,95 dolarů (USA).

    Ladislav Hagara | Komentářů: 10
    dnes 02:33 | Nová verze

    Byla vydána nová stabilní verze 7.7 webového prohlížeče Vivaldi (Wikipedie). Postavena je na Chromiu 142. Přehled novinek i s náhledy v příspěvku na blogu.

    Ladislav Hagara | Komentářů: 0
    včera 22:11 | Nová verze

    Společnost Epic Games vydala verzi 5.7 svého proprietárního multiplatformního herního enginu Unreal Engine (Wikipedie). Podrobný přehled novinek v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 2
    včera 16:22 | Bezpečnostní upozornění

    Intel vydal 30 upozornění na bezpečnostní chyby ve svých produktech. Současně vydal verzi 20251111 mikrokódů pro své procesory.

    Ladislav Hagara | Komentářů: 0
    včera 15:33 | Nová verze

    Byla vydána říjnová aktualizace aneb nová verze 1.106 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.106 vyjde také VSCodium, tj. komunitní sestavení Visual Studia Code bez telemetrie a licenčních podmínek Microsoftu.

    Ladislav Hagara | Komentářů: 0
    včera 12:11 | Komunita

    Canonical pro své zákazníky, předplatitele Ubuntu Pro, prodloužil podporu Ubuntu LTS z 12 let na 15 let (Legacy add-on). Týká se verzí od 14.04 (Trusty Tahr).

    Ladislav Hagara | Komentářů: 2
    včera 05:11 | Nová verze

    Homebrew (Wikipedie), správce balíčků pro macOS a od verze 2.0.0 také pro Linux, byl vydán ve verzi 5.0.0. Nově je oficiálně podporován Linux ARM64/AArch64. Na stránce Homebrew Formulae lze procházet seznamem balíčků. K dispozici jsou také různé statistiky.

    Ladislav Hagara | Komentářů: 6
    Jaké řešení používáte k vývoji / práci?
     (35%)
     (47%)
     (18%)
     (18%)
     (23%)
     (15%)
     (23%)
     (15%)
     (16%)
    Celkem 350 hlasů
     Komentářů: 16, poslední 12.11. 18:21
    Rozcestník

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

    28.5.2010 17:14 mcuProg
    C - chybné čtení id 1. sensoru
    Přečteno: 364×
    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.