计算机组织与结构:第3章 系统总线解析

版权申诉
0 下载量 173 浏览量 更新于2024-07-03 收藏 700KB PPT 举报
"计算机组织与结构的第三章主要讲解了系统总线(System Buses)的相关内容,出自William Stallings的《计算机组织与架构》第七版。本章将深入探讨计算机硬件的基本构造,包括控制单元、算术逻辑单元、输入/输出以及主存储器等组件的功能,同时介绍了程序的概念和指令周期的工作原理。" 计算机组织与结构是理解计算机系统运作的基础,系统总线在其中起着关键的作用。系统总线是一组物理线路,它允许CPU与其他硬件组件(如内存和I/O设备)交换数据和控制信号。总线分为数据总线、地址总线和控制总线,分别负责传输数据、寻址和控制操作。 硬连线系统因其固定功能而缺乏灵活性,而通用硬件可以执行多种任务,只需提供适当的控制信号即可。程序就是一系列步骤,每个步骤对应一个算术或逻辑运算,需要特定的控制信号来执行。控制单元的功能就是根据操作代码产生相应的控制信号,使得硬件能够执行指定的操作。例如,当执行加法操作时,控制单元会发出ADD指令对应的信号。 中央处理单元(CPU)由控制单元和算术逻辑单元(ALU)组成。ALU执行基本的算术和逻辑运算,而控制单元则负责整个操作的调度和控制。计算机还需要与外部世界交互,这就涉及到了输入/输出(I/O)设备,它们负责数据的输入和结果的输出。此外,主存储器作为临时存储,保存待执行的指令和运算结果。 指令周期是CPU工作的一个核心概念,分为两个主要步骤:取指(Fetch)和执行(Execute)。取指过程中,程序计数器(PC)存储下一条指令的地址,CPU从内存中取出该地址的指令,并将PC递增,除非遇到分支指令。执行阶段,CPU解析并执行取出的指令,可能涉及到数据的计算、移动或其他操作。 计算机组织与结构中的系统总线部分,详细阐述了计算机硬件如何通过总线进行通信,以及程序如何在硬件的支持下运行,为我们理解计算机的内部运作提供了深入的洞察。
2023-06-10 上传

void SystemClock_Config(void) { RCC_OscInitTypeDef RCC_OscInitStruct = {0}; RCC_ClkInitTypeDef RCC_ClkInitStruct = {0}; /** Configure the main internal regulator output voltage */ HAL_PWREx_ControlVoltageScaling(PWR_REGULATOR_VOLTAGE_SCALE1); /** Initializes the RCC Oscillators according to the specified parameters * in the RCC_OscInitTypeDef structure. */ RCC_OscInitStruct.OscillatorType = RCC_OSCILLATORTYPE_HSI; RCC_OscInitStruct.HSIState = RCC_HSI_ON; RCC_OscInitStruct.HSIDiv = RCC_HSI_DIV1; RCC_OscInitStruct.HSICalibrationValue = RCC_HSICALIBRATION_DEFAULT; RCC_OscInitStruct.PLL.PLLState = RCC_PLL_ON; RCC_OscInitStruct.PLL.PLLSource = RCC_PLLSOURCE_HSI; RCC_OscInitStruct.PLL.PLLM = RCC_PLLM_DIV1; RCC_OscInitStruct.PLL.PLLN = 8; RCC_OscInitStruct.PLL.PLLP = RCC_PLLP_DIV2; RCC_OscInitStruct.PLL.PLLR = RCC_PLLR_DIV2; if (HAL_RCC_OscConfig(&RCC_OscInitStruct) != HAL_OK) { Error_Handler(); } /** Initializes the CPU, AHB and APB buses clocks */ RCC_ClkInitStruct.ClockType = RCC_CLOCKTYPE_HCLK|RCC_CLOCKTYPE_SYSCLK |RCC_CLOCKTYPE_PCLK1; RCC_ClkInitStruct.SYSCLKSource = RCC_SYSCLKSOURCE_PLLCLK; RCC_ClkInitStruct.AHBCLKDivider = RCC_SYSCLK_DIV1; RCC_ClkInitStruct.APB1CLKDivider = RCC_HCLK_DIV1; if (HAL_RCC_ClockConfig(&RCC_ClkInitStruct, FLASH_LATENCY_2) != HAL_OK) { Error_Handler(); } } /** * @brief I2C1 Initialization Function * @param None * @retval None */ static void MX_I2C1_Init(void) { /* USER CODE BEGIN I2C1_Init 0 */ /* USER CODE END I2C1_Init 0 */ /* USER CODE BEGIN I2C1_Init 1 */ /* USER CODE END I2C1_Init 1 */ hi2c1.Instance = I2C1; hi2c1.Init.Timing = 0x10707DBC; hi2c1.Init.OwnAddress1 = 0; hi2c1.Init.AddressingMode = I2C_ADDRESSINGMODE_7BIT; hi2c1.Init.DualAddressMode = I2C_DUALADDRESS_DISABLE; hi2c1.Init.OwnAddress2 = 0; hi2c1.Init.OwnAddress2Masks = I2C_OA2_NOMASK; hi2c1.Init.GeneralCallMode = I2C_GENERALCALL_DISABLE; hi2c1.Init.NoStretchMode = I2C_NOSTRETCH_DISABLE; if (HAL_I2C_Init(&hi2c1) != HAL_OK) { Error_Handler(); } /** Configure Analogue filter */ if (HAL_I2CEx_ConfigAnalogFilter(&hi2c1, I2C_ANALOGFILTER_ENABLE) != HAL_OK) { Error_Handler(); } /** Configure Digital filter */ if (HAL_I2CEx_ConfigDigitalFilter(&hi2c1, 0) != HAL_OK) { Error_Handler(); } GPIO_InitTypeDef GPIO_InitStruct; __HAL_RCC_GPIOB_CLK_ENABLE(); // 配置 I2C1_SCL 引脚 GPIO_InitStruct.Pin = GPIO_PIN_3; GPIO_InitStruct.Mode = GPIO_MODE_AF_OD; GPIO_InitStruct.Pull = GPIO_PULLUP; GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_HIGH; GPIO_InitStruct.Alternate = GPIO_AF6_I2C1; HAL_GPIO_Init(GPIOB, &GPIO_InitStruct); GPIO_InitStruct.Pin = GPIO_PIN_7; GPIO_InitStruct.Mode = GPIO_MODE_AF_OD; GPIO_InitStruct.Pull = GPIO_PULLUP; GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_HIGH; GPIO_InitStruct.Alternate = GPIO_AF6_I2C1; HAL_GPIO_Init(GPIOB, &GPIO_InitStruct); /* USER CODE BEGIN I2C1_Init 2 */ /* USER CODE END I2C1_Init 2 */ }这个是什么意思需要修改添加代码吗

2023-07-15 上传