mirror of https://github.com/OpenIPC/firmware.git
				
				
				
			Fixes for Hi3536Cv100 SoC
							parent
							
								
									c82116d012
								
							
						
					
					
						commit
						37a28e7ebc
					
				|  | @ -0,0 +1,134 @@ | |||
| name: Hi3536Cv100 | ||||
| 
 | ||||
| on: | ||||
|   push: | ||||
|     branches: | ||||
|       - master | ||||
|     tags: | ||||
|       - "v*" | ||||
|   workflow_dispatch: | ||||
| 
 | ||||
| jobs: | ||||
|   build_core: | ||||
|     name: OpenIPC v2.1 for Hi3536Cv100 | ||||
|     runs-on: ubuntu-latest | ||||
| 
 | ||||
|     steps: | ||||
| 
 | ||||
|       - name: Checkout | ||||
|         id: checkout | ||||
|         uses: actions/checkout@v2 | ||||
| 
 | ||||
|       - name: Install build dependencies | ||||
|         id: install | ||||
|         run: | | ||||
|           make install-deps | ||||
|           mkdir -p tmp | ||||
| 
 | ||||
|       - name: Free disk space | ||||
|         id: freshing | ||||
|         run: | | ||||
|           sudo swapoff -a | ||||
|           sudo rm -f /swapfile | ||||
|           sudo apt clean | ||||
|           docker rmi $(docker image ls -aq) | ||||
|           df -h | ||||
| 
 | ||||
|       - name: Prepare buildroot | ||||
|         id: prepare | ||||
|         run: | | ||||
|           HEAD_TAG=$(git tag --points-at HEAD) | ||||
|           GIT_HASH=$(git rev-parse --short $GITHUB_SHA) | ||||
|           BRANCH_NAME=$(echo $GITHUB_REF | cut -d'/' -f 3) | ||||
|           if [ -z "$HEAD_TAG" ]; then | ||||
|             TAG_NAME="latest" | ||||
|             RELEASE_NAME="Development Build" | ||||
|             PRERELEASE=true | ||||
|           else | ||||
|             TAG_NAME=${{ github.ref }} | ||||
|             RELEASE_NAME="Release ${{ github.ref }}" | ||||
|             PRERELEASE=false | ||||
|           fi | ||||
|           echo "GIT_HASH=$GIT_HASH" >> $GITHUB_ENV | ||||
|           echo "TAG_NAME=$TAG_NAME" >> $GITHUB_ENV | ||||
|           echo "RELEASE_NAME=$RELEASE_NAME" >> $GITHUB_ENV | ||||
|           echo "PRERELEASE=$PRERELEASE" >> $GITHUB_ENV | ||||
|           echo "BRANCH_NAME=$BRANCH_NAME" >> $GITHUB_ENV | ||||
|           cd $GITHUB_WORKSPACE | ||||
|           make prepare | ||||
| 
 | ||||
|       - name: Build Hi3536Cv100 firmware | ||||
|         id: build-hi3536cv100-firmware | ||||
|         continue-on-error: true | ||||
|         run: | | ||||
|           ARCHIVE_FW="${GITHUB_WORKSPACE}/output/images/openipc.hi3536cv100-br.tgz" | ||||
|           echo "ARCHIVE_FW=$ARCHIVE_FW" >> $GITHUB_ENV | ||||
|           cd $GITHUB_WORKSPACE | ||||
|           make PLATFORM=hisilicon BOARD=unknown_unknown_hi3536cv100_openipc all | ||||
|           [[ $(stat --printf="%s" ${GITHUB_WORKSPACE}/output/images/uImage) -gt 2097152 ]] && echo "TG_NOTIFY=Warning, kernel size exceeded : $(stat --printf="%s" ${GITHUB_WORKSPACE}/output/images/uImage) vs 2097152" >> $GITHUB_ENV && exit 1 | ||||
|           [[ $(stat --printf="%s" ${GITHUB_WORKSPACE}/output/images/rootfs.squashfs) -gt 5242880 ]] && echo "TG_NOTIFY=Warning, rootfs size exceeded - $(stat --printf="%s" ${GITHUB_WORKSPACE}/output/images/rootfs.squashfs) vs 5242880" >> $GITHUB_ENV && exit 1 | ||||
|           mv ${GITHUB_WORKSPACE}/output/images/uImage ${GITHUB_WORKSPACE}/output/images/uImage.hi3536cv100 | ||||
|           mv ${GITHUB_WORKSPACE}/output/images/rootfs.squashfs ${GITHUB_WORKSPACE}/output/images/rootfs.squashfs.hi3536cv100 | ||||
|           tar -C ${GITHUB_WORKSPACE}/output/images -cvzf $ARCHIVE_FW rootfs.squashfs.hi3536cv100 uImage.hi3536cv100 | ||||
| 
 | ||||
