diff --git a/src/plugins/genericprojectmanager/genericmakestep.cpp b/src/plugins/genericprojectmanager/genericmakestep.cpp
index cc56f3a13d9cecd4731145529f6588fa24b15666..cc707266e841a7d3b43c17c47bdd89fed7410688 100644
--- a/src/plugins/genericprojectmanager/genericmakestep.cpp
+++ b/src/plugins/genericprojectmanager/genericmakestep.cpp
@@ -30,6 +30,7 @@
 #include "genericmakestep.h"
 #include "genericprojectconstants.h"
 #include "genericproject.h"
+#include "ui_genericmakestep.h"
 
 #include <extensionsystem/pluginmanager.h>
 #include <projectexplorer/toolchain.h>
@@ -98,11 +99,21 @@ bool GenericMakeStep::init(const QString &buildConfiguration)
 
     setEnabled(buildConfiguration, true);
     setWorkingDirectory(buildConfiguration, m_pro->buildDirectory(buildConfiguration));
-    if (ProjectExplorer::ToolChain *toolChain = m_pro->toolChain())
-        setCommand(buildConfiguration, toolChain->makeCommand());
-    else
-        setCommand(buildConfiguration, "make");
-    setArguments(buildConfiguration, value(buildConfiguration, "buildTargets").toStringList()); // TODO
+
+    QString command = value(buildConfiguration, "makeCommand").toString();
+    if (command.isEmpty()) {
+        if (ProjectExplorer::ToolChain *toolChain = m_pro->toolChain())
+            command = toolChain->makeCommand();
+        else
+            command = QLatin1String("make");
+    }
+    setCommand(buildConfiguration, command);
+
+    const QStringList targets = value(buildConfiguration, "buildTargets").toStringList();
+    QStringList arguments = value(buildConfiguration, "makeArguments").toStringList();
+    arguments.append(targets);
+    setArguments(buildConfiguration, arguments);
+
     setEnvironment(buildConfiguration, m_pro->environment(buildConfiguration));
     return AbstractProcessStep::init(buildConfiguration);
 }
