aboutsummaryrefslogtreecommitdiffstats
path: root/docs/ja/newbs_git_resynchronize_a_branch.md
blob: e81d2da1fb1c932e2bb492e83a802b1716a509cd (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
# 同期のとれていない git ブランチの再同期

<!---
  grep --no-filename "^[ ]*git diff" docs/ja/*.md | sh
  original document: adf4acf59:docs/newbs_git_resynchronize_a_branch.md
  git diff adf4acf59 HEAD -- docs/newbs_git_resynchronize_a_branch.md | cat
-->

仮にあなたの `master` ブランチにあなたのコミットを行い、そしてあなたの QMK リポジトリの更新が必要になったとします。
(フォーク元の) QMK の `master` ブランチをあなたの `master` ブランチに `git pull` することもできますが、GitHub は、あなたのブランチが `qmk:master` より何コミットか先行していると通知します、この状態で QMK にプルリクエストを行う場合、問題が発生する可能性があります。
(訳注:この通知は、GitHub のあなたのリポジトリの code ペインのブランチ選択メニューの下のあたりで `This branch is 3 commit ahead of qmk:master` という様な文面で表示されています。)

?> このドキュメントは [あなたのフォークの master ブランチ: 更新は頻繁に、コミットはしないこと](ja/newbs_git_using_your_master_branch.md) で詳述されている概念に基づいています。その概念に慣れていない場合は、まずそれを読んでから、ここに戻ってください。  
(訳注:この文書で言う、「同期のとれていない git ブランチ」とは、master ブランチに関する、この「コミットしない」方針を逸脱して、QMK の master リポジトリに存在しないコミットがあなたのフォークの master ブランチに入っている状態を指します。)

## あなた自身の `master` ブランチでの変更のバックアップ(オプション)

救えるものなら自分の行った変更を失いたくはないでしょう。
あなたの `master` ブランチに既に加えた変更を保存したい場合、最も簡単な方法は、単に「ダーティな」`master` ブランチの複製を作成することです:

```sh
git branch old_master master
```

これで、 `master` ブランチの複製である `old_master` という名前のブランチができました。

## あなたのブランチの再同期

さあ、`master` ブランチを再同期します。
この手順では、QMK のリポジトリを git のリモートリポジトリとして設定する必要があります。
設定済みのリモートリポジトリを確認するには、`git remote -v` を実行し、次のような結果が返されなければなりません。

```sh
QMKuser ~/qmk_firmware (master)
$ git remote -v
origin  https://github.com/<your_username>/qmk_firmware.git (fetch)
origin  https://github.com/<your_username>/qmk_firmware.git (push)
upstream        https://github.com/qmk/qmk_firmware.git (fetch)
upstream        https://github.com/qmk/qmk_firmware.git (push)
```

もし、上記のようにならずに以下のように参照されるフォークが、1つだけ表示される場合:

```sh
QMKuser ~/qmk_firmware (master)
$ git remote -v
origin  https://github.com/qmk/qmk_firmware.git (fetch)
origin  https://github.com/qmk/qmk_firmware.git (push)
```

新しいリモートリポジトリを追加します:

```sh
git remote add upstream https://github.com/qmk/qmk_firmware.git
```

次に、`origin` リモートリポジトリを、あなた自身のフォークにリダイレクトします:

```sh
git remote set-url origin https://github.com/<あなたのユーザ名>/qmk_firmware.git
```

両方のリモートリポジトリが設定されたので、次を実行して、QMK である `upstream` リポジトリの参照を更新する必要があります。

```sh
git fetch upstream
```

この時点で、次を実行してあなたの(訳注:master)ブランチを QMK のブランチに再同期します。
(訳注: 今現在 `master` ブランチがチェックアウトされていなければなりません。
 そうなってなければ、`git checkout master` を先に実行しておく必要があります。)

```sh
git reset --hard upstream/master
```

これらの手順により、あなたのコンピュータ上のリポジトリが更新されますが、あなたの GitHub 上のフォークはまだ同期されていません。
GitHub 上のフォークを再同期するには、あなたのフォークにプッシュして、ローカルリポジトリに反映されていないリモート変更をオーバーライドするように Git に指示する必要があります。
これを行うには、次を実行します:

```sh
git push --force-with-lease
```

!> 他のユーザーがコミットを投稿するフォークで `git push --force-with-lease` を**実行しないでください**。これをすると、かれらのコミットが消去されてしまいます。

これで、あなたの GitHub フォーク、あなたのローカルファイル、および QMK のリポジトリはすべて同じになりました。
ここから、[ブランチを使って](ja/newbs_git_using_your_master_branch.md#making-changes)さらに必要な変更を加え、通常どおりそれらを投稿できます。
o_read_flash_cmd(struct spi_device *spi, + struct spi_transfer *t) +{ + struct ath79_spi *sp = ath79_spidev_to_sp(spi); + int len; + const u8 *p; + + sp->read_addr = 0; + + len = t->len - 1; + p = t->tx_buf; + + while (len--) { + p++; + sp->read_addr <<= 8; + sp->read_addr |= *p; + } + + return t->len; +} + +static bool ath79_spi_is_read_cmd(struct spi_device *spi, + struct spi_transfer *t) +{ + return t->type == SPI_TRANSFER_FLASH_READ_CMD; +} + +static bool ath79_spi_is_data_read(struct spi_device *spi, + struct spi_transfer *t) +{ + return t->type == SPI_TRANSFER_FLASH_READ_DATA; +} + +static int ath79_spi_txrx_bufs(struct spi_device *spi, struct spi_transfer *t) +{ + struct ath79_spi *sp = ath79_spidev_to_sp(spi); + int ret; + + switch (sp->state) { + case ATH79_SPI_STATE_WAIT_CMD: + if (ath79_spi_is_read_cmd(spi, t)) { + ret = ath79_spi_do_read_flash_cmd(spi, t); + sp->state = ATH79_SPI_STATE_WAIT_READ; + } else { + ret = spi_bitbang_bufs(spi, t); + } + break; + + case ATH79_SPI_STATE_WAIT_READ: + if (ath79_spi_is_data_read(spi, t)) { + ret = ath79_spi_do_read_flash_data(spi, t); + } else { + dev_warn(&spi->dev, "flash data read expected\n"); + ret = -EIO; + } + sp->state = ATH79_SPI_STATE_WAIT_CMD; + break; + + default: + BUG(); + } + + return ret; +} + +static int ath79_spi_setup_transfer(struct spi_device *spi, + struct spi_transfer *t) +{ + struct ath79_spi *sp = ath79_spidev_to_sp(spi); + struct ath79_spi_controller_data *cdata; + int ret; + + ret = spi_bitbang_setup_transfer(spi, t); + if (ret) + return ret; + + cdata = spi->controller_data; + if (cdata->is_flash) + sp->bitbang.txrx_bufs = ath79_spi_txrx_bufs; + else + sp->bitbang.txrx_bufs = spi_bitbang_bufs; + + return ret; +} + static __devinit int ath79_spi_probe(struct platform_device *pdev) { struct spi_master *master; @@ -251,6 +362,8 @@ static __devinit int ath79_spi_probe(str sp = spi_master_get_devdata(master); platform_set_drvdata(pdev, sp); + sp->state = ATH79_SPI_STATE_WAIT_CMD; + master->setup = ath79_spi_setup; master->cleanup = ath79_spi_cleanup; master->bus_num = pdata->bus_num; @@ -259,7 +372,7 @@ static __devinit int ath79_spi_probe(str sp->bitbang.master = spi_master_get(master); sp->bitbang.chipselect = ath79_spi_chipselect; sp->bitbang.txrx_word[SPI_MODE_0] = ath79_spi_txrx_mode0; - sp->bitbang.setup_transfer = spi_bitbang_setup_transfer; + sp->bitbang.setup_transfer = ath79_spi_setup_transfer; sp->bitbang.flags = SPI_CS_HIGH; r = platform_get_resource(pdev, IORESOURCE_MEM, 0); @@ -284,7 +397,8 @@ static __devinit int ath79_spi_probe(str if (ret) goto err_clk_put; - rate = DIV_ROUND_UP(clk_get_rate(sp->clk), MHZ); + sp->ahb_rate = clk_get_rate(sp->clk); + rate = DIV_ROUND_UP(sp->ahb_rate, MHZ); if (!rate) { ret = -EINVAL; goto err_clk_disable; --- a/arch/mips/include/asm/mach-ath79/ath79_spi_platform.h +++ b/arch/mips/include/asm/mach-ath79/ath79_spi_platform.h @@ -24,6 +24,7 @@ enum ath79_spi_cs_type { struct ath79_spi_controller_data { enum ath79_spi_cs_type cs_type; unsigned cs_line; + bool is_flash; }; #endif /* _ATH79_SPI_PLATFORM_H */