|       - name: Build Hi3536Cv100 SDK | ||||
|         id: build-hi3536cv100-sdk | ||||
|         continue-on-error: true | ||||
|         run: | | ||||
|           ARCHIVE_SDK="${GITHUB_WORKSPACE}/output/images/arm-openipc-linux-musleabi_sdk-buildroot.tar.gz" | ||||
|           echo "ARCHIVE_SDK=$ARCHIVE_SDK" >> $GITHUB_ENV | ||||
|           cd $GITHUB_WORKSPACE/output | ||||
|           make sdk | ||||
| 
 | ||||
|       - name: Send warning message to telegram channel | ||||
|         env: | ||||
|           TG_TOKEN: ${{ secrets.TELEGRAM_TOKEN_BOT_OPENIPC }} | ||||
|           TG_CHANNEL: ${{ secrets.TELEGRAM_CHANNEL_OPENIPC_DEV }} | ||||
|         if: steps.build-hi3536cv100-firmware.outcome != 'success' || steps.build-hi3536cv100-sdk.outcome != 'success' | ||||
|         run: | | ||||
|           TG_OPTIONS="-s --connect-timeout 30 --max-time 30" | ||||
|           TG_NOTIFY="${TG_NOTIFY:=Warning, Buildroot compiling error... Hi3536Cv100}" | ||||
|           TG_HEADER=$(echo -e "\r\n$TG_NOTIFY \r\n\r\nCommit: $GIT_HASH \r\nBranch: $BRANCH_NAME \r\nTag: $TAG_NAME \r\n\r\n\xE2\x9A\xA0 GitHub Actions") | ||||
|           curl $TG_OPTIONS -H "Content-Type: multipart/form-data" -X POST https://api.telegram.org/bot$TG_TOKEN/sendMessage \ | ||||
|             -F chat_id=$TG_CHANNEL -F text="$TG_HEADER" | ||||
| 
 | ||||
|       - name: Create release | ||||
|         uses: actions/create-release@v1 | ||||
|         continue-on-error: true | ||||
|         env: | ||||
|           GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | ||||
|         with: | ||||
|           tag_name: ${{ env.TAG_NAME }} | ||||
|           release_name: ${{ env.RELEASE_NAME }} | ||||
|           draft: false | ||||
|           prerelease: ${{ env.PRERELEASE }} | ||||
| 
 | ||||
|       - name: Upload FW to release | ||||
|         uses: svenstaro/upload-release-action@v2 | ||||
|         continue-on-error: true | ||||
|         with: | ||||
|           repo_token: ${{ secrets.GITHUB_TOKEN }} | ||||
|           file: ${{ env.ARCHIVE_FW }} | ||||
|           asset_name: "openipc.hi3536cv100-br.tgz" | ||||
|           tag: ${{ env.TAG_NAME }} | ||||
|           overwrite: true | ||||
| 
 | ||||
|       - name: Upload SDK to release | ||||
|         uses: svenstaro/upload-release-action@v2 | ||||
|         continue-on-error: true | ||||
|         with: | ||||
|           repo_token: ${{ secrets.GITHUB_TOKEN }} | ||||
|           file: ${{ env.ARCHIVE_SDK }} | ||||
|           asset_name: "arm-openipc-hi3536cv100-linux-musleabi_sdk-buildroot.tar.gz" | ||||
|           tag: ${{ env.TAG_NAME }} | ||||
|           overwrite: true | ||||
| 
 | ||||
|       - name: Send binary file to telegram channel | ||||
|         env: | ||||
|           TG_TOKEN: ${{ secrets.TELEGRAM_TOKEN_BOT_OPENIPC }} | ||||
|           TG_CHANNEL: ${{ secrets.TELEGRAM_CHANNEL_OPENIPC_DEV }} | ||||
|         run: | | ||||
|           TG_OPTIONS="-s --connect-timeout 30 --max-time 30" | ||||
|           TG_HEADER=$(echo -e "\r\nCommit: $GIT_HASH \r\nBranch: $BRANCH_NAME \r\nTag: $TAG_NAME \r\n\r\n\xE2\x9C\x85 GitHub Actions") | ||||
|           curl $TG_OPTIONS -H "Content-Type: multipart/form-data" -X POST https://api.telegram.org/bot$TG_TOKEN/sendDocument \ | ||||
|             -F chat_id=$TG_CHANNEL -F document="@$ARCHIVE_FW" -F caption="$TG_HEADER" | ||||
|  | @ -0,0 +1,18 @@ | |||
| --- a/arch/arm/boot/dts/hi3536c-demb.dts
 | ||||