@@ -231,25 +242,23 @@ void GenericMakeStep::setBuildTarget(const QString &buildConfiguration, const QS
 GenericMakeStepConfigWidget::GenericMakeStepConfigWidget(GenericMakeStep *makeStep)
     : m_makeStep(makeStep)
 {
-    QFormLayout *fl = new QFormLayout(this);
-    setLayout(fl);
-
-    m_targetsList = new QListWidget;
-    fl->addRow("Targets:", m_targetsList);
+    m_ui = new Ui::GenericMakeStep;
+    m_ui->setupUi(this);
 
     // TODO update this list also on rescans of the GenericLists.txt
     GenericProject *pro = m_makeStep->project();
-    foreach(const QString& target, pro->targets()) {
-        QListWidgetItem *item = new QListWidgetItem(target, m_targetsList);
+    foreach (const QString &target, pro->targets()) {
+        QListWidgetItem *item = new QListWidgetItem(target, m_ui->targetsList);
         item->setFlags(item->flags() | Qt::ItemIsUserCheckable);
         item->setCheckState(Qt::Unchecked);
     }
-    connect(m_targetsList, SIGNAL(itemChanged(QListWidgetItem*)), this, SLOT(itemChanged(QListWidgetItem*)));
-}
 
-void GenericMakeStepConfigWidget::itemChanged(QListWidgetItem *item)
-{
-    m_makeStep->setBuildTarget(m_buildConfiguration, item->text(), item->checkState() & Qt::Checked);
+    connect(m_ui->targetsList, SIGNAL(itemChanged(QListWidgetItem*)),
+            this, SLOT(itemChanged(QListWidgetItem*)));
+    connect(m_ui->makeLineEdit, SIGNAL(textEdited(const QString&)),
+            this, SLOT(makeLineEditTextEdited()));
+    connect(m_ui->makeArgumentsLineEdit, SIGNAL(textEdited(const QString&)),
+            this, SLOT(makeArgumentsLineEditTextEdited()));
 }
 
 QString GenericMakeStepConfigWidget::displayName() const
@@ -259,18 +268,48 @@ QString GenericMakeStepConfigWidget::displayName() const
 
 void GenericMakeStepConfigWidget::init(const QString &buildConfiguration)
 {
-    // TODO
-
-    // disconnect to make the changes to the items
-    disconnect(m_targetsList, SIGNAL(itemChanged(QListWidgetItem*)), this, SLOT(itemChanged(QListWidgetItem*)));
     m_buildConfiguration = buildConfiguration;
-    int count = m_targetsList->count();
-    for(int i = 0; i < count; ++i) {
-        QListWidgetItem *item = m_targetsList->item(i);
+
+    // TODO: Label should update when tool chain is changed
+    m_ui->makeLabel->setText(tr("Override %1:").arg(m_makeStep->command(buildConfiguration)));
+
+    const QString &makeCommand = m_makeStep->value(buildConfiguration, "makeCommand").toString();
+    m_ui->makeLineEdit->setText(makeCommand);
+
+    const QStringList &makeArguments =
+            m_makeStep->value(buildConfiguration, "makeArguments").toStringList();
+    m_ui->makeArgumentsLineEdit->setText(ProjectExplorer::Environment::joinArgumentList(makeArguments));
+
+    // Disconnect to make the changes to the items
+    disconnect(m_ui->targetsList, SIGNAL(itemChanged(QListWidgetItem*)), this, SLOT(itemChanged(QListWidgetItem*)));
+
+    int count = m_ui->targetsList->count();
+    for (int i = 0; i < count; ++i) {
+        QListWidgetItem *item = m_ui->targetsList->item(i);
         item->setCheckState(m_makeStep->buildsTarget(buildConfiguration, item->text()) ? Qt::Checked : Qt::Unchecked);
     }
+
     // and connect again
-    connect(m_targetsList, SIGNAL(itemChanged(QListWidgetItem*)), this, SLOT(itemChanged(QListWidgetItem*)));
+    connect(m_ui->targetsList, SIGNAL(itemChanged(QListWidgetItem*)), this, SLOT(itemChanged(QListWidgetItem*)));
+}
+
+void GenericMakeStepConfigWidget::itemChanged(QListWidgetItem *item)
+{
+    QTC_ASSERT(!m_buildConfiguration.isNull(), return);
+    m_makeStep->setBuildTarget(m_buildConfiguration, item->text(), item->checkState() & Qt::Checked);
+}
+
+void GenericMakeStepConfigWidget::makeLineEditTextEdited()
+{
+    QTC_ASSERT(!m_buildConfiguration.isNull(), return);
+    m_makeStep->setValue(m_buildConfiguration, "makeCommand", m_ui->makeLineEdit->text());
+}
+
+void GenericMakeStepConfigWidget::makeArgumentsLineEditTextEdited()
+{
+    QTC_ASSERT(!m_buildConfiguration.isNull(), return);
+    m_makeStep->setValue(m_buildConfiguration, "makeArguments",
+                         ProjectExplorer::Environment::parseCombinedArgString(m_ui->makeArgumentsLineEdit->text()));
 }
 
 //
diff --git a/src/plugins/genericprojectmanager/genericmakestep.h b/src/plugins/genericprojectmanager/genericmakestep.h
index 77e97d4f48391cfc385f5552f85d599788d5a159..e78858fd7828af1201869b1a200a3d7172636e1e 100644
--- a/src/plugins/genericprojectmanager/genericmakestep.h
+++ b/src/plugins/genericprojectmanager/genericmakestep.h
@@ -27,17 +27,19 @@
 **
 **************************************************************************/
 
-#ifndef MAKESTEP_H
-#define MAKESTEP_H
+#ifndef GENERICMAKESTEP_H
+#define GENERICMAKESTEP_H
 
 #include <projectexplorer/abstractprocessstep.h>
 
 QT_BEGIN_NAMESPACE
-class QLineEdit;
-class QListWidget;
 class QListWidgetItem;
 QT_END_NAMESPACE
 
+namespace Ui {
+class GenericMakeStep;
+}
+
 namespace GenericProjectManager {
 namespace Internal {
 
@@ -82,10 +84,12 @@ public:
     virtual void init(const QString &buildConfiguration);
 private slots:
     void itemChanged(QListWidgetItem*);
+    void makeLineEditTextEdited();
+    void makeArgumentsLineEditTextEdited();
 private:
     QString m_buildConfiguration;
+    Ui::GenericMakeStep *m_ui;
     GenericMakeStep *m_makeStep;
-    QListWidget *m_targetsList;
 };
 
 class GenericMakeStepFactory : public ProjectExplorer::IBuildStepFactory
@@ -99,4 +103,4 @@ class GenericMakeStepFactory : public ProjectExplorer::IBuildStepFactory
 } // namespace Internal
 } // namespace GenericProjectManager
 
-#endif // MAKESTEP_H
+#endif // GENERICMAKESTEP_H
diff --git a/src/plugins/genericprojectmanager/genericmakestep.ui b/src/plugins/genericprojectmanager/genericmakestep.ui
new file mode 100644
index 0000000000000000000000000000000000000000..6a4b2796b5dab42bb2039ead9c95137064ca5644
--- /dev/null
+++ b/src/plugins/genericprojectmanager/genericmakestep.ui
@@ -0,0 +1,73 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<ui version="4.0">
+ <class>GenericMakeStep</class>
+ <widget class="QWidget" name="GenericMakeStep">
+  <property name="geometry">
+   <rect>
+    <x>0</x>
+    <y>0</y>
+    <width>274</width>
+    <height>392</height>
+   </rect>
+  </property>
+  <property name="windowTitle">
+   <string>Form</string>
+  </property>
+  <layout class="QVBoxLayout" name="verticalLayout">
+   <item>
+    <widget class="QLabel" name="makeLabel">
+     <property name="text">
+      <string>Override %1:</string>
+     </property>
+     <property name="buddy">
+      <cstring>makeLineEdit</cstring>
+     </property>
+    </widget>
+   </item>
+   <item>
+    <widget class="QLineEdit" name="makeLineEdit"/>
+   </item>
+   <item>
+    <widget class="QLabel" name="makeArgumentsLabel">
+     <property name="text">
+      <string>Make arguments:</string>
+     </property>
+     <property name="buddy">
+      <cstring>makeArgumentsLineEdit</cstring>
+     </property>
+    </widget>
+   </item>
+   <item>
+    <widget class="QLineEdit" name="makeArgumentsLineEdit"/>
+   </item>
+   <item>
+    <widget class="QLabel" name="targetsLabel">
+     <property name="text">
+      <string>Targets:</string>
+     </property>
+     <property name="buddy">
+      <cstring>targetsList</cstring>
+     </property>
+    </widget>
+   </item>
+   <item>
+    <widget class="QListWidget" name="targetsList"/>
+   </item>
+   <item>
+    <spacer name="verticalSpacer">
+     <property name="orientation">
+      <enum>Qt::Vertical</enum>
+     </property>
+     <property name="sizeHint" stdset="0">
+      <size>
+       <width>20</width>
+       <height>40</height>
+      </size>
+     </property>
+    </spacer>
+   </item>
+  </layout>
+ </widget>
+ <resources/>
+ <connections/>
+</ui>
diff --git a/src/plugins/genericprojectmanager/genericprojectmanager.pro b/src/plugins/genericprojectmanager/genericprojectmanager.pro
index bc932c3b01b4445460bd43a9a9114db590f92812..9ffb539b88bec25f78d3fdcd7a784937b7431039 100644
--- a/src/plugins/genericprojectmanager/genericprojectmanager.pro
+++ b/src/plugins/genericprojectmanager/genericprojectmanager.pro
@@ -20,3 +20,4 @@ SOURCES = genericproject.cpp \
     pkgconfigtool.cpp \
     genericmakestep.cpp
 RESOURCES += genericproject.qrc
+FORMS += genericmakestep.ui