Está en la página 1de 5

//ANA MARIA LOPEZ MIRANDA

#include "main.h"

void SystemClock_Config(void);

static void MX_GPIO_Init(void);

int entero=32526;

uint32_t hexa;//depende de la longitud del numero

int cociente=0, residuo=0, convert=0;//auxiliares

int dato1=0,dato2=0;

int main(void)

HAL_Init();

SystemClock_Config();

MX_GPIO_Init();

residuo = entero%16;//se parta la parte del residuo

cociente = entero / 16;

hexa = hexa | (residuo<<4);//se corre de a 4 beats

residuo = cociente%16;

cociente = cociente/16;

hexa = hexa | (residuo<<8);//interaccion cambia el cociente

hexa = hexa | (cociente << 12);//necesito 4 beats por numero

//cociente da un número menor a 16

convert = (int)hexa;//conversion de un numero cualquiera a entero

//se convierte a entero


dato1 = 0x0F & hexa;//(una and) cifras menos significativas ,dejo todos los beats
despues del 4 en 0 y los primeros 4 me quedan en 1 y realizo una and con el
numero hexa (solo mi primera cifra)

dato2 = (0xF00 & hexa)>>8;//corrimiento aseguro los 4 ceros y los últimos


en 1

//agrego un corrimiento de 8 beats para el otro lado para que me muestre F


//12 no porque se va mas alla

while (1){

if (entero){

residuo = entero%16;

{cociente = entero / 16;};

if (entero){

hexa = residuo << 0;

residuo = cociente%16;

cociente = cociente/16;

if(entero){

hexa = hexa | (residuo<<4);

residuo = cociente%16;

cociente = cociente/16;

hexa = hexa | (residuo<<8);

if (entero){

hexa = hexa | (cociente << 12);

convert = (int)hexa;

dato1 = 0x0F & hexa;

dato2 = (0xF00 & hexa)>>8;

}
void SystemClock_Config(void)

RCC_OscInitTypeDef RCC_OscInitStruct = {0};

RCC_ClkInitTypeDef RCC_ClkInitStruct = {0};

/** Initializes the CPU, AHB and APB busses clocks

*/

RCC_OscInitStruct.OscillatorType = RCC_OSCILLATORTYPE_HSI;

RCC_OscInitStruct.HSIState = RCC_HSI_ON;

RCC_OscInitStruct.HSICalibrationValue = RCC_HSICALIBRATION_DEFAULT;

RCC_OscInitStruct.PLL.PLLState = RCC_PLL_ON;

RCC_OscInitStruct.PLL.PLLSource = RCC_PLLSOURCE_HSI;

RCC_OscInitStruct.PLL.PLLMUL = RCC_PLL_MUL12;

if (HAL_RCC_OscConfig(&RCC_OscInitStruct) != HAL_OK)

Error_Handler();

/** Initializes the CPU, AHB and APB busses clocks

*/

RCC_ClkInitStruct.ClockType = RCC_CLOCKTYPE_HCLK|RCC_CLOCKTYPE_SYSCLK

|RCC_CLOCKTYPE_PCLK1|RCC_CLOCKTYPE_PCLK2;

RCC_ClkInitStruct.SYSCLKSource = RCC_SYSCLKSOURCE_PLLCLK;

RCC_ClkInitStruct.AHBCLKDivider = RCC_SYSCLK_DIV1;

RCC_ClkInitStruct.APB1CLKDivider = RCC_HCLK_DIV2;

RCC_ClkInitStruct.APB2CLKDivider = RCC_HCLK_DIV1;
if (HAL_RCC_ClockConfig(&RCC_ClkInitStruct, FLASH_LATENCY_1) != HAL_OK)

Error_Handler();

static void MX_GPIO_Init(void)

GPIO_InitTypeDef GPIO_InitStruct = {0};

/* GPIO Ports Clock Enable */

__HAL_RCC_GPIOE_CLK_ENABLE();

/*Configure GPIO pin Output Level */

HAL_GPIO_WritePin(GPIOE, GPIO_PIN_11|GPIO_PIN_12|GPIO_PIN_13|GPIO_PIN_14, GPIO_PIN_RESET);

/*Configure GPIO pins : PE11 PE12 PE13 PE14 */

GPIO_InitStruct.Pin = GPIO_PIN_11|GPIO_PIN_12|GPIO_PIN_13|GPIO_PIN_14;

GPIO_InitStruct.Mode = GPIO_MODE_OUTPUT_PP;

GPIO_InitStruct.Pull = GPIO_NOPULL;

GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW;

HAL_GPIO_Init(GPIOE, &GPIO_InitStruct);

}
void Error_Handler(void)

/* USER CODE BEGIN Error_Handler_Debug */

/* User can add his own implementation to report the HAL error return state */

/* USER CODE END Error_Handler_Debug */

#ifdef USE_FULL_ASSERT

/**

* @brief Reports the name of the source file and the source line number

* where the assert_param error has occurred.

* @param file: pointer to the source file name

* @param line: assert_param error line source number

* @retval None

*/

void assert_failed(uint8_t *file, uint32_t line)

/* USER CODE BEGIN 6 */

/* User can add his own implementation to report the file name and line number,

tex: printf("Wrong parameters value: file %s on line %d\r\n", file, line) */

/* USER CODE END 6 */

#endif /* USE_FULL_ASSERT */

/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/