| +++ b/arch/arm/boot/dts/hi3536c-demb.dts
 | ||||
| @@ -102,12 +102,13 @@
 | ||||
|   | ||||
|  &mdio { | ||||
|  	ethphy: ethernet-phy@1 { | ||||
| -		reg = <1>;
 | ||||
| +		reg = <2>;
 | ||||
|  	}; | ||||
|  }; | ||||
|  &mdio1 { | ||||
|  	ethphy1: ethernet-phy@2 { | ||||
| -		reg = <2>;
 | ||||
| +		reg = <1>;
 | ||||
| +		status = "disabled";
 | ||||
|  	}; | ||||
|  }; | ||||
|   | ||||
|  | @ -0,0 +1,48 @@ | |||
| --- a/drivers/mtd/spi-nor/spi-nor.c
 | ||||
| +++ b/drivers/mtd/spi-nor/spi-nor.c
 | ||||
| @@ -1024,6 +1024,23 @@
 | ||||
|  	.erase_types[1]		= SNOR_OP_ERASE_4K(SPINOR_OP_BE_4K), | ||||
|  }; | ||||
|   | ||||
| +
 | ||||
| +static const struct spi_nor_basic_flash_parameter xmc_params = {
 | ||||
| +	.rd_modes		= SNOR_RD_MODES,
 | ||||
| +	.reads[SNOR_MIDX_SLOW]	= SNOR_OP_READ(0, 0, SPINOR_OP_READ),
 | ||||
| +	.reads[SNOR_MIDX_1_1_1]	= SNOR_OP_READ(0, 8, SPINOR_OP_READ_FAST),
 | ||||
| +	.reads[SNOR_MIDX_1_1_2]	= SNOR_OP_READ(0, 8, SPINOR_OP_READ_1_1_2),
 | ||||
| +	.reads[SNOR_MIDX_1_2_2]	= SNOR_OP_READ(0, 8, SPINOR_OP_READ_1_2_2),
 | ||||
| +	.reads[SNOR_MIDX_1_1_4]	= SNOR_OP_READ(0, 8, SPINOR_OP_READ_1_1_4),
 | ||||
| +	.reads[SNOR_MIDX_1_4_4]	= SNOR_OP_READ(0, 24, SPINOR_OP_READ_1_4_4),
 | ||||
| +
 | ||||
| +	.wr_modes		= SNOR_WR_MODES,
 | ||||
| +	.page_programs[SNOR_MIDX_1_1_1]	= SPINOR_OP_PP,
 | ||||
| +	.page_programs[SNOR_MIDX_1_1_4]	= SPINOR_OP_PP_1_1_4,
 | ||||
| +
 | ||||
| +	.erase_types[0]		= SNOR_OP_ERASE_64K(SPINOR_OP_SE),
 | ||||
| +};
 | ||||
| +
 | ||||
|  #define PARAMS(_name) .params = &_name##_params | ||||
|   | ||||
|  /* Used when the "_ext_id" is two bytes at most */ | ||||
| @@ -1063,7 +1080,7 @@
 | ||||
|  		.addr_width = (_addr_width),				\ | ||||
|  		.flags = (_flags), | ||||
|   | ||||
| -/* Different from spi-max-frequency in DTS, the clk here stands for the clock 
 | ||||
| +/* Different from spi-max-frequency in DTS, the clk here stands for the clock
 | ||||
|   * rate on SPI interface, it is half of the FMC CRG configuration */ | ||||
|  #define CLK_MHZ_2X(clk)  .clkrate = (clk * 2000000), | ||||
|   | ||||
| @@ -1387,6 +1404,12 @@
 | ||||
|  	{ "pn25f32s", INFO(0xe04016, 0, 64 * 1024,  64, | ||||
|  			SPI_NOR_QUAD_READ), PARAMS(paragon), CLK_MHZ_2X(80) }, | ||||
|   | ||||
| +	/* XMC 3.3V */
 | ||||
| +	{ "xm25qh128a",   INFO(0x207018, 0, 64 * 1024,   256, SPI_NOR_DUAL_READ),
 | ||||
| +	    PARAMS(xmc) },
 | ||||
| +	{ "xm25qh128b",   INFO(0x206018, 0, 64 * 1024,   256, SPI_NOR_DUAL_READ),
 | ||||
| +	    PARAMS(xmc) },
 | ||||
| +
 | ||||
|  	{ }, | ||||
|  }; | ||||
|   | ||||
		Loading…
	
		Reference in New Issue